*/ /** * @class memberAdminView * @author NAVER (developers@xpressengine.com) * member module's admin view class */ class MemberAdminView extends Member { /** * Group list * * @var array */ var $group_list = NULL; /** * Selected member info * * @var array */ var $memberInfo = NULL; /** * Member module config. * * @var Object */ var $memberConfig = NULL; /** * initialization * * @return void */ function init() { $oMemberModel = getModel('member'); $this->memberConfig = $oMemberModel->getMemberConfig(); Context::set('config', $this->memberConfig); $oSecurity = new Security(); $oSecurity->encodeHTML('config.signupForm..'); // if member_srl exists, set memberInfo $member_srl = Context::get('member_srl'); if($member_srl) { $this->memberInfo = $oMemberModel->getMemberInfoByMemberSrl($member_srl); if(!$this->memberInfo) { Context::set('member_srl',''); } else { Context::set('member_info',$this->memberInfo); } } // retrieve group list $this->group_list = $oMemberModel->getGroups(); if ($this->act !== 'dispMemberAdminGroupList') { foreach ($this->group_list as $group) { $group->title = Context::replaceUserLang($group->title, true); } } Context::set('group_list', $this->group_list); $security = new Security(); $security->encodeHTML('group_list..', 'config..'); $this->setTemplatePath($this->module_path.'tpl'); } /** * display member list * * @return void */ function dispMemberAdminList() { $oMemberAdminModel = getAdminModel('member'); $oMemberModel = getModel('member'); $output = $oMemberAdminModel->getMemberList(); $filter_type = Context::get('filter_type'); global $lang; switch($filter_type) { case 'super_admin' : Context::set('filter_type_title', $lang->cmd_show_super_admin_member);break; case 'site_admin' : Context::set('filter_type_title', $lang->cmd_show_site_admin_member);break; default : Context::set('filter_type_title', $lang->cmd_show_all_member);break; } // retrieve list of groups for each member if($output->data) { foreach($output->data as $key => $member) { $output->data[$key]->group_list = $oMemberModel->getMemberGroups($member->member_srl,0); $output->data[$key]->profile_image = $oMemberModel->getProfileImage($member->member_srl); } } $config = $this->memberConfig; $memberIdentifiers = array( 'user_id' => 'user_id', 'email_address' => 'email_address', 'phone_number' => 'phone_number', 'user_name' => 'user_name', 'nick_name' => 'nick_name' ); $usedIdentifiers = array(); if(is_array($config->signupForm)) { foreach($config->signupForm as $signupItem) { if(!count($memberIdentifiers)) break; if(in_array($signupItem->name, $memberIdentifiers) && ($signupItem->required || $signupItem->isUse)) { unset($memberIdentifiers[$signupItem->name]); $usedIdentifiers[$signupItem->name] = $lang->{$signupItem->name}; } } } Context::set('total_count', $output->total_count); Context::set('total_page', $output->total_page); Context::set('page', $output->page); Context::set('filter_type', $filter_type); Context::set('selected_group_srl', Context::get('selected_group_srl')); Context::set('sort_index', Context::get('sort_index')); Context::set('member_config', $oMemberModel->getMemberConfig()); Context::set('member_list', $output->data); Context::set('usedIdentifiers', $usedIdentifiers); Context::set('page_navigation', $output->page_navigation); Context::set('profileImageConfig', $config->profile_image); $security = new Security(); $security->encodeHTML('member_list..user_name', 'member_list..nick_name', 'member_list..group_list..'); $security->encodeHTML('search_target', 'search_keyword'); $this->setTemplateFile('member_list'); } /** * Set the default config. * * @return void */ public function dispMemberAdminConfig() { // Get supported password algorithms. $oDB = DB::getInstance(); $column_info = $oDB->getColumnInfo('member', 'password'); $password_maxlength = intval($column_info->size); $password_algos = Rhymix\Framework\Password::getSupportedAlgorithms(); if ($password_maxlength < 128 && isset($password_algos['argon2id'])) { $password_algos['argon2id'] = false; } if ($password_maxlength < 128 && isset($password_algos['sha512'])) { $password_algos['sha512'] = false; } if ($password_maxlength < 64 && isset($password_algos['sha256'])) { $password_algos['sha256'] = false; } Context::set('password_hashing_algos', $password_algos); $this->setTemplateFile('default_config'); } /** * Set the features config. * * @return void */ public function dispMemberAdminFeaturesConfig() { $this->setTemplateFile('features_config'); } /** * Set the agreements config. * * @return void */ public function dispMemberAdminAgreementsConfig() { $this->setTemplateFile('agreements_config'); } public function dispMemberAdminSignUpConfig() { $config = $this->memberConfig; $oMemberModel = getModel('member'); // retrieve skins of editor $oEditorModel = getModel('editor'); Context::set('editor_skin_list', $oEditorModel->getEditorSkinList()); // get an editor $option = new stdClass; $option->primary_key_name = 'temp_srl'; $option->content_key_name = 'agreement'; $option->allow_fileupload = false; $option->enable_autosave = false; $option->enable_default_component = true; $option->enable_component = false; $option->resizable = true; $option->height = 300; $option->editor_toolbar_hide = 'Y'; Context::set('editor', $oEditorModel->getEditor(0, $option)); $userIdInfo = null; $signupForm = $config->signupForm; foreach($signupForm as $val) { if($val->name == 'user_id') { $userIdInfo = $val; break; } } $oSecurity = new Security(); if($userIdInfo && $userIdInfo->isUse) { // get denied ID list Context::set('useUserID', 1); $denied_list = $oMemberModel->getDeniedIDs(); Context::set('deniedIDs', $denied_list); $oSecurity->encodeHTML('deniedIDs..user_id'); } // get denied NickName List $deniedNickNames = $oMemberModel->getDeniedNickNames(); Context::set('deniedNickNames', $deniedNickNames); $oSecurity->encodeHTML('deniedNickNames..nick_name'); //get managed Email Hosts $managedEmailHost = $oMemberModel->getManagedEmailHosts(); Context::set('managedEmailHost', $managedEmailHost); $oSecurity->encodeHTML('managedEmailHost..email_host'); // Get country calling code list $country_list = Rhymix\Framework\i18n::listCountries(Context::get('lang_type') === 'ko' ? Rhymix\Framework\i18n::SORT_NAME_KOREAN : Rhymix\Framework\i18n::SORT_NAME_ENGLISH); Context::set('country_list', $country_list); if(!$config->phone_number_default_country && Context::get('lang_type') === 'ko') { $config->phone_number_default_country = 'KOR'; } $this->setTemplateFile('signup_config'); } public function dispMemberAdminLoginConfig() { $this->setTemplateFile('login_config'); } public function dispMemberAdminDesignConfig() { $oModuleModel = getModel('module'); // Get a layout list $oLayoutModel = getModel('layout'); $layout_list = $oLayoutModel->getLayoutList(); Context::set('layout_list', $layout_list); $mlayout_list = $oLayoutModel->getLayoutList(0, 'M'); Context::set('mlayout_list', $mlayout_list); // list of skins for member module $skin_list = $oModuleModel->getSkins($this->module_path); Context::set('skin_list', $skin_list); // list of skins for member module $mskin_list = $oModuleModel->getSkins($this->module_path, 'm.skins'); Context::set('mskin_list', $mskin_list); $this->setTemplateFile('design_config'); } /** * default configuration for member management * * @return void */ function dispMemberAdminConfigOLD() { $oModuleModel = getModel('module'); $oMemberModel = getModel('member'); // Get a layout list $oLayoutModel = getModel('layout'); $layout_list = $oLayoutModel->getLayoutList(); Context::set('layout_list', $layout_list); $mlayout_list = $oLayoutModel->getLayoutList(0, 'M'); Context::set('mlayout_list', $mlayout_list); // list of skins for member module $skin_list = $oModuleModel->getSkins($this->module_path); Context::set('skin_list', $skin_list); // list of skins for member module $mskin_list = $oModuleModel->getSkins($this->module_path, 'm.skins'); Context::set('mskin_list', $mskin_list); // retrieve skins of editor $oEditorModel = getModel('editor'); Context::set('editor_skin_list', $oEditorModel->getEditorSkinList()); // get an editor $option->skin = $oEditorModel->getEditorConfig()->editor_skin; $option->primary_key_name = 'temp_srl'; $option->content_key_name = 'agreement'; $option->allow_fileupload = false; $option->enable_autosave = false; $option->enable_default_component = true; $option->enable_component = true; $option->resizable = true; $option->height = 300; $editor = $oEditorModel->getEditor(0, $option); Context::set('editor', $editor); $signupForm = $config->signupForm; foreach($signupForm as $val) { if($val->name == 'user_id') { $userIdInfo = $val; break; } } if($userIdInfo->isUse) { // get denied ID list Context::set('useUserID', 1); $denied_list = $oMemberModel->getDeniedIDs(); Context::set('deniedIDs', $denied_list); } // get denied NickName List $deniedNickNames = $oMemberModel->getDeniedNickNames(); Context::set('deniedNickNames', $deniedNickNames); $security = new Security(); $security->encodeHTML('config..'); $this->setTemplateFile('member_config'); } /** * display member information * * @return void */ function dispMemberAdminInfo() { $oMemberModel = getModel('member'); $oModuleModel = getModel('module'); $member_config = $oModuleModel->getModuleConfig('member'); Context::set('member_config', $member_config); $extendForm = $oMemberModel->getCombineJoinForm($this->memberInfo); Context::set('extend_form_list', $extendForm); $memberInfo = Context::get('member_info'); if(!is_object($memberInfo) || !$memberInfo->member_srl) { throw new Rhymix\Framework\Exceptions\TargetNotFound(); } $memberInfo = get_object_vars($memberInfo); if (!is_array($memberInfo['group_list'])) $memberInfo['group_list'] = array(); Context::set('memberInfo', $memberInfo); $disableColumns = array('password', 'find_account_question', 'find_account_answer'); Context::set('disableColumns', $disableColumns); $security = new Security(); $security->encodeHTML('member_config..'); $security->encodeHTML('extend_form_list...'); $oMemberView = getView('member'); $oMemberView->_getDisplayedMemberInfo($this->memberInfo, $extendForm, $member_config); $this->setTemplateFile('member_info'); } /** * display member insert form * * @return void */ function dispMemberAdminInsert() { $oMemberModel = getModel('member'); $member_config = $this->memberConfig; if($member_info = Context::get('member_info')) { $member_info->signature = $oMemberModel->getSignature($this->memberInfo->member_srl); } else { $member_info = new stdClass; } Context::set('member_info', $member_info); $formTags = $this->_getMemberInputTag($member_info, true); Context::set('formTags', $formTags); // Editor of the module set for signing by calling getEditor foreach($formTags as $formTag) { if($formTag->name == 'signature') { $option = new stdClass; $option->primary_key_name = 'member_srl'; $option->content_key_name = 'signature'; $option->allow_html = $member_config->signature_html !== 'N'; $option->allow_fileupload = $member_config->member_allow_fileupload === 'Y'; $option->enable_autosave = false; $option->enable_default_component = true; $option->enable_component = false; $option->resizable = false; $option->disable_html = true; $option->height = 200; $option->editor_toolbar = 'simple'; $option->editor_toolbar_hide = 'Y'; $option->editor_skin = $member_config->signature_editor_skin; $option->sel_editor_colorset = $member_config->sel_editor_colorset; if (!$option->allow_html) { $option->editor_skin = 'textarea'; } if ($option->allow_fileupload) { $option->module_srl = MemberView::getInstance()->getMemberModuleSrl(); $option->upload_target_type = 'sig'; } if ($member_config->member_max_filesize) { $option->allowed_filesize = $member_config->member_max_filesize * 1024; } Context::set('editor', getModel('editor')->getEditor($member_info->member_srl, $option)); } } if ($member_info->limit_date < date('Ymd')) { $member_info->limit_date = ''; } if (Context::get('member_srl')) { Context::setBrowserTitle(lang('member.msg_update_member')); } else { Context::setBrowserTitle(lang('member.msg_new_member')); } $this->setTemplateFile('insert_member'); } /** * Get tags by the member info type * * @param object $memberInfo * @param boolean $isAdmin (true : admin, false : not admin) * * @return array */ function _getMemberInputTag($memberInfo = null, $isAdmin = false) { $extend_form_list = MemberModel::getCombineJoinForm($memberInfo); $security = new Security($extend_form_list); $security->encodeHTML('..column_title', '..description', '..default_value', '..options.'); if ($memberInfo) { $memberInfo = get_object_vars($memberInfo); $isSignup = false; } else { $memberInfo = array(); $isSignup = true; } $member_config = $this->memberConfig; if(!$this->memberConfig) { $member_config = $this->memberConfig = MemberModel::getMemberConfig(); } $identifiers = $member_config->identifiers ?? [$member_config->identifier]; $identifiers = array_intersect($identifiers, ['user_id', 'email_address']); global $lang; $formTags = array(); foreach($member_config->signupForm as $formInfo) { if(!$formInfo->isUse || ($formInfo->name == 'password' && !$isAdmin)) { continue; } if((in_array($formInfo->name, $identifiers) && $formInfo->name === array_first($identifiers)) && !$isAdmin) { continue; } $formTag = new stdClass(); $inputTag = ''; $formTag->title = $formInfo->title; if($isAdmin) { if($formInfo->mustRequired || $formInfo->required) $formTag->title = '* '.$formTag->title; } else { if ($formInfo->required && $formInfo->name != 'password') $formTag->title = '* '.$formTag->title; } $formTag->name = $formInfo->name; // Default input fields if($formInfo->isDefaultForm) { if($formInfo->imageType) { $formTag->type = 'image'; if($formInfo->name == 'profile_image') { $target = $memberInfo['profile_image']; $functionName = 'doDeleteProfileImage'; } else if($formInfo->name == 'image_name') { $target = $memberInfo['image_name']; $functionName = 'doDeleteImageName'; } else if($formInfo->name == 'image_mark') { $target = $memberInfo['image_mark']; $functionName = 'doDeleteImageMark'; } if(!empty($target->src)) { $inputTag = sprintf('%s ', $formInfo->name, $formInfo->name.'tag', $target->src, $formInfo->title, $functionName, $memberInfo['member_srl'], $lang->cmd_delete); } else { $inputTag = sprintf('', $formInfo->name); } $max_filesize = min(FileHandler::returnBytes(ini_get('upload_max_filesize')), FileHandler::returnBytes(ini_get('post_max_size'))); if (isset($member_config->{$formInfo->name.'_max_filesize'})) { $max_filesize = min($max_filesize, $member_config->{$formInfo->name.'_max_filesize'} * 1024); } $inputTag .= sprintf('

%s: %s, %s: %dpx, %s: %dpx

', $formInfo->name, $formInfo->name, $max_filesize, escape(lang('file.allowed_filesize_exceeded')), lang('file.allowed_filesize'), FileHandler::filesize($max_filesize), $lang->{$formInfo->name.'_max_width'}, $member_config->{$formInfo->name.'_max_width'}, $lang->{$formInfo->name.'_max_height'}, $member_config->{$formInfo->name.'_max_height'}); }//end imageType else if($formInfo->name == 'birthday') { $formTag->type = 'date'; $inputTag = sprintf('' . ' ' . '', $memberInfo['birthday'], $memberInfo['birthday'] ? sprintf('%s-%s-%s', substr($memberInfo['birthday'], 0, 4), substr($memberInfo['birthday'], 4, 2), substr($memberInfo['birthday'], 6, 2)) : '', $lang->cmd_delete); } else if($formInfo->name == 'find_account_question') { continue; } else if($formInfo->name == 'email_address') { if(isset($member_config->enable_confirm) && $member_config->enable_confirm === 'Y' && !$isAdmin && !$isSignup) { $readonly = 'readonly="readonly" '; } else { $readonly = ''; } $formTag->type = 'email'; $inputTag = ''; } else if($formInfo->name == 'phone_number') { $formTag->type = 'phone'; $match_country = $memberInfo['phone_country']; if(!$match_country && $member_config->phone_number_default_country) { $match_country = $member_config->phone_number_default_country; } if($match_country && !preg_match('/^[A-Z]{3}$/', $match_country)) { $match_country = Rhymix\Framework\i18n::getCountryCodeByCallingCode($match_country); } if(!$match_country && Context::get('lang_type') === 'ko') { $match_country = 'KOR'; } if($member_config->phone_number_hide_country !== 'Y') { $inputTag = '' . "\n"; } if($memberInfo['phone_number']) { if($match_country === 'KOR') { $phone_number = Rhymix\Framework\Korea::formatPhoneNumber($memberInfo['phone_number']); } else { $phone_number = $memberInfo['phone_number']; } } else { $phone_number = ''; } $inputTag .= ''; if($member_config->phone_number_verify_by_sms === 'Y') { $inputTag .= "\n" . ''; $inputTag .= "\n" . ''; } } else if($formInfo->name == 'homepage' || $formInfo->name === 'blog') { $formTag->type = 'url'; $input = new Rhymix\Modules\Extravar\Models\Value(0, 1, '', 'url'); $input->parent_type = 'member'; $input->input_name = $formInfo->name; $input->input_id = $formInfo->name; $input->value = $memberInfo[$formInfo->name] ?? ''; $inputTag = $input->getFormHTML(); } else if($formInfo->name == 'password') { $formTag->type = 'password'; $input = new Rhymix\Modules\Extravar\Models\Value(0, 1, '', 'password'); $input->parent_type = 'member'; $input->input_name = $formInfo->name; $input->input_id = $formInfo->name; $input->value = ''; $inputTag = $input->getFormHTML(); } else { if($formInfo->name === 'nick_name' && ($member_config->allow_nickname_change ?? 'Y') === 'N' && !$isAdmin && !$isSignup) { $readonly = 'Y'; } else { $readonly = 'N'; } $formTag->type = 'text'; $input = new Rhymix\Modules\Extravar\Models\Value(0, 1, '', 'text'); $input->parent_type = 'member'; $input->input_name = $formInfo->name; $input->input_id = $formInfo->name; $input->value = $memberInfo[$formInfo->name] ?? ''; $input->is_readonly = $readonly; $inputTag = $input->getFormHTML(); } } // User-defined input fields else { $extendForm = $extend_form_list[$formInfo->member_join_form_srl]; $formTag->type = $extendForm->column_type; $input = new Rhymix\Modules\Extravar\Models\Value(0, 1, '', $extendForm->column_type); $input->parent_type = 'member'; $input->input_name = $extendForm->column_name; $input->input_id = $extendForm->column_name; $input->value = $extendForm->value ?? ''; $input->default = $extendForm->default_value ?? null; $input->options = $extendForm->options ?? null; if ($extendForm->column_type === 'tel' || $extendForm->column_type === 'tel_intl') { $input->style = 'width:33.3px'; } $inputTag = $input->getFormHTML(); if (!empty($extendForm->description)) { $inputTag = vsprintf('%s

%s

', [ $inputTag, $extendForm->description, ]); } } $formTag->inputTag = $inputTag; $formTags[] = $formTag; } return $formTags; } /** * display group list * * @return void */ function dispMemberAdminGroupList() { $oModuleModel = getModel('module'); $output = $oModuleModel->getModuleFileBoxList(); Context::set('fileBoxList', $output->data); $this->setTemplateFile('group_list'); } /** * Display an admin page for memebr join forms * * @return void */ function dispMemberAdminInsertJoinForm() { // Get the value of join_form $member_join_form_srl = Context::get('member_join_form_srl'); if($member_join_form_srl) { $oMemberModel = getModel('member'); $join_form = $oMemberModel->getJoinForm($member_join_form_srl); if(!$join_form) Context::set('member_join_form_srl','',true); else { Context::set('join_form', $join_form); $security = new Security(); $security->encodeHTML('join_form..'); } } $this->setTemplateFile('insert_join_form'); } function dispMemberAdminNickNameLog() { $page = Context::get('page'); $output = getModel('member')->getMemberModifyNicknameLog($page); Context::set('total_count', $output->total_count); Context::set('total_page', $output->total_page); Context::set('page', $output->page); Context::set('nickname_list', $output->data); Context::set('page_navigation', $output->page_navigation); $this->setTemplateFile('nick_name_log'); } } /* End of file member.admin.view.php */ /* Location: ./modules/member/member.admin.view.php */