mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-05 17:51:40 +09:00
443 lines
16 KiB
PHP
443 lines
16 KiB
PHP
<?php
|
|
/**
|
|
* @class memberAdminController
|
|
* @author zero (zero@nzeo.com)
|
|
* @brief member module의 admin controller class
|
|
**/
|
|
|
|
class memberAdminController extends member {
|
|
|
|
/**
|
|
* @brief 초기화
|
|
**/
|
|
function init() {
|
|
}
|
|
|
|
/**
|
|
* @brief 사용자 추가 (관리자용)
|
|
**/
|
|
function procMemberAdminInsert() {
|
|
// 필수 정보들을 미리 추출
|
|
$args = Context::gets('member_srl','user_id','user_name','nick_name','homepage','blog','birthday','email_address','password','allow_mailing','allow_message','denied','is_admin','description','group_srl_list');
|
|
|
|
// 넘어온 모든 변수중에서 몇가지 불필요한 것들 삭제
|
|
$all_args = Context::getRequestVars();
|
|
unset($all_args->module);
|
|
unset($all_args->act);
|
|
|
|
// 모든 request argument에서 필수 정보만 제외 한 후 추가 데이터로 입력
|
|
$extra_vars = delObjectVars($all_args, $args);
|
|
$args->extra_vars = serialize($extra_vars);
|
|
|
|
// member_srl이 넘어오면 원 회원이 있는지 확인
|
|
if($args->member_srl) {
|
|
// 멤버 모델 객체 생성
|
|
$oMemberModel = &getModel('member');
|
|
|
|
// 회원 정보 구하기
|
|
$member_info = $oMemberModel->getMemberInfoByMemberSrl($args->member_srl);
|
|
|
|
// 만약 원래 회원이 없으면 새로 입력하기 위한 처리
|
|
if($member_info->member_srl != $args->member_srl) unset($args->member_srl);
|
|
}
|
|
|
|
// member_srl의 값에 따라 insert/update
|
|
if(!$args->member_srl) {
|
|
$output = $this->insertMember($args);
|
|
$msg_code = 'success_registed';
|
|
} else {
|
|
$output = $this->updateMember($args);
|
|
$msg_code = 'success_updated';
|
|
}
|
|
|
|
if(!$output->toBool()) return $output;
|
|
|
|
// 서명 저장
|
|
$signature = Context::get('signature');
|
|
$this->putSignature($args->member_srl, $signature);
|
|
|
|
// 결과 리턴
|
|
$this->add('member_srl', $args->member_srl);
|
|
$this->setMessage($msg_code);
|
|
}
|
|
|
|
/**
|
|
* @brief 사용자 삭제 (관리자용)
|
|
**/
|
|
function procMemberAdminDelete() {
|
|
// 일단 입력된 값들을 모두 받아서 db 입력항목과 그외 것으로 분리
|
|
$member_srl = Context::get('member_srl');
|
|
|
|
$output = $this->deleteMember($member_srl);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->add('page',Context::get('page'));
|
|
$this->setMessage("success_deleted");
|
|
}
|
|
|
|
/**
|
|
* @brief 회원 관리용 기본 정보의 추가
|
|
**/
|
|
function procMemberAdminInsertConfig() {
|
|
// 기본 정보를 받음
|
|
$args = Context::gets('enable_join','limit_day','redirect_url','content','image_name','image_mark', 'image_name_max_width', 'image_name_max_height','image_mark_max_width','image_mark_max_height');
|
|
if($args->enable_join!='Y') $args->enable_join = 'N';
|
|
if($args->image_name!='Y') $args->image_name = 'N';
|
|
if($args->image_mark!='Y') $args->image_mark = 'N';
|
|
$args->limit_day = (int)$args->limit_day;
|
|
$args->agreement = $args->content;
|
|
unset($args->content);
|
|
|
|
// module Controller 객체 생성하여 입력
|
|
$oModuleController = &getController('module');
|
|
$output = $oModuleController->insertModuleConfig('member',$args);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief 사용자 그룹 추가
|
|
**/
|
|
function procMemberAdminInsertGroup() {
|
|
$args = Context::gets('title','description','is_default');
|
|
$output = $this->insertGroup($args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->add('group_srl','');
|
|
$this->add('page',Context::get('page'));
|
|
$this->setMessage('success_registed');
|
|
}
|
|
|
|
/**
|
|
* @brief 사용자 그룹 정보 수정
|
|
**/
|
|
function procMemberAdminUpdateGroup() {
|
|
$group_srl = Context::get('group_srl');
|
|
$mode = Context::get('mode');
|
|
|
|
switch($mode) {
|
|
case 'delete' :
|
|
$output = $this->deleteGroup($group_srl);
|
|
if(!$output->toBool()) return $output;
|
|
$msg_code = 'success_deleted';
|
|
break;
|
|
case 'update' :
|
|
$args = Context::gets('group_srl','title','description','is_default');
|
|
$output = $this->updateGroup($args);
|
|
if(!$output->toBool()) return $output;
|
|
$msg_code = 'success_updated';
|
|
break;
|
|
}
|
|
|
|
$this->add('group_srl','');
|
|
$this->add('page',Context::get('page'));
|
|
$this->setMessage($msg_code);
|
|
}
|
|
|
|
/**
|
|
* @brief 가입 항목 추가
|
|
**/
|
|
function procMemberAdminInsertJoinForm() {
|
|
$args->member_join_form_srl = Context::get('member_join_form_srl');
|
|
|
|
$args->column_type = Context::get('column_type');
|
|
$args->column_name = Context::get('column_name');
|
|
$args->column_title = Context::get('column_title');
|
|
$args->default_value = explode('|@|', Context::get('default_value'));
|
|
$args->is_active = Context::get('is_active');
|
|
if(!in_array(strtoupper($args->is_active), array('Y','N'))) $args->is_active = 'N';
|
|
$args->required = Context::get('required');
|
|
if(!in_array(strtoupper($args->required), array('Y','N'))) $args->required = 'N';
|
|
$args->description = Context::get('description');
|
|
$args->list_order = getNextSequence();
|
|
|
|
// 기본값의 정리
|
|
if(in_array($args->column_type, array('checkbox','select')) && count($args->default_value) ) {
|
|
$args->default_value = serialize($args->default_value);
|
|
} else {
|
|
$args->default_value = '';
|
|
}
|
|
|
|
// member_join_form_srl이 있으면 수정, 없으면 추가
|
|
if(!$args->member_join_form_srl) $output = executeQuery('member.insertJoinForm', $args);
|
|
else $output = executeQuery('member.updateJoinForm', $args);
|
|
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->add('act','dispJoinForm');
|
|
$this->setMessage('success_registed');
|
|
}
|
|
|
|
/**
|
|
* @brief 가입 항목의 상/하 이동 및 내용 수정
|
|
**/
|
|
function procMemberAdminUpdateJoinForm() {
|
|
$member_join_form_srl = Context::get('member_join_form_srl');
|
|
$mode = Context::get('mode');
|
|
|
|
switch($mode) {
|
|
case 'up' :
|
|
$output = $this->moveJoinFormUp($member_join_form_srl);
|
|
$msg_code = 'success_moved';
|
|
break;
|
|
case 'down' :
|
|
$output = $this->moveJoinFormDown($member_join_form_srl);
|
|
$msg_code = 'success_moved';
|
|
break;
|
|
case 'delete' :
|
|
$output = $this->deleteJoinForm($member_join_form_srl);
|
|
$msg_code = 'success_deleted';
|
|
break;
|
|
case 'update' :
|
|
break;
|
|
}
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->setMessage($msg_code);
|
|
}
|
|
|
|
/**
|
|
* @brief 금지 아이디 추가
|
|
**/
|
|
function procMemberAdminInsertDeniedID() {
|
|
$user_id = Context::get('user_id');
|
|
$description = Context::get('description');
|
|
|
|
$oMemberController = &getController('member');
|
|
$output = $oMemberController->insertDeniedID($user_id, $description);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->add('group_srl','');
|
|
$this->add('page',Context::get('page'));
|
|
$this->setMessage('success_registed');
|
|
}
|
|
|
|
/**
|
|
* @brief 금지 아이디 업데이트
|
|
**/
|
|
function procMemberAdminUpdateDeniedID() {
|
|
$user_id = Context::get('user_id');
|
|
$mode = Context::get('mode');
|
|
|
|
$oMemberController = &getController('member');
|
|
|
|
switch($mode) {
|
|
case 'delete' :
|
|
$output = $oMemberController->deleteDeniedID($user_id);
|
|
if(!$output->toBool()) return $output;
|
|
$msg_code = 'success_deleted';
|
|
break;
|
|
}
|
|
|
|
$this->add('page',Context::get('page'));
|
|
$this->setMessage($msg_code);
|
|
}
|
|
|
|
/**
|
|
* @brief 관리자를 추가한다
|
|
**/
|
|
function insertAdmin($args) {
|
|
// 관리자임을 설정
|
|
$args->is_admin = 'Y';
|
|
|
|
// 관리자 그룹을 구해와서 설정
|
|
$oMemberModel = &getModel('member');
|
|
$admin_group = $oMemberModel->getAdminGroup();
|
|
$args->group_srl_list = $admin_group->group_srl;
|
|
|
|
return $this->insertMember($args);
|
|
}
|
|
|
|
/**
|
|
* @brief member_srl에 group_srl을 추가
|
|
**/
|
|
function addMemberToGroup($member_srl,$group_srl) {
|
|
$args->member_srl = $member_srl;
|
|
$args->group_srl = $group_srl;
|
|
|
|
// 추가
|
|
return executeQuery('member.addMemberToGroup',$args);
|
|
}
|
|
|
|
/**
|
|
* @brief 회원의 그룹값을 변경
|
|
**/
|
|
function changeGroup($source_group_srl, $target_group_srl) {
|
|
$args->source_group_srl = $source_group_srl;
|
|
$args->target_group_srl = $target_group_srl;
|
|
|
|
return executeQuery('member.changeGroup', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief 그룹 등록
|
|
**/
|
|
function insertGroup($args) {
|
|
// is_default값을 체크, Y일 경우 일단 모든 is_default에 대해서 N 처리
|
|
if($args->is_default!='Y') {
|
|
$args->is_default = 'N';
|
|
} else {
|
|
$output = executeQuery('member.updateGroupDefaultClear');
|
|
if(!$output->toBool()) return $output;
|
|
}
|
|
|
|
return executeQuery('member.insertGroup', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief 그룹 정보 수정
|
|
**/
|
|
function updateGroup($args) {
|
|
// is_default값을 체크, Y일 경우 일단 모든 is_default에 대해서 N 처리
|
|
if($args->is_default!='Y') $args->is_default = 'N';
|
|
else {
|
|
$output = executeQuery('member.updateGroupDefaultClear');
|
|
if(!$output->toBool()) return $output;
|
|
}
|
|
|
|
return executeQuery('member.updateGroup', $args);
|
|
}
|
|
|
|
/**
|
|
* 그룹 삭제
|
|
**/
|
|
function deleteGroup($group_srl) {
|
|
// 멤버모델 객체 생성
|
|
$oMemberModel = &getModel('member');
|
|
|
|
// 삭제 대상 그룹을 가져와서 체크 (is_default == 'Y'일 경우 삭제 불가)
|
|
$group_info = $oMemberModel->getGroup($group_srl);
|
|
|
|
if(!$group_info) return new Object(-1, 'lang->msg_not_founded');
|
|
if($group_info->is_default == 'Y') return new Object(-1, 'msg_not_delete_default');
|
|
|
|
// is_default == 'Y'인 그룹을 가져옴
|
|
$default_group = $oMemberModel->getDefaultGroup();
|
|
$default_group_srl = $default_group->group_srl;
|
|
|
|
// default_group_srl로 변경
|
|
$this->changeGroup($group_srl, $default_group_srl);
|
|
|
|
$args->group_srl = $group_srl;
|
|
return executeQuery('member.deleteGroup', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief 금지아이디 등록
|
|
**/
|
|
function insertDeniedID($user_id, $desription = '') {
|
|
$args->user_id = $user_id;
|
|
$args->description = $description;
|
|
$args->list_order = -1*getNextSequence();
|
|
|
|
return executeQuery('member.insertDeniedID', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief 금지아이디 삭제
|
|
**/
|
|
function deleteDeniedID($user_id) {
|
|
$args->user_id = $user_id;
|
|
return executeQuery('member.deleteDeniedID', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief 가입폼 항목을 삭제
|
|
**/
|
|
function deleteJoinForm($member_join_form_srl) {
|
|
$args->member_join_form_srl = $member_join_form_srl;
|
|
$output = executeQuery('member.deleteJoinForm', $args);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief 가입항목을 상단으로 이동
|
|
**/
|
|
function moveJoinFormUp($member_join_form_srl) {
|
|
$oMemberModel = &getModel('member');
|
|
|
|
// 선택된 가입항목의 정보를 구한다
|
|
$args->member_join_form_srl = $member_join_form_srl;
|
|
$output = executeQuery('member.getJoinForm', $args);
|
|
|
|
$join_form = $output->data;
|
|
$list_order = $join_form->list_order;
|
|
|
|
// 전체 가입항목 목록을 구한다
|
|
$join_form_list = $oMemberModel->getJoinFormList();
|
|
$join_form_srl_list = array_keys($join_form_list);
|
|
if(count($join_form_srl_list)<2) return new Object();
|
|
|
|
$prev_member_join_form = NULL;
|
|
foreach($join_form_list as $key => $val) {
|
|
if($val->member_join_form_srl == $member_join_form_srl) break;
|
|
$prev_member_join_form = $val;
|
|
}
|
|
|
|
// 이전 가입항목가 없으면 그냥 return
|
|
if(!$prev_member_join_form) return new Object();
|
|
|
|
// 선택한 가입항목의 정보
|
|
$cur_args->member_join_form_srl = $member_join_form_srl;
|
|
$cur_args->list_order = $prev_member_join_form->list_order;
|
|
|
|
// 대상 가입항목의 정보
|
|
$prev_args->member_join_form_srl = $prev_member_join_form->member_join_form_srl;
|
|
$prev_args->list_order = $list_order;
|
|
|
|
// DB 처리
|
|
$output = executeQuery('member.updateMemberJoinFormListorder', $cur_args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
executeQuery('member.updateMemberJoinFormListorder', $prev_args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
return new Object();
|
|
}
|
|
|
|
/**
|
|
* @brief 가입항목을 하단으로 이동
|
|
**/
|
|
function moveJoinFormDown($member_join_form_srl) {
|
|
$oMemberModel = &getModel('member');
|
|
|
|
// 선택된 가입항목의 정보를 구한다
|
|
$args->member_join_form_srl = $member_join_form_srl;
|
|
$output = executeQuery('member.getJoinForm', $args);
|
|
|
|
$join_form = $output->data;
|
|
$list_order = $join_form->list_order;
|
|
|
|
// 전체 가입항목 목록을 구한다
|
|
$join_form_list = $oMemberModel->getJoinFormList();
|
|
$join_form_srl_list = array_keys($join_form_list);
|
|
if(count($join_form_srl_list)<2) return new Object();
|
|
|
|
for($i=0;$i<count($join_form_srl_list);$i++) {
|
|
if($join_form_srl_list[$i]==$member_join_form_srl) break;
|
|
}
|
|
|
|
$next_member_join_form_srl = $join_form_srl_list[$i+1];
|
|
|
|
// 이전 가입항목가 없으면 그냥 return
|
|
if(!$next_member_join_form_srl) return new Object();
|
|
$next_member_join_form = $join_form_list[$next_member_join_form_srl];
|
|
|
|
// 선택한 가입항목의 정보
|
|
$cur_args->member_join_form_srl = $member_join_form_srl;
|
|
$cur_args->list_order = $next_member_join_form->list_order;
|
|
|
|
// 대상 가입항목의 정보
|
|
$next_args->member_join_form_srl = $next_member_join_form->member_join_form_srl;
|
|
$next_args->list_order = $list_order;
|
|
|
|
// DB 처리
|
|
$output = executeQuery('member.updateMemberJoinFormListorder', $cur_args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$output = executeQuery('member.updateMemberJoinFormListorder', $next_args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
return new Object();
|
|
}
|
|
}
|
|
?>
|