PageRenderTime 43ms CodeModel.GetById 14ms RepoModel.GetById 1ms app.codeStats 0ms

/modules/security/install/index.php

https://gitlab.com/alexprowars/bitrix
PHP | 321 lines | 286 code | 32 blank | 3 comment | 18 complexity | f1df7c991e4defba60501d6f77e7ff11 MD5 | raw file
  1. <?
  2. IncludeModuleLangFile(__FILE__);
  3. if(class_exists("security")) return;
  4. Class security extends CModule
  5. {
  6. var $MODULE_ID = "security";
  7. var $MODULE_VERSION;
  8. var $MODULE_VERSION_DATE;
  9. var $MODULE_NAME;
  10. var $MODULE_DESCRIPTION;
  11. var $MODULE_CSS;
  12. var $MODULE_GROUP_RIGHTS = "Y";
  13. public function __construct()
  14. {
  15. $arModuleVersion = array();
  16. include(__DIR__.'/version.php');
  17. $this->MODULE_VERSION = $arModuleVersion["VERSION"];
  18. $this->MODULE_VERSION_DATE = $arModuleVersion["VERSION_DATE"];
  19. $this->MODULE_NAME = GetMessage("SEC_MODULE_NAME");
  20. $this->MODULE_DESCRIPTION = GetMessage("SEC_MODULE_DESCRIPTION");
  21. }
  22. function GetModuleTasks()
  23. {
  24. return array(
  25. 'security_denied' => array(
  26. "LETTER" => "D",
  27. "BINDING" => "module",
  28. "OPERATIONS" => array(
  29. ),
  30. ),
  31. 'security_filter' => array(
  32. "LETTER" => "F",
  33. "BINDING" => "module",
  34. "OPERATIONS" => array(
  35. 'security_filter_bypass',
  36. ),
  37. ),
  38. 'security_otp' => array(
  39. "LETTER" => "S",
  40. "BINDING" => "module",
  41. "OPERATIONS" => array(
  42. 'security_edit_user_otp',
  43. ),
  44. ),
  45. 'security_view_all_settings' => array(
  46. "LETTER" => "T",
  47. "BINDING" => "module",
  48. "OPERATIONS" => array(
  49. 'security_module_settings_read',
  50. 'security_panel_view',
  51. 'security_filter_settings_read',
  52. 'security_otp_settings_read',
  53. 'security_iprule_admin_settings_read',
  54. 'security_session_settings_read',
  55. 'security_redirect_settings_read',
  56. 'security_stat_activity_settings_read',
  57. 'security_iprule_settings_read',
  58. 'security_antivirus_settings_read',
  59. 'security_frame_settings_read',
  60. ),
  61. ),
  62. 'security_full_access' => array(
  63. "LETTER" => "W",
  64. "BINDING" => "module",
  65. "OPERATIONS" => array(
  66. 'security_edit_user_otp',
  67. 'security_filter_bypass',
  68. 'security_module_settings_read',
  69. 'security_module_settings_write',
  70. 'security_panel_view',
  71. 'security_filter_settings_read',
  72. 'security_filter_settings_write',
  73. 'security_otp_settings_read',
  74. 'security_otp_settings_write',
  75. 'security_iprule_admin_settings_read',
  76. 'security_iprule_admin_settings_write',
  77. 'security_session_settings_read',
  78. 'security_session_settings_write',
  79. 'security_redirect_settings_read',
  80. 'security_redirect_settings_write',
  81. 'security_stat_activity_settings_read',
  82. 'security_stat_activity_settings_write',
  83. 'security_iprule_settings_read',
  84. 'security_iprule_settings_write',
  85. 'security_file_verifier_sign',
  86. 'security_file_verifier_collect',
  87. 'security_file_verifier_verify',
  88. 'security_antivirus_settings_read',
  89. 'security_antivirus_settings_write',
  90. 'security_frame_settings_read',
  91. 'security_frame_settings_write',
  92. ),
  93. ),
  94. );
  95. }
  96. function InstallDB($arParams = array())
  97. {
  98. global $DB, $DBType, $APPLICATION;
  99. $this->errors = false;
  100. // Database tables creation
  101. if(!$DB->Query("SELECT 'x' FROM b_sec_iprule WHERE 1=0", true))
  102. {
  103. $this->errors = $DB->RunSQLBatch($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/db/".mb_strtolower($DB->type)."/install.sql");
  104. }
  105. if($this->errors !== false)
  106. {
  107. $APPLICATION->ThrowException(implode("<br>", $this->errors));
  108. return false;
  109. }
  110. else
  111. {
  112. $this->InstallTasks();
  113. RegisterModule("security");
  114. RegisterModuleDependences("main", "OnUserDelete", "security", "CSecurityUser", "OnUserDelete");
  115. RegisterModuleDependences("main", "OnEventLogGetAuditTypes", "security", "CSecurityFilter", "GetAuditTypes");
  116. RegisterModuleDependences("main", "OnEventLogGetAuditTypes", "security", "CSecurityAntiVirus", "GetAuditTypes");
  117. RegisterModuleDependences("main", "OnAdminInformerInsertItems", "security", "CSecurityFilter", "OnAdminInformerInsertItems");
  118. RegisterModuleDependences("main", "OnAdminInformerInsertItems", "security", "CSecuritySiteChecker", "OnAdminInformerInsertItems");
  119. CModule::IncludeModule("security");
  120. //agents
  121. CAgent::RemoveAgent("CSecuritySession::CleanUpAgent();", "security");
  122. CAgent::Add(array(
  123. "NAME"=>"CSecuritySession::CleanUpAgent();",
  124. "MODULE_ID"=>"security",
  125. "ACTIVE"=>"Y",
  126. "AGENT_INTERVAL"=>1800,
  127. "IS_PERIOD"=>"N",
  128. ));
  129. CAgent::RemoveAgent("CSecurityIPRule::CleanUpAgent();", "security");
  130. CAgent::Add(array(
  131. "NAME"=>"CSecurityIPRule::CleanUpAgent();",
  132. "MODULE_ID"=>"security",
  133. "ACTIVE"=>"Y",
  134. "AGENT_INTERVAL"=>3600,
  135. "IS_PERIOD"=>"N",
  136. ));
  137. if(!COption::GetOptionString("security", "ipcheck_disable_file"))
  138. COption::SetOptionString("security", "ipcheck_disable_file", "/bitrix/modules/ipcheck_disable_".md5(mt_rand()));
  139. CAgent::RemoveAgent("CSecurityFilter::ClearTmpFiles();", "security");
  140. CSecurityFilter::SetActive(true);
  141. CSecurityRedirect::SetActive(true);
  142. return true;
  143. }
  144. }
  145. function UnInstallDB($arParams = array())
  146. {
  147. global $DB, $DBType, $APPLICATION;
  148. $this->errors = false;
  149. UnRegisterModuleDependences("main", "OnPageStart", "security", "CSecurityIPRule", "OnPageStart");
  150. UnRegisterModuleDependences("main", "OnBeforeProlog", "security", "CSecurityFilter", "OnBeforeProlog");
  151. UnRegisterModuleDependences("main", "OnEndBufferContent", "security", "CSecurityXSSDetect", "OnEndBufferContent");
  152. UnRegisterModuleDependences("main", "OnBeforeUserLogin", "security", "CSecurityUser", "OnBeforeUserLogin");
  153. UnRegisterModuleDependences("main", "OnUserDelete", "security", "CSecurityUser", "OnUserDelete");
  154. UnRegisterModuleDependences("main", "OnEventLogGetAuditTypes", "security", "CSecurityFilter", "GetAuditTypes");
  155. UnRegisterModuleDependences("main", "OnEventLogGetAuditTypes", "security", "CSecurityAntiVirus", "GetAuditTypes");
  156. UnRegisterModuleDependences("main", "OnBeforeLocalRedirect", "security", "CSecurityRedirect", "BeforeLocalRedirect");
  157. UnRegisterModuleDependences("main", "OnEndBufferContent", "security", "CSecurityRedirect", "EndBufferContent");
  158. UnRegisterModuleDependences("main", "OnAdminInformerInsertItems", "security", "CSecurityFilter", "OnAdminInformerInsertItems");
  159. UnRegisterModuleDependences("main", "OnAdminInformerInsertItems", "security", "CSecuritySiteChecker", "OnAdminInformerInsertItems");
  160. COption::SetOptionString("main", "session_id_ttl", "60");
  161. COption::SetOptionString("main", "use_session_id_ttl", "N");
  162. COption::SetOptionInt("main", "session_id_ttl", 60);
  163. COption::SetOptionString("security", "session", "N");
  164. if(!array_key_exists("save_tables", $arParams) || $arParams["save_tables"] != "Y")
  165. {
  166. $this->errors = $DB->RunSQLBatch($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/db/".mb_strtolower($DB->type)."/uninstall.sql");
  167. $this->UnInstallTasks();
  168. }
  169. UnRegisterModule("security");
  170. if($this->errors !== false)
  171. {
  172. $APPLICATION->ThrowException(implode("<br>", $this->errors));
  173. return false;
  174. }
  175. return true;
  176. }
  177. function InstallEvents()
  178. {
  179. global $DB;
  180. $sIn = "'VIRUS_DETECTED'";
  181. $rs = $DB->Query("SELECT count(*) C FROM b_event_type WHERE EVENT_NAME IN (".$sIn.") ", false, "File: ".__FILE__."<br>Line: ".__LINE__);
  182. $ar = $rs->Fetch();
  183. if($ar["C"] <= 0)
  184. {
  185. include($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/events.php");
  186. }
  187. return true;
  188. }
  189. function UnInstallEvents()
  190. {
  191. global $DB;
  192. $sIn = "'VIRUS_DETECTED'";
  193. $DB->Query("DELETE FROM b_event_message WHERE EVENT_NAME IN (".$sIn.") ", false, "File: ".__FILE__."<br>Line: ".__LINE__);
  194. $DB->Query("DELETE FROM b_event_type WHERE EVENT_NAME IN (".$sIn.") ", false, "File: ".__FILE__."<br>Line: ".__LINE__);
  195. return true;
  196. }
  197. function InstallFiles($arParams = array())
  198. {
  199. if($_ENV["COMPUTERNAME"]!='BX')
  200. {
  201. CopyDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/admin", $_SERVER["DOCUMENT_ROOT"]."/bitrix/admin");
  202. CopyDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/otp", $_SERVER["DOCUMENT_ROOT"]."/bitrix/otp", true, true);
  203. CopyDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/js/security", $_SERVER["DOCUMENT_ROOT"]."/bitrix/js/security", true, true);
  204. CopyDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/images", $_SERVER["DOCUMENT_ROOT"]."/bitrix/images/security", false, true);
  205. CopyDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/themes", $_SERVER["DOCUMENT_ROOT"]."/bitrix/themes", true, true);
  206. CopyDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/components", $_SERVER["DOCUMENT_ROOT"]."/bitrix/components", True, True);
  207. }
  208. return true;
  209. }
  210. function UnInstallFiles()
  211. {
  212. DeleteDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/admin/", $_SERVER["DOCUMENT_ROOT"]."/bitrix/admin");
  213. DeleteDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/otp/", $_SERVER["DOCUMENT_ROOT"]."/bitrix/otp");
  214. DeleteDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/js/security/", $_SERVER["DOCUMENT_ROOT"]."/bitrix/js/security");
  215. DeleteDirFiles($_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/themes/.default/", $_SERVER["DOCUMENT_ROOT"]."/bitrix/themes/.default");
  216. DeleteDirFilesEx("/bitrix/themes/.default/icons/security/");
  217. DeleteDirFilesEx("/bitrix/images/security/");
  218. return true;
  219. }
  220. function DoInstall()
  221. {
  222. global $DB, $DOCUMENT_ROOT, $APPLICATION, $step;
  223. $SEC_RIGHT = $APPLICATION->GetGroupRight("security");
  224. if($SEC_RIGHT >= "W")
  225. {
  226. $step = intval($step);
  227. if($step < 2)
  228. {
  229. $APPLICATION->IncludeAdminFile(GetMessage("SEC_INSTALL_TITLE"), $_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/step1.php");
  230. }
  231. elseif($step==2)
  232. {
  233. if($this->InstallDB())
  234. {
  235. $this->InstallEvents();
  236. $this->InstallFiles();
  237. }
  238. $GLOBALS["errors"] = $this->errors;
  239. $APPLICATION->IncludeAdminFile(GetMessage("SEC_INSTALL_TITLE"), $_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/step2.php");
  240. }
  241. }
  242. }
  243. function DoUninstall()
  244. {
  245. global $DB, $DOCUMENT_ROOT, $APPLICATION, $step;
  246. $SEC_RIGHT = $APPLICATION->GetGroupRight("security");
  247. if($SEC_RIGHT >= "W")
  248. {
  249. $step = intval($step);
  250. if($step < 2)
  251. {
  252. $APPLICATION->IncludeAdminFile(GetMessage("SEC_UNINSTALL_TITLE"), $_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/unstep1.php");
  253. }
  254. elseif($step == 2)
  255. {
  256. $this->UnInstallDB(array(
  257. "save_tables" => $_REQUEST["save_tables"],
  258. ));
  259. //message types and templates
  260. if($_REQUEST["save_templates"] != "Y")
  261. {
  262. $this->UnInstallEvents();
  263. }
  264. $this->UnInstallFiles();
  265. $GLOBALS["errors"] = $this->errors;
  266. $APPLICATION->IncludeAdminFile(GetMessage("SEC_UNINSTALL_TITLE"), $_SERVER["DOCUMENT_ROOT"]."/bitrix/modules/security/install/unstep2.php");
  267. }
  268. }
  269. }
  270. function GetModuleRightList()
  271. {
  272. $arr = array(
  273. "reference_id" => array("D","F","S","T","W"),
  274. "reference" => array(
  275. "[D] ".GetMessage("SEC_DENIED"),
  276. "[F] ".GetMessage("SEC_FILTER"),
  277. "[S] ".GetMessage("SEC_PASSWORD"),
  278. "[T] ".GetMessage("SEC_VIEW"),
  279. "[W] ".GetMessage("SEC_ADMIN"),
  280. )
  281. );
  282. return $arr;
  283. }
  284. public function migrateToBox()
  285. {
  286. CModule::IncludeModule('security');
  287. CSecuritySession::deactivate();
  288. }
  289. }