ajax.render.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <?php
  2. require_once('../application/application.inc.php');
  3. require_once('../application/webpage.class.inc.php');
  4. require_once('../application/ajaxwebpage.class.inc.php');
  5. require_once('../application/wizardhelper.class.inc.php');
  6. require_once('../application/ui.linkswidget.class.inc.php');
  7. require_once('../application/startup.inc.php');
  8. session_start();
  9. if (isset($_SESSION['auth_user']))
  10. {
  11. $sAuthUser = $_SESSION['auth_user'];
  12. $sAuthPwd = $_SESSION['auth_pwd'];
  13. // Attempt to login, fails silently
  14. UserRights::Login($sAuthUser, $sAuthPwd);
  15. }
  16. else
  17. {
  18. // No session information
  19. echo "<p>No session information</p>\n";
  20. }
  21. $oPage = new ajax_page("");
  22. $oPage->no_cache();
  23. $oContext = new UserContext();
  24. $operation = utils::ReadParam('operation', '');
  25. $sFilter = stripslashes(utils::ReadParam('filter', ''));
  26. $sEncoding = utils::ReadParam('encoding', 'serialize');
  27. $sClass = utils::ReadParam('class', 'bizContact');
  28. $sStyle = utils::ReadParam('style', 'list');
  29. switch($operation)
  30. {
  31. case 'wizard_helper_preview':
  32. $sJson = utils::ReadParam('json_obj', '', 'post');
  33. $oWizardHelper = WizardHelper::FromJSON($sJson);
  34. $oObj = $oWizardHelper->GetTargetObject();
  35. $oObj->DisplayBareDetails($oPage);
  36. break;
  37. case 'wizard_helper':
  38. $sJson = utils::ReadParam('json_obj', '');
  39. $oWizardHelper = WizardHelper::FromJSON($sJson);
  40. $oObj = $oWizardHelper->GetTargetObject();
  41. foreach($oWizardHelper->GetFieldsForDefaultValue() as $sAttCode)
  42. {
  43. $oAttDef = MetaModel::GetAttributeDef(get_class($oObj), $sAttCode);
  44. $oWizardHelper->SetDefaultValue($sAttCode, $oAttDef->GetDefaultValue());
  45. }
  46. foreach($oWizardHelper->GetFieldsForAllowedValues() as $sAttCode)
  47. {
  48. $oWizardHelper->SetAllowedValuesHtml($sAttCode, "Possible values ($sAttCode)");
  49. }
  50. $oPage->add($oWizardHelper->ToJSON());
  51. break;
  52. case 'ajax':
  53. if ($sFilter != "")
  54. {
  55. if ($sEncoding == 'sibusql')
  56. {
  57. $oFilter = CMDBSearchFilter::FromSibusQL($sFilter);
  58. }
  59. else
  60. {
  61. $oFilter = CMDBSearchFilter::unserialize($sFilter);
  62. }
  63. $oDisplayBlock = new DisplayBlock($oFilter, $sStyle, false);
  64. $oDisplayBlock->RenderContent($oPage);
  65. }
  66. else
  67. {
  68. $oPage->p("Invalid query (empty filter).");
  69. }
  70. break;
  71. case 'details':
  72. $key = utils::ReadParam('id', 0);
  73. $oFilter = $oContext->NewFilter($sClass);
  74. $oFilter->AddCondition('pkey', $key, '=');
  75. $oDisplayBlock = new DisplayBlock($oFilter, 'details', false);
  76. $oDisplayBlock->RenderContent($oPage);
  77. break;
  78. case 'preview':
  79. $key = utils::ReadParam('id', 0);
  80. $oFilter = $oContext->NewFilter($sClass);
  81. $oFilter->AddCondition('pkey', $key, '=');
  82. $oDisplayBlock = new DisplayBlock($oFilter, 'preview', false);
  83. $oDisplayBlock->RenderContent($oPage);
  84. break;
  85. case 'pie_chart':
  86. $sGroupBy = utils::ReadParam('group_by', '');
  87. if ($sFilter != '')
  88. {
  89. if ($sEncoding == 'oql')
  90. {
  91. $oFilter = CMDBSearchFilter::FromOQL($sFilter);
  92. }
  93. else
  94. {
  95. $oFilter = CMDBSearchFilter::unserialize($sFilter);
  96. }
  97. $oDisplayBlock = new DisplayBlock($oFilter, 'pie_chart_ajax', false);
  98. $oDisplayBlock->RenderContent($oPage, array('group_by' => $sGroupBy));
  99. }
  100. else
  101. {
  102. $oPage->add("<chart>\n<chart_type>3d pie</chart_type><!-- empty filter '$sFilter' --></chart>\n.");
  103. }
  104. break;
  105. case 'open_flash_chart':
  106. $aParams = utils::ReadParam('params', array());
  107. if ($sFilter != '')
  108. {
  109. if ($sEncoding == 'oql')
  110. {
  111. $oFilter = CMDBSearchFilter::FromOQL($sFilter);
  112. }
  113. else
  114. {
  115. $oFilter = CMDBSearchFilter::unserialize($sFilter);
  116. }
  117. $oDisplayBlock = new DisplayBlock($oFilter, 'open_flash_chart_ajax', false);
  118. $oDisplayBlock->RenderContent($oPage, $aParams);
  119. }
  120. else
  121. {
  122. $oPage->add("<chart>\n<chart_type>3d pie</chart_type><!-- empty filter '$sFilter' --></chart>\n.");
  123. }
  124. break;
  125. case 'modal_details':
  126. $key = utils::ReadParam('id', 0);
  127. $oFilter = $oContext->NewFilter($sClass);
  128. $oFilter->AddCondition('pkey', $key, '=');
  129. $oPage->Add("<p style=\"width:100%; margin-top:-5px;padding:3px; background-color:#33f; color:#fff;\">Object Details</p>\n");
  130. $oDisplayBlock = new DisplayBlock($oFilter, 'details', false);
  131. $oDisplayBlock->RenderContent($oPage);
  132. $oPage->Add("<input type=\"button\" class=\"jqmClose\" value=\" Close \" />\n");
  133. break;
  134. case 'ui.linkswidget':
  135. $sClass = utils::ReadParam('sclass', 'bizContact');
  136. $sAttCode = utils::ReadParam('attCode', 'name');
  137. $sOrg = utils::ReadParam('org_id', '');
  138. $sName = utils::ReadParam('q', '');
  139. $iMaxCount = utils::ReadParam('max', 30);
  140. UILinksWidget::Autocomplete($oPage, $oContext, $sClass, $sAttCode, $sName, $iMaxCount);
  141. break;
  142. case 'ui.linkswidget.linkedset':
  143. $sClass = utils::ReadParam('sclass', 'bizContact');
  144. $sJSONSet = stripslashes(utils::ReadParam('sset', ''));
  145. $sExtKeyToMe = utils::ReadParam('sextkeytome', '');
  146. UILinksWidget::RenderSet($oPage, $sClass, $sJSONSet, $sExtKeyToMe);
  147. break;
  148. case 'autocomplete':
  149. $key = utils::ReadParam('id', 0);
  150. $sClass = utils::ReadParam('sclass', 'bizContact');
  151. $sAttCode = utils::ReadParam('attCode', 'name');
  152. $sOrg = utils::ReadParam('org_id', '');
  153. $sName = utils::ReadParam('q', '');
  154. $iMaxCount = utils::ReadParam('max', 30);
  155. $aArgs = array();
  156. if (!empty($key))
  157. {
  158. if ($oThis = MetaModel::GetObject($sClass, $key))
  159. {
  160. $aArgs['*this*'] = $oThis;
  161. }
  162. }
  163. $aAllowedValues = MetaModel::GetAllowedValues_att($sClass, $sAttCode, $aArgs, $sName);
  164. $iCount = 0;
  165. foreach($aAllowedValues as $key => $value)
  166. {
  167. $oPage->add($value."|".$key."\n");
  168. if ($iCount++) break;
  169. }
  170. break;
  171. case 'link':
  172. $sClass = utils::ReadParam('sclass', 'logInfra');
  173. $sAttCode = utils::ReadParam('attCode', 'name');
  174. //$sOrg = utils::ReadParam('org_id', '');
  175. $sName = utils::ReadParam('q', '');
  176. $iMaxCount = utils::ReadParam('max', 30);
  177. $iCount = 0;
  178. $oFilter = $oContext->NewFilter($sClass);
  179. $oFilter->AddCondition($sAttCode, $sName, 'Begins with');
  180. //$oFilter->AddCondition('org_id', $sOrg);
  181. $oSet = new CMDBObjectSet($oFilter, array($sAttCode => true));
  182. while( ($iCount < $iMaxCount) && ($oObj = $oSet->fetch()) )
  183. {
  184. $oPage->add($oObj->GetAsHTML($sAttCode)."|".$oObj->GetKey()."\n");
  185. $iCount++;
  186. }
  187. break;
  188. case 'create':
  189. case 'create_menu':
  190. $sClass = utils::ReadParam('class', '');
  191. $sFilter = utils::ReadParam('filter', '');
  192. menuNode::DisplayCreationForm($oPage, $sClass, $sFilter);
  193. break;
  194. case 'combo_options':
  195. $oFilter = CMDBSearchFilter::FromSibusQL($sFilter);
  196. $oSet = new CMDBObjectSet($oFilter);
  197. while( $oObj = $oSet->fetch())
  198. {
  199. $oPage->add('<option title="Here is more information..." value="'.$oObj->GetKey().'">'.$oObj->GetDisplayName().'</option>');
  200. }
  201. break;
  202. default:
  203. $oPage->p("Invalid query.");
  204. }
  205. $oPage->output();
  206. ?>