|
Server : Apache/2.2.17 (Unix) mod_ssl/2.2.17 OpenSSL/0.9.8e-fips-rhel5 DAV/2 PHP/5.2.17 System : Linux localhost 2.6.18-419.el5 #1 SMP Fri Feb 24 22:47:42 UTC 2017 x86_64 User : nobody ( 99) PHP Version : 5.2.17 Disable Function : NONE Directory : /proc/21571/root/home/queenjbs/xe/modules/point/ |
Upload File : |
<?php
/**
* @class pointModel
* @author zero (zero@nzeo.com)
* @brief point 모듈의 model class
**/
class pointModel extends point {
/**
* @brief 초기화
**/
function init() {
}
/**
* @brief 포인트 정보가 있는지 체크
**/
function isExistsPoint($member_srl) {
$member_srl = abs($member_srl);
$args->member_srl = $member_srl;
$output = executeQuery('point.getPoint', $args);
if($output->data->member_srl == $member_srl) return true;
return false;
}
/**
* @brief 포인트를 구해옴
**/
function getPoint($member_srl, $from_db = false) {
$member_srl = abs($member_srl);
$path = sprintf('./files/member_extra_info/point/%s',getNumberingPath($member_srl));
if(!is_dir($path)) FileHandler::makeDir($path);
$cache_filename = sprintf('%s%d.cache.txt', $path, $member_srl);
if(!$from_db && file_exists($cache_filename)) return trim(FileHandler::readFile($cache_filename));
// DB에서 가져옴
$args->member_srl = $member_srl;
$output = executeQuery('point.getPoint', $args);
$point = (int)$output->data->point;
FileHandler::writeFile($cache_filename, $point);
return $point;
}
/**
* @brief 레벨을 구함
**/
function getLevel($point, $level_step) {
$level_count = count($level_step);
for($level=0;$level<=$level_count;$level++) if($point < $level_step[$level]) break;
$level --;
return $level;
}
/**
* @brief 포인트 순 회원목록 가져오기
**/
function getMemberList($args = null) {
// 검색 옵션 정리
$args->is_admin = Context::get('is_admin')=='Y'?'Y':'';
$args->is_denied = Context::get('is_denied')=='Y'?'Y':'';
$args->selected_group_srl = Context::get('selected_group_srl');
$search_target = trim(Context::get('search_target'));
$search_keyword = trim(Context::get('search_keyword'));
if($search_target && $search_keyword) {
switch($search_target) {
case 'user_id' :
if($search_keyword) $search_keyword = str_replace(' ','%',$search_keyword);
$args->s_user_id = $search_keyword;
break;
case 'user_name' :
if($search_keyword) $search_keyword = str_replace(' ','%',$search_keyword);
$args->s_user_name = $search_keyword;
break;
case 'nick_name' :
if($search_keyword) $search_keyword = str_replace(' ','%',$search_keyword);
$args->s_nick_name = $search_keyword;
break;
case 'email_address' :
if($search_keyword) $search_keyword = str_replace(' ','%',$search_keyword);
$args->s_email_address = $search_keyword;
break;
case 'regdate' :
$args->s_regdate = $search_keyword;
break;
case 'last_login' :
$args->s_last_login = $search_keyword;
break;
case 'extra_vars' :
$args->s_extra_vars = $search_keyword;
break;
}
}
// selected_group_srl이 있으면 query id를 변경 (table join때문에)
if($args->selected_group_srl) {
$query_id = 'point.getMemberListWithinGroup';
} else {
$query_id = 'point.getMemberList';
}
$output = executeQuery($query_id, $args);
if($output->total_count) {
$oModuleModel = &getModel('module');
$config = $oModuleModel->getModuleConfig('point');
foreach($output->data as $key => $val) {
$output->data[$key]->level = $this->getLevel($val->point, $config->level_step);
}
}
return $output;
}
}
?>