mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-14 00:39:57 +09:00
git-svn-id: http://xe-core.googlecode.com/svn/trunk@193 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
parent
0a49ee5406
commit
0b38226b7a
14 changed files with 414 additions and 202 deletions
|
|
@ -7,6 +7,13 @@
|
|||
|
||||
class memberModel extends member {
|
||||
|
||||
/**
|
||||
* @brief 자주 호출될거라 예상되는 데이터는 내부적으로 가지고 있자...
|
||||
**/
|
||||
var $member_info = NULL;
|
||||
var $member_groups = NULL;
|
||||
var $join_form_list = NULL;
|
||||
|
||||
/**
|
||||
* @brief 초기화
|
||||
**/
|
||||
|
|
@ -37,34 +44,54 @@
|
|||
* @brief user_id에 해당하는 사용자 정보 return
|
||||
**/
|
||||
function getMemberInfoByUserID($user_id) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->member_info[$member_srl]) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->user_id = $user_id;
|
||||
$output = $oDB->executeQuery('member.getMemberInfo', $args);
|
||||
if(!$output) return $output;
|
||||
$args->user_id = $user_id;
|
||||
$output = $oDB->executeQuery('member.getMemberInfo', $args);
|
||||
if(!$output) return $output;
|
||||
|
||||
$member_info = $output->data;
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
$member_info = $this->arrangeMemberInfo($output->data);
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
|
||||
return $member_info;
|
||||
$this->member_info[$$member_info->member_srl] = $member_info;
|
||||
}
|
||||
return $this->member_info[$member_srl];
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief member_srl로 사용자 정보 return
|
||||
**/
|
||||
function getMemberInfoByMemberSrl($member_srl) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->member_info[$member_srl]) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberInfoByMemberSrl', $args);
|
||||
if(!$output) return $output;
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberInfoByMemberSrl', $args);
|
||||
if(!$output) return $output;
|
||||
|
||||
$member_info = $output->data;
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
$member_info = $this->arrangeMemberInfo($output->data);
|
||||
$member_info->group_list = $this->getMemberGroups($member_info->member_srl);
|
||||
|
||||
return $member_info;
|
||||
$this->member_info[$member_srl] = $member_info;
|
||||
}
|
||||
return $this->member_info[$member_srl];
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief 사용자 정보 중 extra_vars를 알맞게 편집
|
||||
**/
|
||||
function arrangeMemberInfo($info) {
|
||||
$extra_vars = unserialize($info->extra_vars);
|
||||
unset($info->extra_vars);
|
||||
if(!$extra_vars) return $info;
|
||||
foreach($extra_vars as $key => $val) {
|
||||
if(eregi('\|\@\|', $val)) $val = explode('|@|', $val);
|
||||
if(!$info->{$key}) $info->{$key} = $val;
|
||||
}
|
||||
return $info;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -138,20 +165,23 @@
|
|||
* @brief member_srl이 속한 group 목록을 가져옴
|
||||
**/
|
||||
function getMemberGroups($member_srl) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->member_groups[$member_srl]) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberGroups', $args);
|
||||
if(!$output->data) return;
|
||||
$args->member_srl = $member_srl;
|
||||
$output = $oDB->executeQuery('member.getMemberGroups', $args);
|
||||
if(!$output->data) return;
|
||||
|
||||
$group_list = $output->data;
|
||||
if(!is_array($group_list)) $group_list = array($group_list);
|
||||
$group_list = $output->data;
|
||||
if(!is_array($group_list)) $group_list = array($group_list);
|
||||
|
||||
foreach($group_list as $group) {
|
||||
$result[$group->group_srl] = $group->title;
|
||||
foreach($group_list as $group) {
|
||||
$result[$group->group_srl] = $group->title;
|
||||
}
|
||||
$this->member_groups[$member_srl] = $result;
|
||||
}
|
||||
return $result;
|
||||
return $this->member_groups[$member_srl];
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -204,42 +234,64 @@
|
|||
* 이 인자값이 true일 경우 filter 타입에 맞는 형태의 object로 결과를 return하여야 한다.
|
||||
**/
|
||||
function getJoinFormList($filter_response = false) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
global $lang;
|
||||
|
||||
// list_order 컬럼의 정렬을 위한 인자 세팅
|
||||
$args->sort_index = "list_order";
|
||||
$output = $oDB->executeQuery('member.getJoinFormList', $args);
|
||||
if(!$this->join_form_list) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
// 결과 데이터가 없으면 NULL return
|
||||
$join_form_list = $output->data;
|
||||
if(!$join_form_list) return NULL;
|
||||
// list_order 컬럼의 정렬을 위한 인자 세팅
|
||||
$args->sort_index = "list_order";
|
||||
$output = $oDB->executeQuery('member.getJoinFormList', $args);
|
||||
|
||||
// default_value의 경우 DB에 array가 serialize되어 입력되므로 unserialize가 필요
|
||||
if(!is_array($join_form_list)) $join_form_list = array($join_form_list);
|
||||
$join_form_count = count($join_form_list);
|
||||
for($i=0;$i<$join_form_count;$i++) {
|
||||
$member_join_form_srl = $join_form_list[$i]->member_join_form_srl;
|
||||
$column_type = $join_form_list[$i]->column_type;
|
||||
$default_value = $join_form_list[$i]->default_value;
|
||||
// 결과 데이터가 없으면 NULL return
|
||||
$join_form_list = $output->data;
|
||||
if(!$join_form_list) return NULL;
|
||||
|
||||
if(in_array($column_type, array('checkbox','select'))) {
|
||||
$join_form_list[$i]->default_value = unserialize($default_value);
|
||||
if(!$join_form_list[$i]->default_value[0]) $join_form_list[$i]->default_value = '';
|
||||
} else {
|
||||
$join_form_list[$i]->default_value = '';
|
||||
// default_value의 경우 DB에 array가 serialize되어 입력되므로 unserialize가 필요
|
||||
if(!is_array($join_form_list)) $join_form_list = array($join_form_list);
|
||||
$join_form_count = count($join_form_list);
|
||||
for($i=0;$i<$join_form_count;$i++) {
|
||||
$member_join_form_srl = $join_form_list[$i]->member_join_form_srl;
|
||||
$column_type = $join_form_list[$i]->column_type;
|
||||
$column_name = $join_form_list[$i]->column_name;
|
||||
$column_title = $join_form_list[$i]->column_title;
|
||||
$default_value = $join_form_list[$i]->default_value;
|
||||
|
||||
// 언어변수에 추가
|
||||
$lang->extend_vars[$column_name] = $column_title;
|
||||
|
||||
// checkbox, select등 다수 데이터 형식일 경우 unserialize해줌
|
||||
if(in_array($column_type, array('checkbox','select'))) {
|
||||
$join_form_list[$i]->default_value = unserialize($default_value);
|
||||
if(!$join_form_list[$i]->default_value[0]) $join_form_list[$i]->default_value = '';
|
||||
} else {
|
||||
$join_form_list[$i]->default_value = '';
|
||||
}
|
||||
|
||||
$list[$member_join_form_srl] = $join_form_list[$i];
|
||||
}
|
||||
|
||||
$list[$member_join_form_srl] = $join_form_list[$i];
|
||||
$this->join_form_list = $list;
|
||||
}
|
||||
|
||||
// filter_response가 true일 경우 object 스타일을 구함
|
||||
if($filter_response) {
|
||||
if($filter_response && count($this->join_form_list)) {
|
||||
|
||||
foreach($this->join_form_list as $key => $val) {
|
||||
if($val->is_active != 'Y') continue;
|
||||
unset($obj);
|
||||
$obj->type = $val->column_type;
|
||||
$obj->name = $val->column_name;
|
||||
$obj->lang = $val->column_title;
|
||||
$obj->required = $val->required=='Y'?true:false;
|
||||
$filter_output[] = $obj;
|
||||
}
|
||||
return $filter_output;
|
||||
|
||||
}
|
||||
|
||||
|
||||
// 결과 리턴
|
||||
return $list;
|
||||
return $this->join_form_list;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -269,16 +321,19 @@
|
|||
* @brief 금지 아이디 목록 가져오기
|
||||
**/
|
||||
function getDeniedIDList() {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
if(!$this->denied_id_list) {
|
||||
// DB 객체 생성
|
||||
$oDB = &DB::getInstance();
|
||||
|
||||
$args->sort_index = "list_order";
|
||||
$args->page = Context::get('page');
|
||||
$args->list_count = 40;
|
||||
$args->page_count = 10;
|
||||
$args->sort_index = "list_order";
|
||||
$args->page = Context::get('page');
|
||||
$args->list_count = 40;
|
||||
$args->page_count = 10;
|
||||
|
||||
$output = $oDB->executeQuery('member.getDeniedIDList', $args);
|
||||
return $output;
|
||||
$output = $oDB->executeQuery('member.getDeniedIDList', $args);
|
||||
$this->denied_id_list = $output;
|
||||
}
|
||||
return $this->denied_id_list;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue