123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361 |
- <?php
- if (!defined('SMF'))
- die('No direct access...');
- function RegCenter()
- {
- global $context, $txt, $scripturl;
-
- if (isset($_REQUEST['sa']) && $_REQUEST['sa'] == 'browse')
- redirectexit('action=admin;area=viewmembers;sa=browse' . (isset($_REQUEST['type']) ? ';type=' . $_REQUEST['type'] : ''));
- $subActions = array(
- 'register' => array('AdminRegister', 'moderate_forum'),
- 'agreement' => array('EditAgreement', 'admin_forum'),
- 'reservednames' => array('SetReserved', 'admin_forum'),
- 'settings' => array('ModifyRegistrationSettings', 'admin_forum'),
- );
- call_integration_hook('integrate_manage_registrations', array(&$subActions));
-
- $context['sub_action'] = isset($_REQUEST['sa']) && isset($subActions[$_REQUEST['sa']]) ? $_REQUEST['sa'] : (allowedTo('moderate_forum') ? 'register' : 'settings');
-
- isAllowedTo($subActions[$context['sub_action']][1]);
-
- loadLanguage('Login');
- loadTemplate('Register');
-
- $context[$context['admin_menu_name']]['tab_data'] = array(
- 'title' => $txt['registration_center'],
- 'help' => 'registrations',
- 'description' => $txt['admin_settings_desc'],
- 'tabs' => array(
- 'register' => array(
- 'description' => $txt['admin_register_desc'],
- ),
- 'agreement' => array(
- 'description' => $txt['registration_agreement_desc'],
- ),
- 'reservednames' => array(
- 'description' => $txt['admin_reserved_desc'],
- ),
- 'settings' => array(
- 'description' => $txt['admin_settings_desc'],
- )
- )
- );
-
- $subActions[$context['sub_action']][0]();
- }
- function AdminRegister()
- {
- global $txt, $context, $sourcedir, $scripturl, $smcFunc;
-
- require_once($sourcedir . '/Profile.php');
- loadCustomFields(0, 'register');
- if (!empty($_POST['regSubmit']))
- {
- checkSession();
- validateToken('admin-regc');
- foreach ($_POST as $key => $value)
- if (!is_array($_POST[$key]))
- $_POST[$key] = htmltrim__recursive(str_replace(array("\n", "\r"), '', $_POST[$key]));
- $regOptions = array(
- 'interface' => 'admin',
- 'username' => $_POST['user'],
- 'email' => $_POST['email'],
- 'password' => $_POST['password'],
- 'password_check' => $_POST['password'],
- 'check_reserved_name' => true,
- 'check_password_strength' => false,
- 'check_email_ban' => false,
- 'send_welcome_email' => isset($_POST['emailPassword']) || empty($_POST['password']),
- 'require' => isset($_POST['emailActivate']) ? 'activation' : 'nothing',
- 'memberGroup' => empty($_POST['group']) || !allowedTo('manage_membergroups') ? 0 : (int) $_POST['group'],
- );
- require_once($sourcedir . '/Subs-Members.php');
- $memberID = registerMember($regOptions);
- if (!empty($memberID))
- {
-
- if (!empty($_POST['customfield']))
- {
- require_once($sourcedir . '/Profile-Modify.php');
- makeCustomFieldChanges($memberID, 'register');
- }
- $context['new_member'] = array(
- 'id' => $memberID,
- 'name' => $_POST['user'],
- 'href' => $scripturl . '?action=profile;u=' . $memberID,
- 'link' => '<a href="' . $scripturl . '?action=profile;u=' . $memberID . '">' . $_POST['user'] . '</a>',
- );
- $context['registration_done'] = sprintf($txt['admin_register_done'], $context['new_member']['link']);
- }
- }
-
- if (allowedTo('manage_membergroups'))
- {
- $request = $smcFunc['db_query']('', '
- SELECT group_name, id_group
- FROM {db_prefix}membergroups
- WHERE id_group != {int:moderator_group}
- AND min_posts = {int:min_posts}' . (allowedTo('admin_forum') ? '' : '
- AND id_group != {int:admin_group}
- AND group_type != {int:is_protected}') . '
- AND hidden != {int:hidden_group}
- ORDER BY min_posts, CASE WHEN id_group < {int:newbie_group} THEN id_group ELSE 4 END, group_name',
- array(
- 'moderator_group' => 3,
- 'min_posts' => -1,
- 'admin_group' => 1,
- 'is_protected' => 1,
- 'hidden_group' => 2,
- 'newbie_group' => 4,
- )
- );
- $context['member_groups'] = array(0 => $txt['admin_register_group_none']);
- while ($row = $smcFunc['db_fetch_assoc']($request))
- $context['member_groups'][$row['id_group']] = $row['group_name'];
- $smcFunc['db_free_result']($request);
- }
- else
- $context['member_groups'] = array();
-
- $context['sub_template'] = 'admin_register';
- $context['page_title'] = $txt['registration_center'];
- createToken('admin-regc');
- loadJavascriptFile('register.js', array('default_theme' => true, 'defer' => false), 'smf_register');
- }
- function EditAgreement()
- {
-
- global $txt, $boarddir, $context, $modSettings, $smcFunc;
-
- $context['current_agreement'] = '';
-
- $context['editable_agreements'] = array(
- '' => $txt['admin_agreement_default'],
- );
-
- getLanguages();
-
- foreach ($context['languages'] as $lang)
- {
- if (file_exists($boarddir . '/agreement.' . $lang['filename'] . '.txt'))
- {
- $context['editable_agreements']['.' . $lang['filename']] = $lang['name'];
-
- if (isset($_POST['agree_lang']) && $_POST['agree_lang'] == '.' . $lang['filename'])
- $context['current_agreement'] = '.' . $lang['filename'];
- }
- }
- if (isset($_POST['agreement']))
- {
- checkSession();
- validateToken('admin-rega');
-
- $to_write = str_replace("\r", '', $_POST['agreement']);
- $bytes = file_put_contents($boarddir . '/agreement' . $context['current_agreement'] . '.txt', $to_write, LOCK_EX);
- updateSettings(array('requireAgreement' => !empty($_POST['requireAgreement'])));
- if ($bytes == strlen($to_write))
- $context['saved_successful'] = true;
- else
- $context['could_not_save'] = true;
- }
- $context['agreement'] = file_exists($boarddir . '/agreement' . $context['current_agreement'] . '.txt') ? $smcFunc['htmlspecialchars'](file_get_contents($boarddir . '/agreement' . $context['current_agreement'] . '.txt')) : '';
- $context['warning'] = is_writable($boarddir . '/agreement' . $context['current_agreement'] . '.txt') ? '' : $txt['agreement_not_writable'];
- $context['require_agreement'] = !empty($modSettings['requireAgreement']);
- $context['sub_template'] = 'edit_agreement';
- $context['page_title'] = $txt['registration_agreement'];
- createToken('admin-rega');
- }
- function SetReserved()
- {
- global $txt, $context, $modSettings;
-
- if (!empty($_POST['save_reserved_names']))
- {
- checkSession();
- validateToken('admin-regr');
-
- updateSettings(array(
- 'reserveWord' => (isset($_POST['matchword']) ? '1' : '0'),
- 'reserveCase' => (isset($_POST['matchcase']) ? '1' : '0'),
- 'reserveUser' => (isset($_POST['matchuser']) ? '1' : '0'),
- 'reserveName' => (isset($_POST['matchname']) ? '1' : '0'),
- 'reserveNames' => str_replace("\r", '', $_POST['reserved'])
- ));
- $context['saved_successful'] = true;
- }
-
- $modSettings['reserveNames'] = str_replace('\n', "\n", $modSettings['reserveNames']);
- $context['reserved_words'] = explode("\n", $modSettings['reserveNames']);
- $context['reserved_word_options'] = array();
- $context['reserved_word_options']['match_word'] = $modSettings['reserveWord'] == '1';
- $context['reserved_word_options']['match_case'] = $modSettings['reserveCase'] == '1';
- $context['reserved_word_options']['match_user'] = $modSettings['reserveUser'] == '1';
- $context['reserved_word_options']['match_name'] = $modSettings['reserveName'] == '1';
-
- $context['sub_template'] = 'edit_reserved_words';
- $context['page_title'] = $txt['admin_reserved_set'];
- createToken('admin-regr');
- }
- function ModifyRegistrationSettings($return_config = false)
- {
- global $txt, $context, $scripturl, $modSettings, $sourcedir;
-
- require_once($sourcedir . '/ManageServer.php');
- $config_vars = array(
- array('select', 'registration_method', array($txt['setting_registration_standard'], $txt['setting_registration_activate'], $txt['setting_registration_approval'], $txt['setting_registration_disabled'])),
- array('select', 'enableOpenID', array(0 => $txt['enableOpenID_disabled'], 1 => $txt['enableOpenID_enabled'], 2 => $txt['enableOpenID_enabled_login'])),
- array('check', 'send_welcomeEmail'),
- '',
- array('int', 'coppaAge', 'subtext' => $txt['setting_coppaAge_desc'], 'onchange' => 'checkCoppa();', 'onkeyup' => 'checkCoppa();'),
- array('select', 'coppaType', array($txt['setting_coppaType_reject'], $txt['setting_coppaType_approval']), 'onchange' => 'checkCoppa();'),
- array('large_text', 'coppaPost', 'subtext' => $txt['setting_coppaPost_desc']),
- array('text', 'coppaFax'),
- array('text', 'coppaPhone'),
- );
- call_integration_hook('integrate_modify_registration_settings', array(&$config_vars));
- if ($return_config)
- return $config_vars;
-
- $context['sub_template'] = 'show_settings';
- $context['page_title'] = $txt['registration_center'];
- if (isset($_GET['save']))
- {
- checkSession();
-
- if (!empty($_POST['coppaAge']) && !empty($_POST['coppaType']) && empty($_POST['coppaPost']) && empty($_POST['coppaFax']))
- fatal_lang_error('admin_setting_coppa_require_contact');
-
- $_POST['coppaPost'] = str_replace("\n", '<br>', empty($_POST['coppaPost']) ? '' : $_POST['coppaPost']);
- call_integration_hook('integrate_save_registration_settings');
- saveDBSettings($config_vars);
- $_SESSION['adm-save'] = true;
- redirectexit('action=admin;area=regcenter;sa=settings');
- }
- $context['post_url'] = $scripturl . '?action=admin;area=regcenter;save;sa=settings';
- $context['settings_title'] = $txt['settings'];
-
- $context['settings_post_javascript'] = '
- function checkCoppa()
- {
- var coppaDisabled = document.getElementById(\'coppaAge\').value == 0;
- document.getElementById(\'coppaType\').disabled = coppaDisabled;
- var disableContacts = coppaDisabled || document.getElementById(\'coppaType\').options[document.getElementById(\'coppaType\').selectedIndex].value != 1;
- document.getElementById(\'coppaPost\').disabled = disableContacts;
- document.getElementById(\'coppaFax\').disabled = disableContacts;
- document.getElementById(\'coppaPhone\').disabled = disableContacts;
- }
- checkCoppa();';
-
- $modSettings['coppaPost'] = !empty($modSettings['coppaPost']) ? preg_replace('~<br ?/?' . '>~', "\n", $modSettings['coppaPost']) : '';
- prepareDBSettingContext($config_vars);
- }
- ?>
|