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}
+
+ {$lang->cmd_login_as}
+
+ |
{@$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();
+ });
});
+