[25028] | 1 | <?php |
---|
| 2 | |
---|
| 3 | global $user, $lang, $conf, $errors; |
---|
| 4 | |
---|
| 5 | if (!defined('PHPWG_ROOT_PATH')) die('Hacking attempt!'); |
---|
| 6 | // +-----------------------------------------------------------------------+ |
---|
| 7 | // | Check Access and exit when user status is not ok | |
---|
| 8 | // +-----------------------------------------------------------------------+ |
---|
| 9 | check_status(ACCESS_ADMINISTRATOR); |
---|
| 10 | |
---|
| 11 | if (!defined('PP_PATH')) define('PP_PATH' , PHPWG_PLUGINS_PATH.basename(dirname(__FILE__)).'/'); |
---|
| 12 | |
---|
| 13 | //ini_set('error_reporting', E_ALL); |
---|
| 14 | //ini_set('display_errors', true); |
---|
| 15 | |
---|
| 16 | include_once (PHPWG_ROOT_PATH.'/include/constants.php'); |
---|
| 17 | |
---|
| 18 | load_language('plugin.lang', PP_PATH); |
---|
| 19 | |
---|
| 20 | |
---|
| 21 | // +-----------------------------------------------------------------------+ |
---|
| 22 | // | Variables initialization | |
---|
| 23 | // +-----------------------------------------------------------------------+ |
---|
| 24 | $page['global'] = array(); |
---|
| 25 | $error = array(); |
---|
| 26 | |
---|
| 27 | $PP_Password_Test_Score = 0; |
---|
| 28 | |
---|
| 29 | // +-----------------------------------------------------------------------+ |
---|
| 30 | // | Getting plugin version | |
---|
| 31 | // +-----------------------------------------------------------------------+ |
---|
| 32 | $plugin = PPInfos(PP_PATH); |
---|
| 33 | $version = $plugin['version']; |
---|
| 34 | |
---|
| 35 | |
---|
[25089] | 36 | // +----------------------------------------------------------+ |
---|
| 37 | // | FCK Editor for email text fields | |
---|
| 38 | // +----------------------------------------------------------+ |
---|
| 39 | $toolbar = 'Basic'; |
---|
| 40 | $width = '750px'; |
---|
| 41 | $height = '300px'; |
---|
| 42 | $areas = array(); |
---|
| 43 | array_push($areas,'PP_CustomLockMsg'); |
---|
| 44 | |
---|
| 45 | if (function_exists('set_fckeditor_instance')) |
---|
| 46 | { |
---|
| 47 | $fcke_config = unserialize($conf['FCKEditor']); |
---|
| 48 | foreach($areas as $area) |
---|
[25028] | 49 | { |
---|
[25089] | 50 | if (!isset($fcke_config[$area])) |
---|
| 51 | { |
---|
| 52 | $fcke_config[$area] = false; |
---|
| 53 | } |
---|
| 54 | } |
---|
| 55 | $conf['FCKEditor'] = serialize($fcke_config); |
---|
| 56 | |
---|
| 57 | set_fckeditor_instance($areas, $toolbar, $width, $height); |
---|
| 58 | } |
---|
| 59 | |
---|
| 60 | |
---|
| 61 | if (isset($_POST['submit']) and isset($_POST['PP_Password_Enforced']) and isset($_POST['PP_AdminPassword_Enforced']) and isset($_POST['PP_PwdReset']) and isset($_POST['PP_LogFailedPassw'])) |
---|
| 62 | { |
---|
| 63 | $_POST['PP_CustomLockMsg'] = str_replace('\"', '"', str_replace("\'", "'", str_replace("\\\\", "\\", $_POST['PP_CustomLockMsg']))); |
---|
[25028] | 64 | // Save global PP configuration |
---|
| 65 | // ----------------------------- |
---|
| 66 | $newconf_PP['PPVersion'] = $version; |
---|
| 67 | $newconf_PP['PASSWORDENF'] = (isset($_POST['PP_Password_Enforced']) ? $_POST['PP_Password_Enforced'] : 'false'); |
---|
| 68 | $newconf_PP['PASSWORD_SCORE'] = (isset($_POST['PP_Password_Score']) ? $_POST['PP_Password_Score'] : '100'); |
---|
| 69 | $newconf_PP['ADMINPASSWENF'] = (isset($_POST['PP_AdminPassword_Enforced']) ? $_POST['PP_AdminPassword_Enforced'] : 'false'); |
---|
| 70 | $newconf_PP['PWDRESET'] = (isset($_POST['PP_PwdReset']) ? $_POST['PP_PwdReset'] : 'false'); |
---|
[25089] | 71 | $newconf_PP['LOGFAILBLOCK'] = (isset($_POST['PP_LogFailedPassw']) ? $_POST['PP_LogFailedPassw'] : 'false'); |
---|
| 72 | $newconf_PP['NBLOGFAIL'] = (isset($_POST['PP_NbFailedPassw']) ? $_POST['PP_NbFailedPassw'] : '0'); |
---|
| 73 | $newconf_PP['USRLOCKEDTXT'] = (isset($_POST['PP_CustomLockMsg']) ? $_POST['PP_CustomLockMsg'] : l10n('PP_User_Account_Locked_Txt')); |
---|
[25028] | 74 | |
---|
| 75 | $conf['PasswordPolicy'] = serialize($newconf_PP); |
---|
| 76 | |
---|
| 77 | conf_update_param('PasswordPolicy', pwg_db_real_escape_string($conf['PasswordPolicy'])); |
---|
| 78 | |
---|
| 79 | array_push($page['infos'], l10n('PP_save_config')); |
---|
| 80 | } |
---|
| 81 | |
---|
| 82 | // Testing password enforcement |
---|
| 83 | // ---------------------------- |
---|
| 84 | if (isset($_POST['PasswordTest']) and isset($_POST['PP_Password_Test']) and !empty($_POST['PP_Password_Test'])) |
---|
| 85 | { |
---|
| 86 | $PP_Password_Test_Score = PP_testpassword($_POST['PP_Password_Test']); |
---|
| 87 | } |
---|
| 88 | else if (isset($_POST['PasswordTest']) and empty($_POST['PP_Password_Test'])) |
---|
| 89 | { |
---|
[25050] | 90 | array_push($page['errors'], l10n('PP_Error_Password_Mandatory')); |
---|
[25028] | 91 | } |
---|
| 92 | |
---|
| 93 | $conf_PP = unserialize($conf['PasswordPolicy']); |
---|
| 94 | |
---|
| 95 | // ------------------------------------------ |
---|
| 96 | // Template initialization for forms and data |
---|
| 97 | // ------------------------------------------ |
---|
| 98 | $themeconf=$template->get_template_vars('themeconf'); |
---|
| 99 | $PP_theme=$themeconf['id']; |
---|
| 100 | |
---|
| 101 | $template->assign( |
---|
| 102 | array( |
---|
| 103 | 'PP_VERSION' => $version, |
---|
| 104 | 'PP_PATH' => PP_PATH, |
---|
| 105 | 'PP_PASSWORDENF_TRUE' => $conf_PP['PASSWORDENF']=='true' ? 'checked="checked"' : '' , |
---|
| 106 | 'PP_PASSWORDENF_FALSE' => $conf_PP['PASSWORDENF']=='false' ? 'checked="checked"' : '' , |
---|
| 107 | 'PP_PASSWORD_SCORE' => $conf_PP['PASSWORD_SCORE'], |
---|
| 108 | 'PP_ADMINPASSWENF_TRUE' => $conf_PP['ADMINPASSWENF']=='true' ? 'checked="checked"' : '' , |
---|
| 109 | 'PP_ADMINPASSWENF_FALSE' => $conf_PP['ADMINPASSWENF']=='false' ? 'checked="checked"' : '' , |
---|
| 110 | 'PP_PWDRESET_TRUE' => $conf_PP['PWDRESET']=='true' ? 'checked="checked"' : '' , |
---|
| 111 | 'PP_PWDRESET_FALSE' => $conf_PP['PWDRESET']=='false' ? 'checked="checked"' : '' , |
---|
| 112 | 'PP_PASSWORD_TEST_SCORE' => $PP_Password_Test_Score, |
---|
[25089] | 113 | 'PP_LOGFAILEDPASSW_TRUE' => $conf_PP['LOGFAILBLOCK']=='true' ? 'checked="checked"' : '' , |
---|
| 114 | 'PP_LOGFAILEDPASSW_FALSE' => $conf_PP['LOGFAILBLOCK']=='false' ? 'checked="checked"' : '' , |
---|
| 115 | 'PP_NBLOGFAIL' => $conf_PP['NBLOGFAIL'], |
---|
| 116 | 'PP_USRLOCKEDTXT' => $conf_PP['USRLOCKEDTXT'] |
---|
[25028] | 117 | ) |
---|
| 118 | ); |
---|
| 119 | |
---|
| 120 | |
---|
| 121 | // +-----------------------------------------------------------------------+ |
---|
| 122 | // | errors display | |
---|
| 123 | // +-----------------------------------------------------------------------+ |
---|
| 124 | if (isset ($errors) and count($errors) != 0) |
---|
| 125 | { |
---|
| 126 | $template->assign('errors',array()); |
---|
| 127 | foreach ($errors as $error) |
---|
| 128 | { |
---|
| 129 | array_push($page['errors'], $error); |
---|
| 130 | } |
---|
| 131 | } |
---|
| 132 | |
---|
| 133 | // +-----------------------------------------------------------------------+ |
---|
| 134 | // | templates display | |
---|
| 135 | // +-----------------------------------------------------------------------+ |
---|
| 136 | $template->set_filename('plugin_admin_content', dirname(__FILE__) . '/template/PP_admin.tpl'); |
---|
| 137 | $template->assign_var_from_handle('ADMIN_CONTENT', 'plugin_admin_content'); |
---|
| 138 | ?> |
---|