* @license GNU General Public License, version 2 (GPL-2.0)
*
* For full copyright and license information, please see
* the docs/CREDITS.txt file.
*
*/
/**
* @ignore
*/
define('IN_PHPBB', true);
$phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './';
$phpEx = substr(strrchr(__FILE__, '.'), 1);
require($phpbb_root_path . 'common.' . $phpEx);
require($phpbb_root_path . 'includes/functions_user.' . $phpEx);
require($phpbb_root_path . 'includes/functions_module.' . $phpEx);
// Basic parameter data
$id = request_var('i', '');
$mode = request_var('mode', '');
if (in_array($mode, array('login', 'login_link', 'logout', 'confirm', 'sendpassword', 'activate')))
{
define('IN_LOGIN', true);
}
// Start session management
$user->session_begin();
$auth->acl($user->data);
$user->setup('ucp');
// Setting a variable to let the style designer know where he is...
$template->assign_var('S_IN_UCP', true);
$module = new p_master();
$default = false;
// Basic "global" modes
switch ($mode)
{
case 'activate':
$module->load('ucp', 'activate');
$module->display($user->lang['UCP_ACTIVATE']);
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
break;
case 'resend_act':
$module->load('ucp', 'resend');
$module->display($user->lang['UCP_RESEND']);
break;
case 'sendpassword':
$module->load('ucp', 'remind');
$module->display($user->lang['UCP_REMIND']);
break;
case 'register':
if ($user->data['is_registered'] || isset($_REQUEST['not_agreed']))
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
$module->load('ucp', 'register');
$module->display($user->lang['REGISTER']);
break;
case 'confirm':
$module->load('ucp', 'confirm');
break;
case 'login':
if ($user->data['is_registered'])
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
login_box(request_var('redirect', "index.$phpEx"));
break;
case 'login_link':
if ($user->data['is_registered'])
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
$module->load('ucp', 'login_link');
$module->display($user->lang['UCP_LOGIN_LINK']);
break;
case 'logout':
if ($user->data['user_id'] != ANONYMOUS && $request->is_set('sid') && $request->variable('sid', '') === $user->session_id)
{
$user->session_kill();
}
else if ($user->data['user_id'] != ANONYMOUS)
{
meta_refresh(3, append_sid("{$phpbb_root_path}index.$phpEx"));
$message = $user->lang['LOGOUT_FAILED'] . '
' . sprintf($user->lang['RETURN_INDEX'], '', ' ');
trigger_error($message);
}
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
break;
case 'terms':
case 'privacy':
$message = ($mode == 'terms') ? 'TERMS_OF_USE_CONTENT' : 'PRIVACY_POLICY';
$title = ($mode == 'terms') ? 'TERMS_USE' : 'PRIVACY';
if (empty($user->lang[$message]))
{
if ($user->data['is_registered'])
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
login_box();
}
$template->set_filenames(array(
'body' => 'ucp_agreement.html')
);
// Disable online list
page_header($user->lang[$title]);
$template->assign_vars(array(
'S_AGREEMENT' => true,
'AGREEMENT_TITLE' => $user->lang[$title],
'AGREEMENT_TEXT' => sprintf($user->lang[$message], $config['sitename'], generate_board_url()),
'U_BACK' => append_sid("{$phpbb_root_path}ucp.$phpEx", 'mode=login'),
'L_BACK' => $user->lang['BACK_TO_LOGIN'],
));
page_footer();
break;
case 'delete_cookies':
// Delete Cookies with dynamic names (do NOT delete poll cookies)
if (confirm_box(true))
{
$set_time = time() - 31536000;
foreach ($request->variable_names(\phpbb\request\request_interface::COOKIE) as $cookie_name)
{
$cookie_data = $request->variable($cookie_name, '', true, \phpbb\request\request_interface::COOKIE);
// Only delete board cookies, no other ones...
if (strpos($cookie_name, $config['cookie_name'] . '_') !== 0)
{
continue;
}
$cookie_name = str_replace($config['cookie_name'] . '_', '', $cookie_name);
/**
* Event to save custom cookies from deletion
*
* @event core.ucp_delete_cookies
* @var string cookie_name Cookie name to checking
* @var bool retain_cookie Do we retain our cookie or not, true if retain
* @since 3.1.3-RC1
*/
$retain_cookie = false;
$vars = array('cookie_name', 'retain_cookie');
extract($phpbb_dispatcher->trigger_event('core.ucp_delete_cookies', compact($vars)));
if ($retain_cookie)
{
continue;
}
// Polls are stored as {cookie_name}_poll_{topic_id}, cookie_name_ got removed, therefore checking for poll_
if (strpos($cookie_name, 'poll_') !== 0)
{
$user->set_cookie($cookie_name, '', $set_time);
}
}
$user->set_cookie('track', '', $set_time);
$user->set_cookie('u', '', $set_time);
$user->set_cookie('k', '', $set_time);
$user->set_cookie('sid', '', $set_time);
// We destroy the session here, the user will be logged out nevertheless
$user->session_kill();
$user->session_begin();
meta_refresh(3, append_sid("{$phpbb_root_path}index.$phpEx"));
$message = $user->lang['COOKIES_DELETED'] . '
' . sprintf($user->lang['RETURN_INDEX'], '', '');
trigger_error($message);
}
else
{
confirm_box(false, 'DELETE_COOKIES', '');
}
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
break;
case 'switch_perm':
$user_id = request_var('u', 0);
$sql = 'SELECT *
FROM ' . USERS_TABLE . '
WHERE user_id = ' . (int) $user_id;
$result = $db->sql_query($sql);
$user_row = $db->sql_fetchrow($result);
$db->sql_freeresult($result);
if (!$auth->acl_get('a_switchperm') || !$user_row || $user_id == $user->data['user_id'] || !check_link_hash(request_var('hash', ''), 'switchperm'))
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
include($phpbb_root_path . 'includes/acp/auth.' . $phpEx);
$auth_admin = new auth_admin();
if (!$auth_admin->ghost_permissions($user_id, $user->data['user_id']))
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
add_log('admin', 'LOG_ACL_TRANSFER_PERMISSIONS', $user_row['username']);
$message = sprintf($user->lang['PERMISSIONS_TRANSFERRED'], $user_row['username']) . '
' . sprintf($user->lang['RETURN_INDEX'], '', '');
/**
* Event to run code after permissions are switched
*
* @event core.ucp_switch_permissions
* @var int user_id User ID to switch permission to
* @var array user_row User data
* @var string message Success message
* @since 3.1.11-RC1
*/
$vars = array('user_id', 'user_row', 'message');
extract($phpbb_dispatcher->trigger_event('core.ucp_switch_permissions', compact($vars)));
trigger_error($message);
break;
case 'restore_perm':
if (!$user->data['user_perm_from'] || !$auth->acl_get('a_switchperm'))
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
$auth->acl_cache($user->data);
$sql = 'SELECT username
FROM ' . USERS_TABLE . '
WHERE user_id = ' . $user->data['user_perm_from'];
$result = $db->sql_query($sql);
$username = $db->sql_fetchfield('username');
$db->sql_freeresult($result);
add_log('admin', 'LOG_ACL_RESTORE_PERMISSIONS', $username);
$message = $user->lang['PERMISSIONS_RESTORED'] . '
' . sprintf($user->lang['RETURN_INDEX'], '', '');
/**
* Event to run code after permissions are restored
*
* @event core.ucp_restore_permissions
* @var string username User name
* @var string message Success message
* @since 3.1.11-RC1
*/
$vars = array('username', 'message');
extract($phpbb_dispatcher->trigger_event('core.ucp_restore_permissions', compact($vars)));
trigger_error($message);
break;
default:
$default = true;
break;
}
// We use this approach because it does not impose large code changes
if (!$default)
{
return true;
}
// Only registered users can go beyond this point
if (!$user->data['is_registered'])
{
if ($user->data['is_bot'])
{
redirect(append_sid("{$phpbb_root_path}index.$phpEx"));
}
if ($id == 'pm' && $mode == 'view' && isset($_GET['p']))
{
$redirect_url = append_sid("{$phpbb_root_path}ucp.$phpEx?i=pm&p=" . request_var('p', 0));
login_box($redirect_url, $user->lang['LOGIN_EXPLAIN_UCP']);
}
login_box('', $user->lang['LOGIN_EXPLAIN_UCP']);
}
// Instantiate module system and generate list of available modules
$module->list_modules('ucp');
// Check if the zebra module is set
if ($module->is_active('zebra', 'friends'))
{
// Output listing of friends online
$update_time = $config['load_online_time'] * 60;
$sql_ary = array(
'SELECT' => 'u.user_id, u.username, u.username_clean, u.user_colour, MAX(s.session_time) as online_time, MIN(s.session_viewonline) AS viewonline',
'FROM' => array(
USERS_TABLE => 'u',
ZEBRA_TABLE => 'z',
),
'LEFT_JOIN' => array(
array(
'FROM' => array(SESSIONS_TABLE => 's'),
'ON' => 's.session_user_id = z.zebra_id',
),
),
'WHERE' => 'z.user_id = ' . $user->data['user_id'] . '
AND z.friend = 1
AND u.user_id = z.zebra_id',
'GROUP_BY' => 'z.zebra_id, u.user_id, u.username_clean, u.user_colour, u.username',
'ORDER_BY' => 'u.username_clean ASC',
);
$sql = $db->sql_build_query('SELECT_DISTINCT', $sql_ary);
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
$which = (time() - $update_time < $row['online_time'] && ($row['viewonline'] || $auth->acl_get('u_viewonline'))) ? 'online' : 'offline';
$template->assign_block_vars("friends_{$which}", array(
'USER_ID' => $row['user_id'],
'U_PROFILE' => get_username_string('profile', $row['user_id'], $row['username'], $row['user_colour']),
'USER_COLOUR' => get_username_string('colour', $row['user_id'], $row['username'], $row['user_colour']),
'USERNAME' => get_username_string('username', $row['user_id'], $row['username'], $row['user_colour']),
'USERNAME_FULL' => get_username_string('full', $row['user_id'], $row['username'], $row['user_colour']))
);
}
$db->sql_freeresult($result);
}
// Do not display subscribed topics/forums if not allowed
if (!$config['allow_topic_notify'] && !$config['allow_forum_notify'])
{
$module->set_display('main', 'subscribed', false);
}
/**
* Use this event to enable and disable additional UCP modules
*
* @event core.ucp_display_module_before
* @var p_master module Object holding all modules and their status
* @var mixed id Active module category (can be the int or string)
* @var string mode Active module
* @since 3.1.0-a1
*/
$vars = array('module', 'id', 'mode');
extract($phpbb_dispatcher->trigger_event('core.ucp_display_module_before', compact($vars)));
// Select the active module
$module->set_active($id, $mode);
// Load and execute the relevant module
$module->load_active();
// Assign data to the template engine for the list of modules
$module->assign_tpl_vars(append_sid("{$phpbb_root_path}ucp.$phpEx"));
// Generate the page, do not display/query online list
$module->display($module->get_page_title());
:Wk)FtD1uhZ-I)80rG-c,mvvNڮ
_z WS4kv~~<SѬ*]w桫L2\yNEVVӉvL`xsU$8>جJIi0]*m..變U> 1}!^O\v1$V)=Pb_ |dǒ-f!'!ӄ
۲"Qȸ6Or讛:5QF!1]%.".-qNl`|*iOSfH\CWL7N'&\뿢HN8k-%X'Ҭ@S/D67/aˀ 1KJ9eLQ}ߊSPIe{4}^r|^~#HlHz!R،"oh9u;FmӅQK
&?L^X&c|~ԕ
tKh{hۭF'BS`\X}~҅x"ۢ_eE^%Ҥi.15@Ťo_] r/=
:;C0)=UސCTvМe\3gşc;235R=6,;`ܯ\R=@"h3yށGh#<M5hXENB93*7Z1 0$2\%> 7':(6 {.]؝wJ=RHv1 07F̗c>Nܭ9,}g\c+nh zeZ?( =9KEP8l-Upy{##!SIx}bٽj(ϽXMȣ>X+hT&m>\\KlH&x|Aݲg
Z.t{s#ŗJp/*T ÆT}X)Fy![nӷ>wϮIc+}; ψ{|:SZB1N}xa=.a\;QԸcft*WSǢ䡤\,4]dC2h~q8
;[g,Ѓ VP;H6ԡr) =ܼm=Q^ԖEXrh3ӏ**](Ε<(g$N
wܦ67i;q#nEF~xbæ=NҤҭ:/gJ+TEAۏ0%1TC.}r(:r<BK-\5
,^uH>,!Fk4Vrs8#oַ
۴"3%^hm{1h3ĎAJDּaTS/ Y҉2#WmnQsy
c
NpGRk'^ig
5%Gm+6e_%KAhl}I)<eeQЄ[$o*\Lag
[A-$6R=GK< -%lW/A9Eo<9pMG]'ߠMHd4,"'nmfR+}-s&.\讟"ᡕsӮf
i5hVpzފ-Go~ߞ}g\Oz(yn5 WF2nLsܼnXx%d"W]2~r)_wl
YHm=y8(A#rw[VDf%[V]wa~"ȥoj]|z$Ŗnc8;AKj{;:xm1A]TY{Teteb"Bt:~j1Y(ED`IZwbK098^~SddxP x#Gj!1A$}T}gb^sOE1U3ks!&tw> EsTbԤ<u&G*eGl;9* J[ @UZ,LpN>WcBdؠ~nd4=V7o涢p?bk3+#}p QS\;A)b'dsJ1?
Ls hz^T&ً9C^V90u
7td˃}#O|R]43:g.u7۴)
G,hn&wr徧
̀DZZlb͊)֙Gw}@Q ?N3`'W-SԭjŸ࣋lNh*`%+sSɩiJ.T[q2Υs?w|xN1;H-<I0A_zV#L·)T?q'Fk_mO-1mA.ǐ%Lbu2jԵ7,{ 㲨`duSnE=v`Nìkoz8 %҆e>l8f=OK ~=1U͐";0-ǻZpߺ_T3'6JaSdCC;UMgI}
ĿE)Qguf~$gLW= N_z[pH we :
H\'(=}BU\?DZVnhXc2Τe\5/6(X
&n66NwL.f[_Lw@^%z$B&JקExիS6,/ick)yw}؊&:vE҇YXK cj)qSca$ah|!>2k&sitǥůy70z&@Kcv
QbEe*G:(-,+O^c.2,HHI@exT`DvJe߹pe\'^b)i&!MLڛ823MHh҂%H+G
: `6a>tuo}x%'J;)ormR\]-Y]NUʧRDd:ՃDRLWhC0HO*@vr3[Wx'0[ v,$} U4śՙJ9eQ[Gz,'}{"7{E5/$'ҀDEPRV3&S[c]ϫ:~>L)C oj{? uR~șYjE9 evJ:5 Nj$n:*mw`,Dfp5䫀ET0gkWEVgi~x
ΚiH-*rMcccA 帴0#ah^M8LW*gFKyfw{s|G?EAщi'Ǩ'1\m5N9"3anu1+
HHjL85f`4$ _Q&?z?ץiٯb.P gŮƮzϹՓ&gd-y:Ku2EzBGi"nP'ϼ~#
& D7A秔5\iEVAb;w T} CIwjDHz٩ok /`y {.(aotOC{=mXDE;PLr=,7f^pgN0_Ueh KxOѮͬkGpm
<mk!/(`3
&U,QP9yzB~w0zPCd<0T.)"i[8Z哴Yؿ."JTbP%%
r4)Ì6HLT_"|ԵS)-\bőţ~'4͚v4neX9@rٴd
ODu`P@+tↅ伒8j7Ԟ9{%A#0K 2 {3
ʎvf<)!1
FY)5VޭVPG¼<17[}FzBxvDLoXK&h'h[l
n7# Ñ(lŲ48ƙt[F;ռL_Xm"8@4{
gT]q=RdR|UN{/w8o2E;u2]hۻ"U]f`V|\H"[yKbԹ5c2yRY\M ó$\/fK+hxi˚ _SPԙ;rp8hbG>makW[FtVG<#Nځ:K(\gW^XHR83/A"ބrbj/*Lwȷ؆vk@e@gߡ6E`v #md_7c.Gq0ay9:G_#;k}bO_+M>;6'DAx*lSme9