diff --git a/modules/member/conf/module.xml b/modules/member/conf/module.xml index a6aabadb5..5e179fc0a 100644 --- a/modules/member/conf/module.xml +++ b/modules/member/conf/module.xml @@ -118,6 +118,7 @@ + diff --git a/modules/member/lang/en.php b/modules/member/lang/en.php index 24eceb38c..71dd2ac37 100644 --- a/modules/member/lang/en.php +++ b/modules/member/lang/en.php @@ -407,3 +407,6 @@ $lang->member_unauthenticated = 'Unauthenticated'; $lang->member_number = 'Member identification number'; $lang->msg_change_after_click = 'Change after clicking link below'; $lang->msg_password_changed = 'Your password has been changed.'; + +$lang->cmd_login_as = 'Login as this member'; +$lang->msg_confirm_login_as = 'Are you sure you want to login as this member? Your current admin session will be terminated.'; diff --git a/modules/member/lang/ko.php b/modules/member/lang/ko.php index dee729b3b..c3f776d8d 100644 --- a/modules/member/lang/ko.php +++ b/modules/member/lang/ko.php @@ -411,3 +411,6 @@ $lang->member_unauthenticated = '미인증'; $lang->member_number = '회원 번호'; $lang->msg_change_after_click = '아래 링크 클릭 후 변경 가능'; $lang->msg_password_changed = '비밀번호가 변경되었습니다.'; + +$lang->cmd_login_as = '해당 회원으로 로그인'; +$lang->msg_confirm_login_as = '해당 회원으로 로그인하시겠습니까? 현재 관리자 세션이 종료됩니다.'; diff --git a/modules/member/member.admin.controller.php b/modules/member/member.admin.controller.php index 1bc72fe41..54fe90c24 100644 --- a/modules/member/member.admin.controller.php +++ b/modules/member/member.admin.controller.php @@ -1802,6 +1802,47 @@ class MemberAdminController extends Member return new BaseObject(); } + + /** + * Login as a specific member (admin only) + * @return void|BaseObject + */ + function procMemberAdminLoginAs() + { + // Check admin permission and CSRF token + $logged_info = Context::get('logged_info'); + if(!$logged_info || $logged_info->is_admin !== 'Y' || !Rhymix\Framework\Security::checkCSRF()) + { + throw new Rhymix\Framework\Exceptions\InvalidRequest; + } + + $member_srl = Context::get('member_srl'); + if(!$member_srl) + { + throw new Rhymix\Framework\Exceptions\InvalidRequest; + } + + // Get target member info + $member_info = MemberModel::getMemberInfoByMemberSrl($member_srl); + if(!$member_info || !$member_info->member_srl) + { + throw new Rhymix\Framework\Exceptions\InvalidRequest; + } + + // Do not allow login as the super admin (member_srl = 4) + if(intval($member_info->member_srl) === 4) + { + throw new Rhymix\Framework\Exceptions\NotPermitted; + } + + // Perform login as the target member + // Session::login() sets the basic session variables, and setSessionInfo() populates Context with member details + Rhymix\Framework\Session::login($member_info->member_srl); + $oMemberController = getController('member'); + $oMemberController->setSessionInfo(); + + $this->setRedirectUrl(getNotEncodedUrl('')); + } } /* End of file member.admin.controller.php */ /* Location: ./modules/member/member.admin.controller.php */ diff --git a/modules/member/tpl/member_list.html b/modules/member/tpl/member_list.html index 09ce416ad..bb3f568d3 100644 --- a/modules/member/tpl/member_list.html +++ b/modules/member/tpl/member_list.html @@ -97,7 +97,12 @@ {zdate($member_info['last_login'], 'Y-m-d')} {$member_info['group_list']}  - {$lang->inquiry}/{$lang->cmd_modify} + + {$lang->inquiry}/{$lang->cmd_modify} + + + + {@$used_values = ''} {@$used_values .= "\t".$member_info[$name]} @@ -245,5 +250,19 @@ jQuery(function($){ } } }); + // Login as member + $('a._login_as').click(function(e){ + e.preventDefault(); + if(!confirm('{$lang->msg_confirm_login_as}')) return; + var member_srl = $(this).data('member-srl'); + var $form = $('#loginAsForm'); + $form.find('input[name=member_srl]').val(member_srl); + $form.submit(); + }); }); +