misuzu/public-legacy/members.php

113 lines
2.9 KiB
PHP
Raw Normal View History

2022-09-13 13:14:49 +00:00
<?php
namespace Misuzu;
use RuntimeException;
2022-09-13 13:14:49 +00:00
2024-12-02 02:28:08 +00:00
if(!isset($msz) || !($msz instanceof \Misuzu\MisuzuContext))
die('Script must be called through the Misuzu route dispatcher.');
if(!$msz->authInfo->isLoggedIn)
Template::throwError(403);
// TODO: restore forum-topics and forum-posts orderings
2023-07-27 23:26:05 +00:00
$roleId = filter_has_var(INPUT_GET, 'r') ? (string)filter_input(INPUT_GET, 'r') : null;
$orderBy = strtolower((string)filter_input(INPUT_GET, 'ss'));
$orderDir = strtolower((string)filter_input(INPUT_GET, 'sd'));
2022-09-13 13:14:49 +00:00
$orderDirs = [
'asc' => 'In Order',
'desc' => 'Reverse Order',
2022-09-13 13:14:49 +00:00
];
$defaultOrder = 'active';
2022-09-13 13:14:49 +00:00
$orderFields = [
'id' => [
'title' => 'User ID',
],
'name' => [
'title' => 'Username',
],
'country' => [
'title' => 'Country',
],
'created' => [
2022-09-13 13:14:49 +00:00
'title' => 'Registration Date',
],
'active' => [
2022-09-13 13:14:49 +00:00
'title' => 'Last Online',
],
'registered' => [
'alt' => 'created',
'title' => 'Registration Date',
2022-09-13 13:14:49 +00:00
],
'last-online' => [
'alt' => 'active',
'title' => 'Last Online',
2022-09-13 13:14:49 +00:00
],
];
if(empty($orderBy)) {
$orderBy = $defaultOrder;
} elseif(!array_key_exists($orderBy, $orderFields)) {
Template::throwError(400);
2022-09-13 13:14:49 +00:00
}
if(array_key_exists('alt', $orderFields[$orderBy]))
$orderBy = $orderFields[$orderBy]['alt'];
2022-09-13 13:14:49 +00:00
if(empty($orderDir)) {
$orderDir = 'asc';
2022-09-13 13:14:49 +00:00
} elseif(!array_key_exists($orderDir, $orderDirs)) {
Template::throwError(400);
2022-09-13 13:14:49 +00:00
}
2023-07-27 23:26:05 +00:00
if($roleId === null) {
$roleInfo = $msz->usersCtx->roles->getDefaultRole();
2023-07-27 23:26:05 +00:00
} else {
try {
2024-12-02 00:34:00 +00:00
$roleInfo = $msz->usersCtx->roles->getRole($roleId);
2023-07-27 23:26:05 +00:00
} catch(RuntimeException $ex) {
Template::throwError(404);
2023-07-27 23:26:05 +00:00
}
2022-09-13 13:14:49 +00:00
}
$canManageUsers = $msz->authInfo->getPerms('user')->check(Perm::U_USERS_MANAGE);
$deleted = $canManageUsers ? null : false;
2022-09-13 13:14:49 +00:00
$rolesAll = $msz->usersCtx->roles->getRoles(hidden: false);
2024-12-19 01:22:26 +00:00
$pagination = Pagination::fromInput($msz->usersCtx->users->countUsers(roleInfo: $roleInfo, deleted: $deleted), 15);
$userList = [];
$userInfos = $msz->usersCtx->users->getUsers(
roleInfo: $roleInfo,
deleted: $deleted,
orderBy: $orderBy,
reverseOrder: $orderDir !== 'asc',
pagination: $pagination,
);
foreach($userInfos as $userInfo)
$userList[] = [
'info' => $userInfo,
'colour' => $msz->usersCtx->getUserColour($userInfo),
'ftopics' => $msz->forumCtx->countTotalUserTopics($userInfo),
'fposts' => $msz->forumCtx->countTotalUserPosts($userInfo),
];
2022-09-13 13:14:49 +00:00
if(empty($userList))
2022-09-13 13:14:49 +00:00
http_response_code(404);
Template::render('user.listing', [
2023-07-27 23:26:05 +00:00
'roles' => $rolesAll,
2022-09-13 13:14:49 +00:00
'role' => $roleInfo,
'users' => $userList,
2022-09-13 13:14:49 +00:00
'order_fields' => $orderFields,
'order_directions' => $orderDirs,
'order_field' => $orderBy,
'order_direction' => $orderDir,
'order_default' => $defaultOrder,
'can_manage_users' => $canManageUsers,
'users_pagination' => $pagination,
]);