mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-07 02:31:40 +09:00
git-svn-id: http://xe-core.googlecode.com/svn/branches/1.5.0@8926 201d5d3c-b55e-5fd7-737f-ddc643e51545
1817 lines
82 KiB
PHP
1817 lines
82 KiB
PHP
<?php
|
|
/**
|
|
* @class memberController
|
|
* @author NHN (developers@xpressengine.com)
|
|
* @brief Controller class of member module
|
|
**/
|
|
|
|
class memberController extends member {
|
|
var $memberInfo;
|
|
|
|
/**
|
|
* @brief Initialization
|
|
**/
|
|
function init() {
|
|
}
|
|
|
|
/**
|
|
* @brief Log-in by checking user_id and password
|
|
**/
|
|
function procMemberLogin($user_id = null, $password = null, $keep_signed = null) {
|
|
// Variables
|
|
if(!$user_id) $user_id = Context::get('user_id');
|
|
$user_id = trim($user_id);
|
|
|
|
if(!$password) $password = Context::get('password');
|
|
$password = trim($password);
|
|
|
|
if(!$keep_signed) $keep_signed = Context::get('keep_signed');
|
|
// Return an error when id and password doesn't exist
|
|
if(!$user_id) return new Object(-1,'null_user_id');
|
|
if(!$password) return new Object(-1,'null_password');
|
|
|
|
$output = $this->doLogin($user_id, $password, $keep_signed=='Y'?true:false);
|
|
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($config->after_login_url) $this->setRedirectUrl($config->after_login_url);
|
|
|
|
// Check change_password_date
|
|
$limit_date = $config->change_password_date;
|
|
|
|
// Check if change_password_date is set
|
|
if ($limit_date > 0) {
|
|
$oMemberModel = &getModel('member');
|
|
//$member_info = $oMemberModel->getMemberInfoByUserID($user_id, $columnList);
|
|
if ($this->memberInfo->change_password_date < date ('YmdHis', strtotime ('-' . $limit_date . ' day'))) {
|
|
$this->setRedirectUrl(getNotEncodedUrl('','vid',Context::get('vid'),'mid',Context::get('mid'),'act','dispMemberModifyPassword'));
|
|
}
|
|
}
|
|
|
|
$redirect_url = Context::get('redirect_url');
|
|
if ($output->toBool () && Context::getRequestMethod () == "POST" && $redirect_url) {
|
|
header ("location:" . $redirect_url);
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Login by openid
|
|
**/
|
|
function procMemberOpenIDLogin($validator = "procMemberOpenIDValidate") {
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($config->enable_openid != 'Y') $this->stop('msg_invalid_request');
|
|
|
|
if(!defined('Auth_OpenID_RAND_SOURCE') && !file_exists("/dev/urandom"))
|
|
{
|
|
define('Auth_OpenID_RAND_SOURCE', null);
|
|
}
|
|
|
|
set_include_path(_XE_PATH_."modules/member/php-openid-1.2.3");
|
|
require_once('Auth/OpenID.php');
|
|
require_once('Auth/OpenID/Consumer.php');
|
|
require_once('Auth/OpenID/XEStore.php');
|
|
$store = new Auth_OpenID_XEStore();
|
|
$consumer = new Auth_OpenID_Consumer($store);
|
|
|
|
$user_id = Context::get('user_id');
|
|
if (!$user_id) $user_id = Context::get('openid');
|
|
$auth_request = $consumer->begin($user_id);
|
|
$auth_request->addExtensionArg('sreg', 'required', 'email');
|
|
$auth_request->addExtensionArg('sreg', 'optional', 'dob');
|
|
if(!$auth_request)
|
|
{
|
|
return new Object(-1, "association failed");
|
|
}
|
|
|
|
$trust_root = 'http://'.$_SERVER["HTTP_HOST"];
|
|
$referer_url = Context::get('referer_url');
|
|
if (!$referer_url) $referer_url = $_SERVER['HTTP_REFERER'];
|
|
if (!$referer_url)
|
|
$referer_url = htmlspecialchars_decode(getRequestUri(RELEASE_SSL));
|
|
$goto = urlencode($referer_url);
|
|
$ApprovedURL = Context::getRequestUri(RELEASE_SSL) . "?module=member&act=" . $validator. "&goto=" . $goto;
|
|
$redirect_url = $auth_request->redirectURL($trust_root, $ApprovedURL);
|
|
$this->add("redirect_url", $redirect_url);
|
|
if (Context::getRequestMethod() == 'POST')
|
|
header("location:" . $redirect_url);
|
|
}
|
|
|
|
function getLegacyUserIDsFromOpenID($openid_identity) {
|
|
// Issue 17515512: workaround
|
|
$result = array();
|
|
$uri_matches = array();
|
|
preg_match(Auth_OpenID_getURIPattern(), $openid_identity, $uri_matches);
|
|
|
|
if (count($uri_matches) < 9) {
|
|
for ($i = count($uri_matches); $i <= 9; $i++) {
|
|
$uri_matches[] = '';
|
|
}
|
|
}
|
|
|
|
$scheme = $uri_matches[2];
|
|
$authority = $uri_matches[4];
|
|
$path = $uri_matches[5];
|
|
$query = $uri_matches[6];
|
|
$fragment = $uri_matches[8];
|
|
|
|
if ($scheme === null) $scheme = '';
|
|
if ($authority === null) $authority = '';
|
|
if ($path === null) $path = '';
|
|
if ($query === null) $query = '';
|
|
if ($fragment === null) $fragment = '';
|
|
|
|
if ($scheme == 'http' or $scheme == '')
|
|
$scheme_part = '';
|
|
else
|
|
$scheme_part = $scheme."://";
|
|
|
|
|
|
if ($path == '' || $path == '/') {
|
|
$result[] = $scheme_part.$authority.''.$query.$fragment;
|
|
$result[] = $scheme_part.$authority.'/'.$query.$fragment;
|
|
}
|
|
else {
|
|
$result[] = $scheme_part.$authority.$path.$query.$fragment;
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* @brief openid authentication check
|
|
**/
|
|
function procMemberOpenIDValidate() {
|
|
set_include_path(_XE_PATH_."modules/member/php-openid-1.2.3");
|
|
require_once('Auth/OpenID.php');
|
|
require_once('Auth/OpenID/Consumer.php');
|
|
require_once('Auth/OpenID/XEStore.php');
|
|
require_once('Auth/OpenID/URINorm.php');
|
|
|
|
$store = new Auth_OpenID_XEStore();
|
|
$consumer = new Auth_OpenID_Consumer($store);
|
|
$response = $consumer->complete($_GET);
|
|
switch($response->status) {
|
|
case Auth_OpenID_CANCEL :
|
|
// Handle if user authentication is canceled
|
|
return $this->stop('authorization_canceled');
|
|
case Auth_OpenID_FAILURE :
|
|
// Handle if user authentication is failed due to a certain problem (for example, openid doesn't exist) (there is no authentication required deunga openid ..)
|
|
return $this->stop('invalid_authorization');
|
|
case Auth_OpenID_SUCCESS :
|
|
// Authentication success!
|
|
break;
|
|
default:
|
|
return $this->stop('invalid_authorization');
|
|
}
|
|
// Authentication success
|
|
$oMemberModel = &getModel('member');
|
|
// Get zeroboard ID which is corresponded to the openID ID.
|
|
$login_success = false;
|
|
$assoc_member_info = null;
|
|
$openid_identity = $response->signed_args["openid.identity"];
|
|
$args->openid = $openid_identity;
|
|
$output = executeQuery('member.getMemberSrlByOpenID', $args);
|
|
|
|
if ($output->toBool() && $output->data && !is_array($output->data)) {
|
|
$member_srl = $output->data->member_srl;
|
|
$columnList = array('member_srl', 'user_id');
|
|
$member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl, 0, $columnList);
|
|
if ($member_info) {
|
|
$assoc_member_info = $member_info;
|
|
}
|
|
}
|
|
|
|
$user_id_candidates = $this->getLegacyUserIDsFromOpenID($openid_identity);
|
|
$default_user_id = $user_id_candidates[0];
|
|
|
|
if ($assoc_member_info != null) {
|
|
$user_id_candidates = array_merge(array($assoc_member_info->user_id), $user_id_candidates);
|
|
}
|
|
$sreg = $response->extensionResponse('sreg');
|
|
|
|
foreach($user_id_candidates as $user_id) {
|
|
$args->user_id = $args->nick_name = $user_id;
|
|
// Get basic information
|
|
$args->email_address = $sreg['email'];
|
|
$args->user_name = $sreg['fullname'];
|
|
if(!$args->user_name) list($args->user_name) = explode('@', $args->email_address);
|
|
$args->birthday = str_replace('-','',$sreg['dob']);
|
|
// Attempts self-authentication
|
|
$output = $this->doLogin($args->user_id);
|
|
|
|
if ($output->toBool()) {
|
|
if ($assoc_member_info == null) {
|
|
$logged_info = Context::get('logged_info');
|
|
$args->member_srl = $logged_info->member_srl;
|
|
$args->openid = $openid_identity;
|
|
executeQuery('member.addOpenIDToMember', $args);
|
|
}
|
|
$login_success = true;
|
|
break;
|
|
}
|
|
}
|
|
// Member join if self-authentication is failed
|
|
if(!$login_success) {
|
|
$args->user_id = $args->nick_name = $default_user_id;
|
|
$args->password = md5(getmicrotime());
|
|
|
|
$output = $this->insertMember($args);
|
|
if(!$output->toBool()) return $this->stop($output->getMessage());
|
|
$output = $this->doLogin($args->user_id);
|
|
if(!$output->toBool()) return $this->stop($output->getMessage());
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
$args->member_srl = $logged_info->member_srl;
|
|
$args->openid = $openid_identity;
|
|
executeQuery('member.addOpenIDToMember', $args);
|
|
}
|
|
|
|
Context::close();
|
|
// Move the page
|
|
if(Context::get('goto')) {
|
|
$goto = Context::get('goto');
|
|
header("location:" . $goto);
|
|
} else {
|
|
header("location:./");
|
|
}
|
|
|
|
exit();
|
|
}
|
|
|
|
/**
|
|
* @brief Request member join by openID
|
|
**/
|
|
function procMemberAddOpenIDToMember() {
|
|
return $this->procMemberOpenIDLogin("procMemberValidateAddOpenIDToMember");
|
|
}
|
|
|
|
/**
|
|
* @brief Validate openID processing
|
|
**/
|
|
function procMemberValidateAddOpenIDToMember() {
|
|
set_include_path(_XE_PATH_."modules/member/php-openid-1.2.3");
|
|
require_once('Auth/OpenID.php');
|
|
require_once('Auth/OpenID/Consumer.php');
|
|
require_once('Auth/OpenID/XEStore.php');
|
|
require_once('Auth/OpenID/URINorm.php');
|
|
|
|
$store = new Auth_OpenID_XEStore();
|
|
$consumer = new Auth_OpenID_Consumer($store);
|
|
$response = $consumer->complete($_GET);
|
|
|
|
switch($response->status) {
|
|
case Auth_OpenID_CANCEL :
|
|
// Handle if user authentication is canceled
|
|
return $this->stop('authorization_canceled');
|
|
case Auth_OpenID_FAILURE :
|
|
// Handle if user authentication is failed due to a certain problem (for example, openid doesn't exist) (there is no authentication required deunga openid ..)
|
|
return $this->stop('invalid_authorization');
|
|
case Auth_OpenID_SUCCESS :
|
|
{
|
|
$logged_info = Context::get('logged_info');
|
|
if (!Context::get('is_logged')) return $this->stop('msg_not_logged');
|
|
|
|
$member_srl = $logged_info->member_srl;
|
|
|
|
$args->member_srl = $member_srl;
|
|
$openid_identity = $response->signed_args["openid.identity"];
|
|
$args->openid = $openid_identity;
|
|
|
|
$output = executeQuery('member.addOpenIDToMember', $args);
|
|
if (!$output->toBool()) return $output;
|
|
|
|
Context::close();
|
|
|
|
if(Context::get('goto')){
|
|
$goto = Context::get('goto');
|
|
header("location:" . $goto);
|
|
}else{
|
|
header("location:./");
|
|
}
|
|
exit();
|
|
}
|
|
// Authentication success!
|
|
break;
|
|
default:
|
|
return $this->stop('invalid_authorization');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Disconnect OpenID
|
|
**/
|
|
function procMemberDeleteOpenIDFromMember() {
|
|
$logged_info = Context::get('logged_info');
|
|
$openid_identity = Context::get('openid_to_delete');
|
|
$arg->openid = $openid_identity;
|
|
$result = executeQuery('member.getMemberSrlByOpenID', $arg);
|
|
|
|
if (!Context::get('is_logged')) {
|
|
$this->setError(-1);
|
|
$this->setMessage('msg_not_logged');
|
|
return;
|
|
} else if (!$result->data || is_array($result->data)) {
|
|
$this->setError(-1);
|
|
$this->setMessage('msg_not_founded');
|
|
return;
|
|
} else if ($result->data->member_srl != $logged_info->member_srl) {
|
|
$this->setError(-1);
|
|
$this->setMessage('msg_not_permitted');
|
|
return;
|
|
}
|
|
|
|
$arg->openid = $openid_identity;
|
|
|
|
$output = executeQuery('member.deleteMemberOpenID', $arg);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->setMessage('success_updated');
|
|
}
|
|
|
|
|
|
/**
|
|
* @brief Log-out
|
|
**/
|
|
function procMemberLogout() {
|
|
// Call a trigger before log-out (before)
|
|
$logged_info = Context::get('logged_info');
|
|
$trigger_output = ModuleHandler::triggerCall('member.doLogout', 'before', $logged_info);
|
|
if(!$trigger_output->toBool()) return $trigger_output;
|
|
// Destroy session information
|
|
$this->destroySessionInfo();
|
|
// Call a trigger after log-out (after)
|
|
$trigger_output = ModuleHandler::triggerCall('member.doLogout', 'after', $logged_info);
|
|
if(!$trigger_output->toBool()) return $trigger_output;
|
|
|
|
$output = new Object();
|
|
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($config->after_logout_url) Context::set('redirect_url', $config->after_logout_url);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Scrap
|
|
**/
|
|
function procMemberScrapDocument() {
|
|
// Check login information
|
|
if(!Context::get('is_logged')) return new Object(-1, 'msg_not_logged');
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
$document_srl = (int)Context::get('document_srl');
|
|
if(!$document_srl) $document_srl = (int)Context::get('target_srl');
|
|
if(!$document_srl) return new Object(-1,'msg_invalid_request');
|
|
// Get document
|
|
$oDocumentModel = &getModel('document');
|
|
$oDocument = $oDocumentModel->getDocument($document_srl);
|
|
// Variables
|
|
$args->document_srl = $document_srl;
|
|
$args->member_srl = $logged_info->member_srl;
|
|
$args->user_id = $oDocument->get('user_id');
|
|
$args->user_name = $oDocument->get('user_name');
|
|
$args->nick_name = $oDocument->get('nick_name');
|
|
$args->target_member_srl = $oDocument->get('member_srl');
|
|
$args->title = $oDocument->get('title');
|
|
// Check if already scrapped
|
|
$output = executeQuery('member.getScrapDocument', $args);
|
|
if($output->data->count) return new Object(-1, 'msg_alreay_scrapped');
|
|
// Insert
|
|
$output = executeQuery('member.addScrapDocument', $args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->setError(-1);
|
|
$this->setMessage('success_registed');
|
|
}
|
|
|
|
/**
|
|
* @brief Delete a scrap
|
|
**/
|
|
function procMemberDeleteScrap() {
|
|
// Check login information
|
|
if(!Context::get('is_logged')) return new Object(-1, 'msg_not_logged');
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
$document_srl = (int)Context::get('document_srl');
|
|
if(!$document_srl) return new Object(-1,'msg_invalid_request');
|
|
// Variables
|
|
$args->member_srl = $logged_info->member_srl;
|
|
$args->document_srl = $document_srl;
|
|
return executeQuery('member.deleteScrapDocument', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief Save posts
|
|
* @Deplicated - instead Document Controller - procDocumentTempSave method use
|
|
**/
|
|
function procMemberSaveDocument() {
|
|
return new Object(0, 'Deplicated method');
|
|
}
|
|
|
|
/**
|
|
* @brief Delete the post
|
|
**/
|
|
function procMemberDeleteSavedDocument() {
|
|
// Check login information
|
|
if(!Context::get('is_logged')) return new Object(-1, 'msg_not_logged');
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
$document_srl = (int)Context::get('document_srl');
|
|
if(!$document_srl) return new Object(-1,'msg_invalid_request');
|
|
// Variables
|
|
$oDocumentController = &getController('document');
|
|
$oDocumentController->deleteDocument($document_srl, true);
|
|
}
|
|
|
|
/**
|
|
* @brief Check values when member joining
|
|
**/
|
|
function procMemberCheckValue() {
|
|
$name = Context::get('name');
|
|
$value = Context::get('value');
|
|
if(!$value) return;
|
|
|
|
$oMemberModel = &getModel('member');
|
|
// Check if logged-in
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
|
|
switch($name) {
|
|
case 'user_id' :
|
|
// Check denied ID
|
|
if($oMemberModel->isDeniedID($value)) return new Object(0,'denied_user_id');
|
|
// Check if duplicated
|
|
$member_srl = $oMemberModel->getMemberSrlByUserID($value);
|
|
if($member_srl && $logged_info->member_srl != $member_srl ) return new Object(0,'msg_exists_user_id');
|
|
break;
|
|
case 'nick_name' :
|
|
// Check if duplicated
|
|
$member_srl = $oMemberModel->getMemberSrlByNickName($value);
|
|
if($member_srl && $logged_info->member_srl != $member_srl ) return new Object(0,'msg_exists_nick_name');
|
|
|
|
break;
|
|
case 'email_address' :
|
|
// Check if duplicated
|
|
$member_srl = $oMemberModel->getMemberSrlByEmailAddress($value);
|
|
if($member_srl && $logged_info->member_srl != $member_srl ) return new Object(0,'msg_exists_email_address');
|
|
break;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Join Membership
|
|
**/
|
|
function procMemberInsert() {
|
|
if (Context::getRequestMethod () == "GET") return new Object (-1, "msg_invalid_request");
|
|
$oMemberModel = &getModel ('member');
|
|
$config = $oMemberModel->getMemberConfig ();
|
|
|
|
// call a trigger (before)
|
|
$trigger_output = ModuleHandler::triggerCall ('member.procMemberInsert', 'before', $config);
|
|
if (!$trigger_output->toBool ()) return $trigger_output;
|
|
|
|
// Check if an administrator allows a membership
|
|
if ($config->enable_join != 'Y') return $this->stop ('msg_signup_disabled');
|
|
|
|
// Check if the user accept the license terms (only if terms exist)
|
|
if ($config->agreement && Context::get('accept_agreement')!='Y') return $this->stop('msg_accept_agreement');
|
|
|
|
// Extract the necessary information in advance
|
|
$args = Context::gets('user_id','user_name','nick_name','homepage','blog','birthday','email_address','password','password1','allow_mailing','find_account_question','find_account_answer');
|
|
$args->member_srl = getNextSequence();
|
|
$args->list_order = -1 * $args->member_srl;
|
|
if($args->password1) $args->password = $args->password1;
|
|
|
|
// Remove some unnecessary variables from all the vars
|
|
$all_args = Context::getRequestVars();
|
|
unset($all_args->module);
|
|
unset($all_args->act);
|
|
unset($all_args->is_admin);
|
|
unset($all_args->description);
|
|
unset($all_args->group_srl_list);
|
|
unset($all_args->body);
|
|
unset($all_args->accept_agreement);
|
|
unset($all_args->signature);
|
|
unset($all_args->password2);
|
|
|
|
// Set the user state as "denied" when using mail authentication
|
|
if ($config->enable_confirm == 'Y') $args->denied = 'Y';
|
|
// Add extra vars after excluding necessary information from all the requested arguments
|
|
$extra_vars = delObjectVars($all_args, $args);
|
|
$args->extra_vars = serialize($extra_vars);
|
|
// Execute insert or update depending on the value of member_srl
|
|
$output = $this->insertMember($args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
// insert ProfileImage, ImageName, ImageMark
|
|
debugPrint($all_args);
|
|
// If a virtual site, join the site
|
|
$site_module_info = Context::get('site_module_info');
|
|
if($site_module_info->site_srl > 0) {
|
|
$columnList = array('site_srl', 'group_srl');
|
|
$default_group = $oMemberModel->getDefaultGroup($site_module_info->site_srl, $columnList);
|
|
if($default_group->group_srl) {
|
|
$this->addMemberToGroup($args->member_srl, $default_group->group_srl, $site_module_info->site_srl);
|
|
}
|
|
|
|
}
|
|
// Log-in
|
|
if ($config->enable_confirm != 'Y') $this->doLogin($args->user_id);
|
|
// Results
|
|
$this->add('member_srl', $args->member_srl);
|
|
if($config->redirect_url) $this->add('redirect_url', $config->redirect_url);
|
|
if ($config->enable_confirm == 'Y') {
|
|
$msg = sprintf(Context::getLang('msg_confirm_mail_sent'), $args->email_address);
|
|
$this->setMessage($msg);
|
|
}
|
|
else $this->setMessage('success_registed');
|
|
// Call a trigger (after)
|
|
$trigger_output = ModuleHandler::triggerCall('member.procMemberInsert', 'after', $config);
|
|
if(!$trigger_output->toBool()) return $trigger_output;
|
|
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', '');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Edit member profile
|
|
**/
|
|
function procMemberModifyInfo() {
|
|
if(!Context::get('is_logged')) return $this->stop('msg_not_logged');
|
|
// Extract the necessary information in advance
|
|
$args = Context::gets('user_name','nick_name','homepage','blog','birthday','email_address','allow_mailing','find_account_question','find_account_answer');
|
|
// Login Information
|
|
$logged_info = Context::get('logged_info');
|
|
$args->member_srl = $logged_info->member_srl;
|
|
// Remove some unnecessary variables from all the vars
|
|
$all_args = Context::getRequestVars();
|
|
unset($all_args->module);
|
|
unset($all_args->act);
|
|
unset($all_args->is_admin);
|
|
unset($all_args->description);
|
|
unset($all_args->group_srl_list);
|
|
unset($all_args->body);
|
|
unset($all_args->accept_agreement);
|
|
unset($all_args->signature);
|
|
unset($all_args->_filter);
|
|
|
|
// Add extra vars after excluding necessary information from all the requested arguments
|
|
$extra_vars = delObjectVars($all_args, $args);
|
|
$args->extra_vars = serialize($extra_vars);
|
|
// Create a member model object
|
|
$oMemberModel = &getModel('member');
|
|
// Execute insert or update depending on the value of member_srl
|
|
$output = $this->updateMember($args);
|
|
if(!$output->toBool()) return $output;
|
|
// Save Signature
|
|
$signature = Context::get('signature');
|
|
$this->putSignature($args->member_srl, $signature);
|
|
// Get user_id information
|
|
$this->memberInfo = $oMemberModel->getMemberInfoByMemberSrl($args->member_srl);
|
|
// Call a trigger after successfully log-in (after)
|
|
$trigger_output = ModuleHandler::triggerCall('member.doLogin', 'after', $this->memberInfo);
|
|
if(!$trigger_output->toBool()) return $trigger_output;
|
|
|
|
$this->setSessionInfo();
|
|
// Return result
|
|
$this->add('member_srl', $args->member_srl);
|
|
$this->setMessage('success_updated');
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', 'dispMemberInfo');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Change the user password
|
|
**/
|
|
function procMemberModifyPassword() {
|
|
if(!Context::get('is_logged')) return $this->stop('msg_not_logged');
|
|
// Extract the necessary information in advance
|
|
$current_password = trim(Context::get('current_password'));
|
|
$password = trim(Context::get('password1'));
|
|
// Get information of logged-in user
|
|
$logged_info = Context::get('logged_info');
|
|
$member_srl = $logged_info->member_srl;
|
|
// Create a member model object
|
|
$oMemberModel = &getModel('member');
|
|
// Get information of member_srl
|
|
$columnList = array('member_srl', 'password');
|
|
$member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl, 0, $columnList);
|
|
// Verify the cuttent password
|
|
if(!$oMemberModel->isValidPassword($member_info->password, $current_password)) return new Object(-1, 'invalid_password');
|
|
|
|
// Check if a new password is as same as the previous password
|
|
if ($current_password == $password) return new Object(-1, 'invalid_new_password');
|
|
|
|
// Execute insert or update depending on the value of member_srl
|
|
$args->member_srl = $member_srl;
|
|
$args->password = $password;
|
|
$output = $this->updateMemberPassword($args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$this->add('member_srl', $args->member_srl);
|
|
$this->setMessage('success_updated');
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', 'dispMemberInfo');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Membership withdrawal
|
|
**/
|
|
function procMemberLeave() {
|
|
if(!Context::get('is_logged')) return $this->stop('msg_not_logged');
|
|
// Extract the necessary information in advance
|
|
$password = trim(Context::get('password'));
|
|
// Get information of logged-in user
|
|
$logged_info = Context::get('logged_info');
|
|
$member_srl = $logged_info->member_srl;
|
|
// Create a member model object
|
|
$oMemberModel = &getModel('member');
|
|
// Get information of member_srl
|
|
if(!$this->memberInfo->password)
|
|
{
|
|
$columnList = array('member_srl', 'password');
|
|
$memberInfo = $oMemberModel->getMemberInfoByMemberSrl($member_srl, 0, $columnList);
|
|
$this->memberInfo->password = $memberInfo->password;
|
|
}
|
|
// Verify the cuttent password
|
|
if(!$oMemberModel->isValidPassword($this->memberInfo->password, $password)) return new Object(-1, 'invalid_password');
|
|
|
|
$output = $this->deleteMember($member_srl);
|
|
if(!$output->toBool()) return $output;
|
|
// Destroy all session information
|
|
$this->destroySessionInfo();
|
|
// Return success message
|
|
$this->setMessage('success_leaved');
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', '');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief OpenID Withdrawal
|
|
**/
|
|
function procMemberOpenIDLeave() {
|
|
// Return an error if in the non-login state
|
|
if(!Context::get('is_logged')) return $this->stop('msg_not_logged');
|
|
// Compare the current IP with session IP
|
|
if($_SESSION['ipaddress']!=$_SERVER['REMOTE_ADDR']) return $this->stop('msg_not_permitted');
|
|
// Get information of logged-in user
|
|
$logged_info = Context::get('logged_info');
|
|
$member_srl = $logged_info->member_srl;
|
|
|
|
$output = $this->deleteMember($member_srl);
|
|
if(!$output->toBool()) return $output;
|
|
// Destroy all session information
|
|
$this->destroySessionInfo();
|
|
// Return success message
|
|
$this->setMessage('success_leaved');
|
|
}
|
|
|
|
/**
|
|
* @brief Add a profile image
|
|
**/
|
|
function procMemberInsertProfileImage() {
|
|
// Check if the file is successfully uploaded
|
|
$file = $_FILES['profile_image'];
|
|
if(!is_uploaded_file($file['tmp_name'])) return $this->stop('msg_not_uploaded_profile_image');
|
|
// Ignore if member_srl is invalid or doesn't exist.
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return $this->stop('msg_not_uploaded_profile_image');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
if($logged_info->is_admin != 'Y' && $logged_info->member_srl != $member_srl) return $this->stop('msg_not_uploaded_profile_image');
|
|
// Return if member module is set not to use an image name or the user is not an administrator ;
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($logged_info->is_admin != 'Y' && $config->profile_image != 'Y') return $this->stop('msg_not_uploaded_profile_image');
|
|
|
|
$this->insertProfileImage($member_srl, $file['tmp_name']);
|
|
// Page refresh
|
|
//$this->setRefreshPage();
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', 'dispMemberModifyInfo');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
function insertProfileImage($member_srl, $target_file) {
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
// Get an image size
|
|
$max_width = $config->profile_image_max_width;
|
|
if(!$max_width) $max_width = "90";
|
|
$max_height = $config->profile_image_max_height;
|
|
if(!$max_height) $max_height = "20";
|
|
// Get a target path to save
|
|
$target_path = sprintf('files/member_extra_info/profile_image/%s', getNumberingPath($member_srl));
|
|
FileHandler::makeDir($target_path);
|
|
// Get file information
|
|
list($width, $height, $type, $attrs) = @getimagesize($target_file);
|
|
if($type == 3) $ext = 'png';
|
|
elseif($type == 2) $ext = 'jpg';
|
|
else $ext = 'gif';
|
|
|
|
$target_filename = sprintf('%s%d.%s', $target_path, $member_srl, $ext);
|
|
// Convert if the image size is larger than a given size or if the format is not a gif
|
|
if($width > $max_width || $height > $max_height || $type!=1) FileHandler::createImageFile($target_file, $target_filename, $max_width, $max_height, $ext);
|
|
else @copy($target_file, $target_filename);
|
|
}
|
|
|
|
/**
|
|
* @brief Add an image name
|
|
**/
|
|
function procMemberInsertImageName() {
|
|
// Check if the file is successfully uploaded
|
|
$file = $_FILES['image_name'];
|
|
if(!is_uploaded_file($file['tmp_name'])) return $this->stop('msg_not_uploaded_image_name');
|
|
// Ignore if member_srl is invalid or doesn't exist.
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return $this->stop('msg_not_uploaded_image_name');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
if($logged_info->is_admin != 'Y' && $logged_info->member_srl != $member_srl) return $this->stop('msg_not_uploaded_image_name');
|
|
// Return if member module is set not to use an image name or the user is not an administrator ;
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($logged_info->is_admin != 'Y' && $config->image_name != 'Y') return $this->stop('msg_not_uploaded_image_name');
|
|
|
|
$this->insertImageName($member_srl, $file['tmp_name']);
|
|
// Page refresh
|
|
//$this->setRefreshPage();
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', 'dispMemberModifyInfo');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
function insertImageName($member_srl, $target_file) {
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
// Get an image size
|
|
$max_width = $config->image_name_max_width;
|
|
if(!$max_width) $max_width = "90";
|
|
$max_height = $config->image_name_max_height;
|
|
if(!$max_height) $max_height = "20";
|
|
// Get a target path to save
|
|
$target_path = sprintf('files/member_extra_info/image_name/%s/', getNumberingPath($member_srl));
|
|
FileHandler::makeDir($target_path);
|
|
|
|
$target_filename = sprintf('%s%d.gif', $target_path, $member_srl);
|
|
// Get file information
|
|
list($width, $height, $type, $attrs) = @getimagesize($target_file);
|
|
// Convert if the image size is larger than a given size or if the format is not a gif
|
|
if($width > $max_width || $height > $max_height || $type!=1) FileHandler::createImageFile($target_file, $target_filename, $max_width, $max_height, 'gif');
|
|
else @copy($target_file, $target_filename);
|
|
}
|
|
|
|
/**
|
|
* @brief Delete profile image
|
|
**/
|
|
function procMemberDeleteProfileImage() {
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return new Object(0,'success');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
if($logged_info->is_admin != 'Y') {
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($config->profile_image == 'N') return new Object(0,'success');
|
|
}
|
|
|
|
if($logged_info->is_admin == 'Y' || $logged_info->member_srl == $member_srl) {
|
|
$oMemberModel = &getModel('member');
|
|
$profile_image = $oMemberModel->getProfileImage($member_srl);
|
|
FileHandler::removeFile($profile_image->file);
|
|
}
|
|
return new Object(0,'success');
|
|
}
|
|
|
|
/**
|
|
* @brief Delete Image name
|
|
**/
|
|
function procMemberDeleteImageName() {
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return new Object(0,'success');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
if($logged_info->is_admin != 'Y') {
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($config->image_name == 'N') return new Object(0,'success');
|
|
}
|
|
|
|
if($logged_info->is_admin == 'Y' || $logged_info->member_srl == $member_srl) {
|
|
$oMemberModel = &getModel('member');
|
|
$image_name = $oMemberModel->getImageName($member_srl);
|
|
FileHandler::removeFile($image_name->file);
|
|
}
|
|
return new Object(0,'success');
|
|
}
|
|
|
|
/**
|
|
* @brief Add an image to mark
|
|
**/
|
|
function procMemberInsertImageMark() {
|
|
// Check if the file is successfully uploaded
|
|
$file = $_FILES['image_mark'];
|
|
if(!is_uploaded_file($file['tmp_name'])) return $this->stop('msg_not_uploaded_image_mark');
|
|
// Ignore if member_srl is invalid or doesn't exist.
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return $this->stop('msg_not_uploaded_image_mark');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
if($logged_info->is_admin != 'Y' && $logged_info->member_srl != $member_srl) return $this->stop('msg_not_uploaded_image_mark');
|
|
// Membership in the images mark the module using the ban was set by an administrator or return;
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
if($logged_info->is_admin != 'Y' && $config->image_mark != 'Y') return $this->stop('msg_not_uploaded_image_mark');
|
|
|
|
$this->insertImageMark($member_srl, $file['tmp_name']);
|
|
// Page refresh
|
|
//$this->setRefreshPage();
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', 'dispMemberModifyInfo');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
function insertImageMark($member_srl, $target_file) {
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
// Get an image size
|
|
$max_width = $config->image_mark_max_width;
|
|
if(!$max_width) $max_width = "20";
|
|
$max_height = $config->image_mark_max_height;
|
|
if(!$max_height) $max_height = "20";
|
|
|
|
$target_path = sprintf('files/member_extra_info/image_mark/%s/', getNumberingPath($member_srl));
|
|
FileHandler::makeDir($target_path);
|
|
|
|
$target_filename = sprintf('%s%d.gif', $target_path, $member_srl);
|
|
// Get file information
|
|
list($width, $height, $type, $attrs) = @getimagesize($target_file);
|
|
|
|
if($width > $max_width || $height > $max_height || $type!=1) FileHandler::createImageFile($target_file, $target_filename, $max_width, $max_height, 'gif');
|
|
else @copy($target_file, $target_filename);
|
|
|
|
}
|
|
|
|
/**
|
|
* @brief Delete Image Mark
|
|
**/
|
|
function procMemberDeleteImageMark() {
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return new Object(0,'success');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
if($logged_info->is_admin == 'Y' || $logged_info->member_srl == $member_srl) {
|
|
$oMemberModel = &getModel('member');
|
|
$image_mark = $oMemberModel->getImageMark($member_srl);
|
|
FileHandler::removeFile($image_mark->file);
|
|
}
|
|
return new Object(0,'success');
|
|
}
|
|
|
|
/**
|
|
* @brief Find ID/Password
|
|
**/
|
|
function procMemberFindAccount() {
|
|
$email_address = Context::get('email_address');
|
|
if(!$email_address) return new Object(-1, 'msg_invalid_request');
|
|
|
|
$oMemberModel = &getModel('member');
|
|
$oModuleModel = &getModel('module');
|
|
// Check if a member having the same email address exists
|
|
$member_srl = $oMemberModel->getMemberSrlByEmailAddress($email_address);
|
|
if(!$member_srl) return new Object(-1, 'msg_email_not_exists');
|
|
// Get information of the member
|
|
$columnList = array('denied', 'member_srl', 'user_id', 'user_name', 'email_address', 'nick_name');
|
|
$member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl, 0, $columnList);
|
|
// Check if possible to find member's ID and password
|
|
if ($member_info->denied == 'Y') {
|
|
$chk_args->member_srl = $member_info->member_srl;
|
|
$output = executeQuery('member.chkAuthMail', $chk_args);
|
|
if ($output->toBool() && $output->data->count != '0') return new Object(-1, 'msg_user_not_confirmed');
|
|
}
|
|
// Insert data into the authentication DB
|
|
$args->user_id = $member_info->user_id;
|
|
$args->member_srl = $member_info->member_srl;
|
|
$args->new_password = rand(111111,999999);
|
|
$args->auth_key = md5( rand(0,999999 ) );
|
|
$args->is_register = 'N';
|
|
|
|
$output = executeQuery('member.insertAuthMail', $args);
|
|
if(!$output->toBool()) return $output;
|
|
// Get content of the email to send a member
|
|
Context::set('auth_args', $args);
|
|
Context::set('member_info', $member_info);
|
|
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
if(!$member_config->skin) $member_config->skin = "default";
|
|
if(!$member_config->colorset) $member_config->colorset = "white";
|
|
|
|
Context::set('member_config', $member_config);
|
|
|
|
$tpl_path = sprintf('%sskins/%s', $this->module_path, $member_config->skin);
|
|
if(!is_dir($tpl_path)) $tpl_path = sprintf('%sskins/%s', $this->module_path, 'default');
|
|
|
|
$find_url = getFullUrl ('', 'module', 'member', 'act', 'procMemberAuthAccount', 'member_srl', $member_info->member_srl, 'auth_key', $args->auth_key);
|
|
Context::set('find_url', $find_url);
|
|
|
|
$oTemplate = &TemplateHandler::getInstance();
|
|
$content = $oTemplate->compile($tpl_path, 'find_member_account_mail');
|
|
// Get information of the Webmaster
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
// Send a mail
|
|
$oMail = new Mail();
|
|
$oMail->setTitle( Context::getLang('msg_find_account_title') );
|
|
$oMail->setContent($content);
|
|
$oMail->setSender( $member_config->webmaster_name?$member_config->webmaster_name:'webmaster', $member_config->webmaster_email);
|
|
$oMail->setReceiptor( $member_info->user_name, $member_info->email_address );
|
|
$oMail->send();
|
|
// Return message
|
|
$msg = sprintf(Context::getLang('msg_auth_mail_sent'), $member_info->email_address);
|
|
return new Object(0,$msg);
|
|
}
|
|
|
|
|
|
/**
|
|
* @brief Generate a temp password by answering to the pre-determined question
|
|
**/
|
|
function procMemberFindAccountByQuestion() {
|
|
$email_address = Context::get('email_address');
|
|
$user_id = Context::get('user_id');
|
|
$find_account_question = trim(Context::get('find_account_question'));
|
|
$find_account_answer = trim(Context::get('find_account_answer'));
|
|
|
|
if(!$user_id || !$email_address || !$find_account_question || !$find_account_answer) return new Object(-1, 'msg_invalid_request');
|
|
|
|
$oMemberModel = &getModel('member');
|
|
$oModuleModel = &getModel('module');
|
|
// Check if a member having the same email address exists
|
|
$member_srl = $oMemberModel->getMemberSrlByEmailAddress($email_address);
|
|
if(!$member_srl) return new Object(-1, 'msg_email_not_exists');
|
|
// Get information of the member
|
|
$columnList = array('member_srl', 'find_account_question', 'find_account_answer');
|
|
$member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl, 0, $columnList);
|
|
|
|
// Display a message if no answer is entered
|
|
if (!$member_info->find_account_question || !$member_info->find_account_answer) return new Object(-1, 'msg_question_not_exists');
|
|
|
|
if(trim($member_info->find_account_question) != $find_account_question || trim($member_info->find_account_answer) != $find_account_answer) return new Object(-1, 'msg_answer_not_matches');
|
|
|
|
// Update to a temporary password and set change_password_date to 1
|
|
$args->member_srl = $member_srl;
|
|
list($usec, $sec) = explode(" ", microtime());
|
|
$temp_password = substr(md5($user_id . $member_info->find_account_answer. $usec . $sec),0,15);
|
|
|
|
$args->password = $temp_password;
|
|
$args->change_password_date = '1';
|
|
$output = $this->updateMemberPassword($args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$_SESSION['xe_temp_password_'.$user_id] = $temp_password;
|
|
|
|
$this->add('user_id',$user_id);
|
|
}
|
|
|
|
/**
|
|
* @brief Execute finding ID/Passoword
|
|
* When clicking the link in the verification email, a method is called to change the old password and to authenticate it
|
|
**/
|
|
function procMemberAuthAccount() {
|
|
// Test user_id and authkey
|
|
$member_srl = Context::get('member_srl');
|
|
$auth_key = Context::get('auth_key');
|
|
if(!$member_srl || !$auth_key) return $this->stop('msg_invalid_request');
|
|
// Test logs for finding password by user_id and authkey
|
|
$args->member_srl = $member_srl;
|
|
$args->auth_key = $auth_key;
|
|
$output = executeQuery('member.getAuthMail', $args);
|
|
if(!$output->toBool() || $output->data->auth_key != $auth_key) return $this->stop('msg_invalid_auth_key');
|
|
// If credentials are correct, change the password to a new one
|
|
if ($output->data->is_register == 'Y') {
|
|
$args->password = $output->data->new_password;
|
|
$args->denied = 'N';
|
|
} else {
|
|
$args->password = md5($output->data->new_password);
|
|
unset($args->denied);
|
|
}
|
|
// Back up the value of $Output->data->is_register
|
|
$is_register = $output->data->is_register;
|
|
|
|
$output = executeQuery('member.updateMemberPassword', $args);
|
|
if(!$output->toBool()) return $this->stop($output->getMessage());
|
|
// Remove all values having the member_srl from authentication table
|
|
executeQuery('member.deleteAuthMail',$args);
|
|
// Notify the result
|
|
Context::set('is_register', $is_register);
|
|
$this->setTemplatePath($this->module_path.'tpl');
|
|
$this->setTemplateFile('msg_success_authed');
|
|
}
|
|
|
|
/**
|
|
* @brief Execute finding ID/Passoword
|
|
* When clicking the link in the verification email, a method is called to change the old password and to authenticate it
|
|
**/
|
|
function procMemberUpdateAuthMail() {
|
|
$member_srl = Context::get('member_srl');
|
|
if(!$member_srl) return new Object(-1, 'msg_invalid_request');
|
|
|
|
$oMemberModel = &getModel('member');
|
|
// Get information of the member
|
|
$member_info = $oMemberModel->getMemberInfoByMemberSrl($member_srl);
|
|
// Check if the member is set to allow a request to re-send an authentication mail
|
|
if ($member_info->denied != 'Y')
|
|
return new Object(-1, 'msg_invalid_request');
|
|
|
|
$chk_args->member_srl = $member_srl;
|
|
$output = executeQuery('member.chkAuthMail', $chk_args);
|
|
if ($output->toBool() && $output->data->count == '0') return new Object(-1, 'msg_invalid_request');
|
|
// Insert data into the authentication DB
|
|
$auth_args->member_srl = $member_srl;
|
|
$auth_args->auth_key = md5(rand(0, 999999));
|
|
|
|
$output = executeQuery('member.updateAuthMail', $auth_args);
|
|
if (!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// Get content of the email to send a member
|
|
Context::set('auth_args', $auth_args);
|
|
Context::set('member_info', $member_info);
|
|
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
if(!$member_config->skin) $member_config->skin = "default";
|
|
if(!$member_config->colorset) $member_config->colorset = "white";
|
|
|
|
Context::set('member_config', $member_config);
|
|
|
|
$tpl_path = sprintf('%sskins/%s', $this->module_path, $member_config->skin);
|
|
if(!is_dir($tpl_path)) $tpl_path = sprintf('%sskins/%s', $this->module_path, 'default');
|
|
|
|
$auth_url = getFullUrl('','module','member','act','procMemberAuthAccount','member_srl',$member_info->member_srl, 'auth_key',$auth_args->auth_key);
|
|
Context::set('auth_url', $auth_url);
|
|
|
|
$oTemplate = &TemplateHandler::getInstance();
|
|
$content = $oTemplate->compile($tpl_path, 'confirm_member_account_mail');
|
|
// Get information of the Webmaster
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
// Send a mail
|
|
$oMail = new Mail();
|
|
$oMail->setTitle( Context::getLang('msg_confirm_account_title') );
|
|
$oMail->setContent($content);
|
|
$oMail->setSender( $member_config->webmaster_name?$member_config->webmaster_name:'webmaster', $member_config->webmaster_email);
|
|
$oMail->setReceiptor( $member_info->user_name, $member_info->email_address );
|
|
$oMail->send();
|
|
// Return message
|
|
$msg = sprintf(Context::getLang('msg_auth_mail_sent'), $member_info->email_address);
|
|
return new Object(-1, $msg);
|
|
}
|
|
|
|
/**
|
|
* @brief Request to re-send the authentication mail
|
|
**/
|
|
function procMemberResendAuthMail() {
|
|
// Get an email_address
|
|
$email_address = Context::get('email_address');
|
|
if(!$email_address) return $this->stop('msg_invalid_request');
|
|
// Log test by using email_address
|
|
$oMemberModel = &getModel('member');
|
|
|
|
$args->email_address = $email_address;
|
|
$memberSrl = $oMemberModel->getMemberSrlByEmailAddress($email_address);
|
|
if(!$memberSrl) return $this->stop('msg_not_exists_member');
|
|
|
|
$columnList = array('member_srl', 'user_id', 'user_name', 'nick_name', 'email_address');
|
|
$memberInfo = $oMemberModel->getMemberInfoByMemberSrl($memberSrl, 0, $columnList);
|
|
|
|
// Check if a authentication mail has been sent previously
|
|
$chk_args->member_srl = $memberInfo->member_srl;
|
|
$output = executeQuery('member.chkAuthMail', $chk_args);
|
|
if($output->toBool() && $output->data->count == '0') return new Object(-1, 'msg_invalid_request');
|
|
|
|
$auth_args->member_srl = $memberInfo->member_srl;
|
|
$output = executeQueryArray('member.getAuthMailInfo', $auth_args);
|
|
if(!$output->data || !$output->data[0]->auth_key) return new Object(-1, 'msg_invalid_request');
|
|
$auth_info = $output->data[0];
|
|
// Get content of the email to send a member
|
|
Context::set('member_info', $memberInfo);
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
if(!$member_config->skin) $member_config->skin = "default";
|
|
if(!$member_config->colorset) $member_config->colorset = "white";
|
|
|
|
Context::set('member_config', $member_config);
|
|
|
|
$tpl_path = sprintf('%sskins/%s', $this->module_path, $member_config->skin);
|
|
if(!is_dir($tpl_path)) $tpl_path = sprintf('%sskins/%s', $this->module_path, 'default');
|
|
|
|
$auth_url = getFullUrl('','module','member','act','procMemberAuthAccount','member_srl',$memberInfo->member_srl, 'auth_key',$auth_info->auth_key);
|
|
Context::set('auth_url', $auth_url);
|
|
|
|
$oTemplate = &TemplateHandler::getInstance();
|
|
$content = $oTemplate->compile($tpl_path, 'confirm_member_account_mail');
|
|
// Get information of the Webmaster
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
// Send a mail
|
|
$oMail = new Mail();
|
|
$oMail->setTitle( Context::getLang('msg_confirm_account_title') );
|
|
$oMail->setContent($content);
|
|
$oMail->setSender( $member_config->webmaster_name?$member_config->webmaster_name:'webmaster', $member_config->webmaster_email);
|
|
$oMail->setReceiptor( $args->user_name, $args->email_address );
|
|
$oMail->send();
|
|
|
|
$msg = sprintf(Context::getLang('msg_confirm_mail_sent'), $args->email_address);
|
|
$this->setMessage($msg);
|
|
if(!in_array(Context::getRequestMethod(),array('XMLRPC','JSON'))) {
|
|
$returnUrl = Context::get('success_return_url') ? Context::get('success_return_url') : getNotEncodedUrl('', 'mid', Context::get('mid'), 'act', '');
|
|
header('location:'.$returnUrl);
|
|
return;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Join a virtual site
|
|
**/
|
|
function procModuleSiteSignUp() {
|
|
$site_module_info = Context::get('site_module_info');
|
|
$logged_info = Context::get('logged_info');
|
|
if(!$site_module_info->site_srl || !Context::get('is_logged') || count($logged_info->group_srl_list) ) return new Object(-1,'msg_invalid_request');
|
|
|
|
$oMemberModel = &getModel('member');
|
|
$columnList = array('site_srl', 'group_srl', 'title');
|
|
$default_group = $oMemberModel->getDefaultGroup($site_module_info->site_srl, $columnList);
|
|
$this->addMemberToGroup($logged_info->member_srl, $default_group->group_srl, $site_module_info->site_srl);
|
|
$groups[$default_group->group_srl] = $default_group->title;
|
|
$logged_info->group_list = $groups;
|
|
}
|
|
|
|
/**
|
|
* @brief Leave the virtual site
|
|
**/
|
|
function procModuleSiteLeave() {
|
|
$site_module_info = Context::get('site_module_info');
|
|
$logged_info = Context::get('logged_info');
|
|
if(!$site_module_info->site_srl || !Context::get('is_logged') || count($logged_info->group_srl_list) ) return new Object(-1,'msg_invalid_request');
|
|
|
|
$args->site_srl= $site_module_info->site_srl;
|
|
$args->member_srl = $logged_info->member_srl;
|
|
$output = executeQuery('member.deleteMembersGroup', $args);
|
|
if(!$output->toBool()) return $output;
|
|
$this->setMessage('success_deleted');
|
|
}
|
|
|
|
/**
|
|
* @brief Save the member configurations
|
|
**/
|
|
function setMemberConfig($args) {
|
|
if(!$args->skin) $args->skin = "default";
|
|
if(!$args->colorset) $args->colorset = "white";
|
|
if(!$args->editor_skin) $args->editor_skin= "xpresseditor";
|
|
if(!$args->editor_colorset) $args->editor_colorset = "white";
|
|
if($args->enable_join!='Y') $args->enable_join = 'N';
|
|
if($args->enable_openid!='Y') $args->enable_openid= 'N';
|
|
if($args->profile_image !='Y') $args->profile_image = 'N';
|
|
if($args->image_name!='Y') $args->image_name = 'N';
|
|
if($args->image_mark!='Y') $args->image_mark = 'N';
|
|
if($args->group_image_mark!='Y') $args->group_image_mark = 'N';
|
|
if(!trim(strip_tags($args->agreement))) $args->agreement = null;
|
|
$args->limit_day = (int)$args->limit_day;
|
|
|
|
$agreement = trim($args->agreement);
|
|
unset($args->agreement);
|
|
|
|
$oModuleController = &getController('module');
|
|
$output = $oModuleController->insertModuleConfig('member',$args);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$agreement_file = _XE_PATH_.'files/member_extra_info/agreement.txt';
|
|
FileHandler::writeFile($agreement_file, $agreement);
|
|
|
|
return new Object();
|
|
}
|
|
|
|
/**
|
|
* @brief Save the signature as a file
|
|
**/
|
|
function putSignature($member_srl, $signature) {
|
|
$signature = trim(removeHackTag($signature));
|
|
$signature = preg_replace('/<(\/?)(embed|object|param)/is', '<$1$2', $signature);
|
|
|
|
$check_signature = trim(str_replace(array(' ',"\n","\r"),'',strip_tags($signature,'<img><object>')));
|
|
$path = sprintf('files/member_extra_info/signature/%s/', getNumberingPath($member_srl));
|
|
$filename = sprintf('%s%d.signature.php', $path, $member_srl);
|
|
|
|
if(!$check_signature) return FileHandler::removeFile($filename);
|
|
|
|
$buff = sprintf('<?php if(!defined("__ZBXE__")) exit();?>%s', $signature);
|
|
FileHandler::makeDir($path);
|
|
FileHandler::writeFile($filename, $buff);
|
|
}
|
|
|
|
/**
|
|
* @brief Delete the signature file
|
|
**/
|
|
function delSignature($member_srl) {
|
|
$filename = sprintf('files/member_extra_info/signature/%s%d.gif', getNumberingPath($member_srl), $member_srl);
|
|
FileHandler::removeFile($filename);
|
|
}
|
|
|
|
/**
|
|
* @brief Add group_srl to member_srl
|
|
**/
|
|
function addMemberToGroup($member_srl,$group_srl,$site_srl=0) {
|
|
$args->member_srl = $member_srl;
|
|
$args->group_srl = $group_srl;
|
|
if($site_srl) $args->site_srl = $site_srl;
|
|
|
|
$oModel =& getModel('member');
|
|
$groups = $oModel->getMemberGroups($member_srl, $site_srl, true);
|
|
if($groups[$group_srl]) return new Object();
|
|
|
|
// Add
|
|
$output = executeQuery('member.addMemberToGroup',$args);
|
|
$output2 = ModuleHandler::triggerCall('member.addMemberToGroup', 'after', $args);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Change a group of certain members
|
|
* Available only when a member has a single group
|
|
**/
|
|
function replaceMemberGroup($args) {
|
|
$obj->site_srl = $args->site_srl;
|
|
$obj->member_srl = implode(',',$args->member_srl);
|
|
|
|
$output = executeQueryArray('member.getMembersGroup', $obj);
|
|
if($output->data) foreach($output->data as $key => $val) $date[$val->member_srl] = $val->regdate;
|
|
|
|
$output = executeQuery('member.deleteMembersGroup', $obj);
|
|
if(!$output->toBool()) return $output;
|
|
|
|
$inserted_members = array();
|
|
foreach($args->member_srl as $key => $val) {
|
|
if($inserted_members[$val]) continue;
|
|
$inserted_members[$val] = true;
|
|
|
|
unset($obj);
|
|
$obj->member_srl = $val;
|
|
$obj->group_srl = $args->group_srl;
|
|
$obj->site_srl = $args->site_srl;
|
|
$obj->regdate = $date[$obj->member_srl];
|
|
$output = executeQuery('member.addMemberToGroup', $obj);
|
|
if(!$output->toBool()) return $output;
|
|
}
|
|
return new Object();
|
|
}
|
|
|
|
|
|
/**
|
|
* @brief Auto-login
|
|
**/
|
|
function doAutologin() {
|
|
// Get a key value of auto log-in
|
|
$args->autologin_key = $_COOKIE['xeak'];
|
|
// Get information of the key
|
|
$output = executeQuery('member.getAutologin', $args);
|
|
// If no information exists, delete a cookie
|
|
if(!$output->toBool() || !$output->data) {
|
|
setCookie('xeak',null,time()+60*60*24*365, '/');
|
|
return;
|
|
}
|
|
|
|
$user_id = $output->data->user_id;
|
|
$password = $output->data->password;
|
|
if(!$user_id || !$password) {
|
|
setCookie('xeak',null,time()+60*60*24*365, '/');
|
|
return;
|
|
}
|
|
|
|
$do_auto_login = false;
|
|
|
|
// Compare key values based on the information
|
|
$key = md5($user_id.$password.$_SERVER['REMOTE_ADDR']);
|
|
|
|
if($key == $args->autologin_key) {
|
|
|
|
// Check change_password_date
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
$limit_date = $member_config->change_password_date;
|
|
|
|
// Check if change_password_date is set
|
|
if($limit_date > 0) {
|
|
$oMemberModel = &getModel('member');
|
|
$columnList = array('member_srl', 'change_password_date');
|
|
$member_info = $oMemberModel->getMemberInfoByUserID($user_id, $columnList);
|
|
|
|
if($member_info->change_password_date >= date('YmdHis', strtotime('-'.$limit_date.' day')) ){
|
|
$do_auto_login = true;
|
|
}
|
|
|
|
} else {
|
|
$do_auto_login = true;
|
|
}
|
|
}
|
|
|
|
|
|
if($do_auto_login) {
|
|
$output = $this->doLogin($user_id);
|
|
} else {
|
|
executeQuery('member.deleteAutologin', $args);
|
|
setCookie('xeak',null,time()+60*60*24*365, '/');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Log-in
|
|
**/
|
|
function doLogin($user_id, $password = '', $keep_signed = false) {
|
|
$user_id = strtolower($user_id);
|
|
// Call a trigger before log-in (before)
|
|
$trigger_obj->user_id = $user_id;
|
|
$trigger_obj->password = $password;
|
|
$trigger_output = ModuleHandler::triggerCall('member.doLogin', 'before', $trigger_obj);
|
|
if(!$trigger_output->toBool()) return $trigger_output;
|
|
// Create a member model object
|
|
$oMemberModel = &getModel('member');
|
|
// Get user_id information
|
|
$this->memberInfo = $oMemberModel->getMemberInfoByUserID($user_id);
|
|
// Set an invalid user if no value returned
|
|
if(!$user_id || strtolower($this->memberInfo->user_id) != strtolower($user_id)) return new Object(-1, 'invalid_user_id');
|
|
// Password Check
|
|
if($password && !$oMemberModel->isValidPassword($this->memberInfo->password, $password)) return new Object(-1, 'invalid_password');
|
|
// If denied == 'Y', notify
|
|
if($this->memberInfo->denied == 'Y') {
|
|
$args->member_srl = $this->memberInfo->member_srl;
|
|
$output = executeQuery('member.chkAuthMail', $args);
|
|
if ($output->toBool() && $output->data->count != '0') return new Object(-1,'msg_user_not_confirmed');
|
|
return new Object(-1,'msg_user_denied');
|
|
}
|
|
// Notify if denied_date is less than the current time
|
|
if($this->memberInfo->limit_date && substr($this->memberInfo->limit_date,0,8) >= date("Ymd")) return new Object(-1,sprintf(Context::getLang('msg_user_limited'),zdate($this->memberInfo->limit_date,"Y-m-d")));
|
|
// Update the latest login time
|
|
$args->member_srl = $this->memberInfo->member_srl;
|
|
$output = executeQuery('member.updateLastLogin', $args);
|
|
// Call a trigger after successfully log-in (after)
|
|
$trigger_output = ModuleHandler::triggerCall('member.doLogin', 'after', $this->memberInfo);
|
|
if(!$trigger_output->toBool()) return $trigger_output;
|
|
// When user checked to use auto-login
|
|
if($keep_signed) {
|
|
// Key generate for auto login
|
|
$autologin_args->autologin_key = md5(strtolower($user_id).$this->memberInfo->password.$_SERVER['REMOTE_ADDR']);
|
|
$autologin_args->member_srl = $this->memberInfo->member_srl;
|
|
executeQuery('member.deleteAutologin', $autologin_args);
|
|
$autologin_output = executeQuery('member.insertAutologin', $autologin_args);
|
|
if($autologin_output->toBool()) setCookie('xeak',$autologin_args->autologin_key, time()+60*60*24*365, '/');
|
|
}
|
|
|
|
$this->setSessionInfo();
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Update or create session information
|
|
**/
|
|
function setSessionInfo() {
|
|
$oMemberModel = &getModel('member');
|
|
// If your information came through the current session information to extract information from the users
|
|
if(!$this->memberInfo && $_SESSION['member_srl'] && $oMemberModel->isLogged() ) {
|
|
$this->memberInfo = $oMemberModel->getMemberInfoByMemberSrl($_SESSION['member_srl']);
|
|
// If you do not destroy the session Profile
|
|
if($this->memberInfo->member_srl != $_SESSION['member_srl']) {
|
|
$this->destroySessionInfo();
|
|
return;
|
|
}
|
|
}
|
|
// Stop using the session id is destroyed
|
|
if($this->memberInfo->denied=='Y') {
|
|
$this->destroySessionInfo();
|
|
return;
|
|
}
|
|
// OpenID is a check (only for a determined identity types)
|
|
if(preg_match("/^([_0-9a-zA-Z]+)$/is", $this->memberInfo->user_id)) $this->memberInfo->is_openid = false;
|
|
else $this->memberInfo->is_openid = true;
|
|
// Log in for treatment sessions set
|
|
$_SESSION['is_logged'] = true;
|
|
$_SESSION['ipaddress'] = $_SERVER['REMOTE_ADDR'];
|
|
$_SESSION['member_srl'] = $this->memberInfo->member_srl;
|
|
$_SESSION['is_admin'] = '';
|
|
// Do not save your password in the session jiwojum;;
|
|
//unset($this->memberInfo->password);
|
|
// User Group Settings
|
|
/*
|
|
if($this->memberInfo->group_list) {
|
|
$group_srl_list = array_keys($this->memberInfo->group_list);
|
|
$_SESSION['group_srls'] = $group_srl_list;
|
|
// If the group is designated as an administrator administrator
|
|
$oMemberModel = &getModel('member');
|
|
$admin_group = $oMemberModel->getAdminGroup();
|
|
if($admin_group->group_srl && in_array($admin_group->group_srl, $group_srl_list)) $_SESSION['is_admin'] = 'Y';
|
|
}
|
|
*/
|
|
// Information stored in the session login user
|
|
Context::set('is_logged', true);
|
|
Context::set('logged_info', $this->memberInfo);
|
|
|
|
// Only the menu configuration of the user (such as an add-on to the menu can be changed)
|
|
$this->addMemberMenu( 'dispMemberInfo', 'cmd_view_member_info');
|
|
$this->addMemberMenu( 'dispMemberScrappedDocument', 'cmd_view_scrapped_document');
|
|
$this->addMemberMenu( 'dispMemberSavedDocument', 'cmd_view_saved_document');
|
|
$this->addMemberMenu( 'dispMemberOwnDocument', 'cmd_view_own_document');
|
|
}
|
|
|
|
/**
|
|
* @brief Logged method for providing a personalized menu
|
|
* Login information is used in the output widget, or personalized page
|
|
**/
|
|
function addMemberMenu($act, $str) {
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
$logged_info->menu_list[$act] = Context::getLang($str);
|
|
|
|
Context::set('logged_info', $logged_info);
|
|
}
|
|
|
|
/**
|
|
* @brief Nickname and click Log In to add a pop-up menu that appears when the method
|
|
**/
|
|
function addMemberPopupMenu($url, $str, $icon = '', $target = 'self') {
|
|
$member_popup_menu_list = Context::get('member_popup_menu_list');
|
|
if(!is_array($member_popup_menu_list)) $member_popup_menu_list = array();
|
|
|
|
$obj->url = $url;
|
|
$obj->str = $str;
|
|
$obj->icon = $icon;
|
|
$obj->target = $target;
|
|
$member_popup_menu_list[] = $obj;
|
|
|
|
Context::set('member_popup_menu_list', $member_popup_menu_list);
|
|
}
|
|
|
|
/**
|
|
* @brief Add users to the member table
|
|
**/
|
|
function insertMember(&$args, $password_is_hashed = false) {
|
|
// Call a trigger (before)
|
|
$output = ModuleHandler::triggerCall('member.insertMember', 'before', $args);
|
|
if(!$output->toBool()) return $output;
|
|
// Terms and Conditions portion of the information set up by members reaffirmed
|
|
$oModuleModel = &getModel('module');
|
|
$config = $oModuleModel->getModuleConfig('member');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
// If the date of the temporary restrictions limit further information on the date of
|
|
if($config->limit_day) $args->limit_date = date("YmdHis", time()+$config->limit_day*60*60*24);
|
|
// Enter the user's identity changed to lowercase
|
|
$args->user_id = strtolower($args->user_id);
|
|
// Control of essential parameters
|
|
if($args->allow_mailing!='Y') $args->allow_mailing = 'N';
|
|
if($args->denied!='Y') $args->denied = 'N';
|
|
$args->allow_message= 'Y';
|
|
|
|
if($logged_info->is_admin == 'Y') {
|
|
if($args->is_admin!='Y') $args->is_admin = 'N';
|
|
} else {
|
|
unset($args->is_admin);
|
|
}
|
|
|
|
list($args->email_id, $args->email_host) = explode('@', $args->email_address);
|
|
// Website, blog, checks the address
|
|
if($args->homepage && !preg_match("/^[a-z]+:\/\//i",$args->homepage)) $args->homepage = 'http://'.$args->homepage;
|
|
if($args->blog && !preg_match("/^[a-z]+:\/\//i",$args->blog)) $args->blog = 'http://'.$args->blog;
|
|
// Create a model object
|
|
$oMemberModel = &getModel('member');
|
|
// ID check is prohibited
|
|
if($oMemberModel->isDeniedID($args->user_id)) return new Object(-1,'denied_user_id');
|
|
// ID, nickname, email address of the redundancy check
|
|
$member_srl = $oMemberModel->getMemberSrlByUserID($args->user_id);
|
|
if($member_srl) return new Object(-1,'msg_exists_user_id');
|
|
|
|
$member_srl = $oMemberModel->getMemberSrlByNickName($args->nick_name);
|
|
if($member_srl) return new Object(-1,'msg_exists_nick_name');
|
|
|
|
$member_srl = $oMemberModel->getMemberSrlByEmailAddress($args->email_address);
|
|
if($member_srl) return new Object(-1,'msg_exists_email_address');
|
|
|
|
$oDB = &DB::getInstance();
|
|
$oDB->begin();
|
|
// Insert data into the DB
|
|
$args->member_srl = getNextSequence();
|
|
$args->list_order = -1 * $args->member_srl;
|
|
if($args->password && !$password_is_hashed) $args->password = md5($args->password);
|
|
elseif(!$args->password) unset($args->password);
|
|
|
|
$output = executeQuery('member.insertMember', $args);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
|
|
if(is_array($args->group_srl_list)) $group_srl_list = $args->group_srl_list;
|
|
else $group_srl_list = explode('|@|', $args->group_srl_list);
|
|
// If no value is entered the default group, the value of group registration
|
|
if(!$args->group_srl_list) {
|
|
$columnList = array('site_srl', 'group_srl');
|
|
$default_group = $oMemberModel->getDefaultGroup(0, $columnList);
|
|
// Add to the default group
|
|
$output = $this->addMemberToGroup($args->member_srl,$default_group->group_srl);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// If the value is the value of the group entered the group registration
|
|
} else {
|
|
for($i=0;$i<count($group_srl_list);$i++) {
|
|
$output = $this->addMemberToGroup($args->member_srl,$group_srl_list[$i]);
|
|
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
}
|
|
}
|
|
// When using email authentication mode (when you subscribed members denied a) certified mail sent
|
|
if ($args->denied == 'Y') {
|
|
// Insert data into the authentication DB
|
|
$auth_args->user_id = $args->user_id;
|
|
$auth_args->member_srl = $args->member_srl;
|
|
$auth_args->new_password = $args->password;
|
|
$auth_args->auth_key = md5(rand(0, 999999));
|
|
$auth_args->is_register = 'Y';
|
|
|
|
$output = executeQuery('member.insertAuthMail', $auth_args);
|
|
if (!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// Get content of the email to send a member
|
|
Context::set('auth_args', $auth_args);
|
|
Context::set('member_info', $args);
|
|
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
if(!$member_config->skin) $member_config->skin = "default";
|
|
if(!$member_config->colorset) $member_config->colorset = "white";
|
|
|
|
Context::set('member_config', $member_config);
|
|
|
|
$tpl_path = sprintf('%sskins/%s', $this->module_path, $member_config->skin);
|
|
if(!is_dir($tpl_path)) $tpl_path = sprintf('%sskins/%s', $this->module_path, 'default');
|
|
|
|
$auth_url = getFullUrl('','module','member','act','procMemberAuthAccount','member_srl',$args->member_srl, 'auth_key',$auth_args->auth_key);
|
|
Context::set('auth_url', $auth_url);
|
|
|
|
$oTemplate = &TemplateHandler::getInstance();
|
|
$content = $oTemplate->compile($tpl_path, 'confirm_member_account_mail');
|
|
// Get information of the Webmaster
|
|
$oModuleModel = &getModel('module');
|
|
$member_config = $oModuleModel->getModuleConfig('member');
|
|
// Send a mail
|
|
$oMail = new Mail();
|
|
$oMail->setTitle( Context::getLang('msg_confirm_account_title') );
|
|
$oMail->setContent($content);
|
|
$oMail->setSender( $member_config->webmaster_name?$member_config->webmaster_name:'webmaster', $member_config->webmaster_email);
|
|
$oMail->setReceiptor( $args->user_name, $args->email_address );
|
|
$oMail->send();
|
|
}
|
|
// Call a trigger (after)
|
|
if($output->toBool()) {
|
|
$trigger_output = ModuleHandler::triggerCall('member.insertMember', 'after', $args);
|
|
if(!$trigger_output->toBool()) {
|
|
$oDB->rollback();
|
|
return $trigger_output;
|
|
}
|
|
}
|
|
|
|
$oDB->commit(true);
|
|
|
|
$output->add('member_srl', $args->member_srl);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Modify member information
|
|
**/
|
|
function updateMember($args) {
|
|
// Call a trigger (before)
|
|
$output = ModuleHandler::triggerCall('member.updateMember', 'before', $args);
|
|
if(!$output->toBool()) return $output;
|
|
// Create a model object
|
|
$oMemberModel = &getModel('member');
|
|
|
|
$logged_info = Context::get('logged_info');
|
|
// Get what you want to modify the original information
|
|
if(!$this->memberInfo) $this->memberInfo = $oMemberModel->getMemberInfoByMemberSrl($args->member_srl);
|
|
if(!$args->user_id) $args->user_id = $this->memberInfo->user_id;
|
|
// Control of essential parameters
|
|
if($args->allow_mailing!='Y') $args->allow_mailing = 'N';
|
|
if($args->allow_message && !in_array($args->allow_message, array('Y','N','F'))) $args->allow_message = 'Y';
|
|
|
|
if($logged_info->is_admin == 'Y') {
|
|
if($args->denied!='Y') $args->denied = 'N';
|
|
if($args->is_admin!='Y' && $logged_info->member_srl != $args->member_srl) $args->is_admin = 'N';
|
|
} else {
|
|
unset($args->is_admin);
|
|
unset($args->denied);
|
|
}
|
|
|
|
list($args->email_id, $args->email_host) = explode('@', $args->email_address);
|
|
// Website, blog, checks the address
|
|
if($args->homepage && !preg_match("/^[a-z]+:\/\//is",$args->homepage)) $args->homepage = 'http://'.$args->homepage;
|
|
if($args->blog && !preg_match("/^[a-z]+:\/\//is",$args->blog)) $args->blog = 'http://'.$args->blog;
|
|
// ID, nickname, email address of the redundancy check
|
|
$member_srl = $oMemberModel->getMemberSrlByUserID($args->user_id);
|
|
if($member_srl&&$args->member_srl!=$member_srl) return new Object(-1,'msg_exists_user_id');
|
|
|
|
$member_srl = $oMemberModel->getMemberSrlByNickName($args->nick_name);
|
|
if($member_srl&&$args->member_srl!=$member_srl) return new Object(-1,'msg_exists_nick_name');
|
|
|
|
$member_srl = $oMemberModel->getMemberSrlByEmailAddress($args->email_address);
|
|
if($member_srl&&$args->member_srl!=$member_srl) return new Object(-1,'msg_exists_email_address');
|
|
|
|
$oDB = &DB::getInstance();
|
|
$oDB->begin();
|
|
// DB in the update
|
|
if($args->password) $args->password = md5($args->password);
|
|
else $args->password = $this->memberInfo->password;
|
|
if(!$args->user_name) $args->user_name = $this->memberInfo->user_name;
|
|
|
|
if(!$args->description) $args->description = '';
|
|
$output = executeQuery('member.updateMember', $args);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
if(is_array($args->group_srl_list)) $group_srl_list = $args->group_srl_list;
|
|
else $group_srl_list = explode('|@|', $args->group_srl_list);
|
|
// If the group information, group information changes
|
|
if(count($group_srl_list) > 0) {
|
|
$args->site_srl = 0;
|
|
// One of its members to delete all the group
|
|
$output = executeQuery('member.deleteMemberGroupMember', $args);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// Enter one of the loop a
|
|
for($i=0;$i<count($group_srl_list);$i++) {
|
|
$output = $this->addMemberToGroup($args->member_srl,$group_srl_list[$i]);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
}
|
|
}
|
|
// Call a trigger (after)
|
|
if($output->toBool()) {
|
|
$trigger_output = ModuleHandler::triggerCall('member.updateMember', 'after', $args);
|
|
if(!$trigger_output->toBool()) {
|
|
$oDB->rollback();
|
|
return $trigger_output;
|
|
}
|
|
}
|
|
|
|
$oDB->commit();
|
|
// Save Session
|
|
if(!$this->memberInfo) $this->memberInfo = $oMemberModel->getMemberInfoByMemberSrl($args->member_srl);
|
|
//remove from cache
|
|
$oCacheHandler = &CacheHandler::getInstance('object');
|
|
if($oCacheHandler->isSupport()){
|
|
$cache_key = 'object:'.$args->member_srl;
|
|
$oCacheHandler->delete($cache_key);
|
|
}
|
|
$logged_info = Context::get('logged_info');
|
|
|
|
$output->add('member_srl', $args->member_srl);
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Modify member password
|
|
**/
|
|
function updateMemberPassword($args) {
|
|
$output = executeQuery('member.updateChangePasswordDate', $args);
|
|
//remove from cache
|
|
$oCacheHandler = &CacheHandler::getInstance('object');
|
|
if($oCacheHandler->isSupport()){
|
|
$cache_key = 'object:'.$args->member_srl;
|
|
$oCacheHandler->delete($cache_key);
|
|
}
|
|
$args->password = md5($args->password);
|
|
return executeQuery('member.updateMemberPassword', $args);
|
|
}
|
|
|
|
/**
|
|
* @brief Delete User
|
|
**/
|
|
function deleteMember($member_srl) {
|
|
// Call a trigger (before)
|
|
$trigger_obj->member_srl = $member_srl;
|
|
$output = ModuleHandler::triggerCall('member.deleteMember', 'before', $trigger_obj);
|
|
if(!$output->toBool()) return $output;
|
|
// Create a model object
|
|
$oMemberModel = &getModel('member');
|
|
// Bringing the user's information
|
|
if(!$this->memberInfo) {
|
|
$columnList = array('member_srl', 'is_admin');
|
|
$this->memberInfo = $oMemberModel->getMemberInfoByMemberSrl($member_srl, 0, $columnList);
|
|
}
|
|
if(!$this->memberInfo) return new Object(-1, 'msg_not_exists_member');
|
|
// If managers can not be deleted
|
|
if($this->memberInfo->is_admin == 'Y') return new Object(-1, 'msg_cannot_delete_admin');
|
|
|
|
$oDB = &DB::getInstance();
|
|
$oDB->begin();
|
|
|
|
$args->member_srl = $member_srl;
|
|
// Delete the entries in member_auth_mail
|
|
$output = executeQuery('member.deleteAuthMail', $args);
|
|
if (!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// Delete the entries in member_openid
|
|
$output = executeQuery('member.deleteMemberOpenIDByMemberSrl', $ags);
|
|
// TODO: If the table is not an upgrade may fail.
|
|
/*
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
*/
|
|
// Delete the entries in member_group_member
|
|
$output = executeQuery('member.deleteMemberGroupMember', $args);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// member removed from the table
|
|
$output = executeQuery('member.deleteMember', $args);
|
|
if(!$output->toBool()) {
|
|
$oDB->rollback();
|
|
return $output;
|
|
}
|
|
// Call a trigger (after)
|
|
if($output->toBool()) {
|
|
$trigger_output = ModuleHandler::triggerCall('member.deleteMember', 'after', $trigger_obj);
|
|
if(!$trigger_output->toBool()) {
|
|
$oDB->rollback();
|
|
return $trigger_output;
|
|
}
|
|
}
|
|
|
|
$oDB->commit();
|
|
// Name, image, image, mark, sign, delete
|
|
$this->procMemberDeleteImageName();
|
|
$this->procMemberDeleteImageMark();
|
|
$this->delSignature($member_srl);
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* @brief Destroy all session information
|
|
**/
|
|
function destroySessionInfo() {
|
|
if(!$_SESSION || !is_array($_SESSION)) return;
|
|
foreach($_SESSION as $key => $val) {
|
|
$_SESSION[$key] = '';
|
|
}
|
|
session_destroy();
|
|
setcookie(session_name(), '', time()-42000, '/');
|
|
setcookie('sso','',time()-42000, '/');
|
|
|
|
if($_COOKIE['xeak']) {
|
|
$args->autologin_key = $_COOKIE['xeak'];
|
|
executeQuery('member.deleteAutologin', $args);
|
|
}
|
|
}
|
|
}
|
|
?>
|