-
Notifications
You must be signed in to change notification settings - Fork 161
/
member.php
90 lines (70 loc) · 3.48 KB
/
member.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<?php
/**
* Copyright (c) UNA, Inc - https://una.io
* MIT License - https://opensource.org/licenses/MIT
*
* @defgroup UnaCore UNA Core
* @{
*/
require_once('./inc/header.inc.php');
require_once(BX_DIRECTORY_PATH_INC . "design.inc.php");
bx_import('BxDolLanguages');
if (isset($_POST['ID'])) { // login form is submitted
$oForm = BxDolForm::getObjectInstance('sys_login', 'sys_login');
bx_alert('account', 'before_login', 0, 0, array('form' => $oForm));
$oForm->initChecker();
$oForm->setRole(bx_get('role'));
$bLoginSuccess = $oForm->isSubmittedAndValid();
$bAjxMode = (isset($_SERVER['HTTP_X_REQUESTED_WITH']) && $_SERVER['HTTP_X_REQUESTED_WITH'] == 'XMLHttpRequest') ? true : false;
if ($bAjxMode) {
if ($bLoginSuccess) {
$s = 'OK';
$oAccount = BxDolAccount::getInstance(trim($oForm->getCleanValue('ID')));
$aAccount = bx_login($oAccount->id(), $oForm->getRememberMe());
}
else {
$s = $oForm->getLoginError();
}
if (isset($_SERVER['HTTP_ACCEPT'])) {
if (false !== strpos($_SERVER['HTTP_ACCEPT'], 'application/json') || false !== strpos($_SERVER['HTTP_ACCEPT'], 'text/javascript')) {
header('Content-type: application/json; charset=utf-8');
echo json_encode(['res' => $s, 'form' => $oForm->getCode()]);
exit;
}
}
header('Content-type: text/html; charset=utf-8');
echo $s;
exit;
}
elseif ($bLoginSuccess) {
$sId = trim($oForm->getCleanValue('ID'));
$oAccount = BxDolAccount::getInstance($sId);
$aAccountInfo = $oAccount->getInfo();
if((getParam('sys_account_activation_2fa_enable') == 'on' && getParam('sys_sms_default') != '')
&& (getParam('sys_account_activation_2fa_lifetime') == 0 || (time() - $aAccountInfo['logged'] > getParam('sys_account_activation_2fa_lifetime')))) {
$oSession = BxDolSession::getInstance();
$oSession->setValue(BX_ACCOUNT_SESSION_KEY_FOR_2FA_LOGIN_ACCOUNT_ID, trim($oForm->getCleanValue('ID')));
$oSession->setValue(BX_ACCOUNT_SESSION_KEY_FOR_2FA_LOGIN_IS_REMEMBER, $oForm->getRememberMe());
header('Location: ' . BX_DOL_URL_ROOT . BxDolPermalinks::getInstance()->permalink('page.php?i=login-step2'));
}
else{
$aAccount = bx_login($oAccount->id(), $oForm->getRememberMe());
$sUrlRelocate = $oForm->getCleanValue('relocate');
if (!$sUrlRelocate || 0 !== strncmp($sUrlRelocate, BX_DOL_URL_ROOT, strlen(BX_DOL_URL_ROOT)))
$sUrlRelocate = BX_DOL_ROLE_ADMIN == $oForm->getRole() ? BX_DOL_URL_STUDIO . 'launcher.php' : BX_DOL_URL_ROOT . 'member.php';
bx_alert('account', 'login_after', $oAccount->id(), false, array(
'account' => $aAccount,
'url_relocate' => &$sUrlRelocate
));
BxDolTemplate::getInstance()->setPageNameIndex (BX_PAGE_TRANSITION);
BxDolTemplate::getInstance()->setPageHeader (_t('_Please Wait'));
BxDolTemplate::getInstance()->setPageContent ('page_main_code', MsgBox(_t('_Please Wait')));
BxDolTemplate::getInstance()->setPageContent ('url_relocate', bx_html_attribute($sUrlRelocate, BX_ESCAPE_STR_QUOTE));
BxDolTemplate::getInstance()->getPageCode();
exit;
}
}
}
bx_require_authentication();
header('Location: ' . BX_DOL_URL_ROOT);
/** @} */