*/
/**
* @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(' ',
$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 */