oddluck f7590e79da Add 'TriviaTime/' from commit 'ae216897cd9c45259853c3f84eae826f344482aa'
git-subtree-dir: TriviaTime
git-subtree-mainline: 3551587ecdefc75e34b8b2a87d91a466bdf4c764
git-subtree-split: ae216897cd9c45259853c3f84eae826f344482aa
2019-02-14 13:32:21 -05:00

187 lines
6.4 KiB
PHP

<?php
class UserController extends Controller
{
public function searchAction() {
$container = $this->container;
$storage = $container->getStorage();
$username = '';
$usernameCanonical = '';
if(array_key_exists('username', $_GET)) {
// Convert username to lowercase in irc
$username = $_GET['username'];
$ircLowerSymbols = array("\\"=>"|", "["=>"{", "]"=>"}", "~"=>"^");
$usernameCanonical = strtr($username, $ircLowerSymbols);
$usernameCanonical = strtolower($usernameCanonical);
}
if(array_key_exists('page', $_GET)) {
$page = $_GET['page'];
}
if(!isset($page)) {
$page = 1;
}
if($page < 1) {
$page = 1;
}
$maxResults = 10;
$usersCount = 0;
$users = array();
$errors = array();
try {
$users = $storage->getUserLikeUsernameCanonical($usernameCanonical, $page, $maxResults);
$usersCount = $storage->getCountUserLikeUsernameCanonical($usernameCanonical);
} catch(StorageSchemaException $e) {
$errors[] = "Error: Database schema is not queryable";
} catch(StorageConnectionException $e) {
$errors[] = "Error: Database is not available";
}
$storage->close();
// Redirect to profile if only 1 result found
if(count($users) == 1) {
$container->redirect($container->router->generate('profile', array("username"=>$users[0]['username'])));
}
$values = array();
$values['username'] = $username;
$values['usernameCanonical'] = $usernameCanonical;
$values['page'] = $page;
$values['maxResults'] = $maxResults;
$values['usersCount'] = $usersCount;
$values['users'] = $users;
$values['errors'] = $errors;
$container->setTitle('Players');
$container->render('user.html.php', $values);
}
public function profileAction($args) {
$container = $this->container;
$storage = $container->getStorage();
$username = '';
$usernameCanonical = '';
if(array_key_exists('username', $args)) {
$username = $args['username'];
}
$username = str_replace('+', '%2b', $username);
$username = urldecode($username);
$ircLowerSymbols = array("\\"=>"|", "["=>"{", "]"=>"}", "~"=>"^");
$usernameCanonical = strtr($username, $ircLowerSymbols);
$usernameCanonical = strtolower($usernameCanonical);
$lastSeen = 'Never';
$result = array();
$result['usrname'] = "Not found";
$result['count'] = 0;
$result['score'] = 0;
$result['points'] = 0;
$result['q_asked'] = 0;
$result['num_e'] = 0;
$result['num_e_accepted'] = 0;
$result['num_q'] = 0;
$result['num_q_accepted'] = 0;
$result['num_r'] = 0;
$result['highest_streak'] = 0;
$userProfile = $result;
$errors = array();
if ($username != '') {
try {
$profileResult = $storage->getUserProfileInformation($usernameCanonical);
if(count($profileResult) > 0) {
if(array_key_exists('usrname', $profileResult[0])) {
if(!is_null($profileResult[0]['usrname'])) {
$userProfile = $profileResult[0];
}
}
}
$lastSeenQuery = $storage->getTimeSinceLastPlayed($usernameCanonical);
if(count($lastSeenQuery) > 0) {
if(array_key_exists('last_updated', $lastSeenQuery[0])) {
if(!is_null($lastSeenQuery[0]['last_updated'])) {
$lastSeenSeconds = strtotime("now") - $lastSeenQuery[0]['last_updated'];
$lastSeenObj = $this->secondsToTime($lastSeenSeconds);
$lastSeen = '';
if($lastSeenObj["d"] > 0) {
$lastSeen .= $lastSeenObj["d"] . ' days ';
}
if($lastSeenObj["h"] > 0) {
$lastSeen .= $lastSeenObj["h"] . ' hours ';
}
if($lastSeenObj["m"] > 0) {
$lastSeen .= $lastSeenObj["m"] . ' mins ';
}
if($lastSeenObj["s"] > 0) {
$lastSeen .= $lastSeenObj["s"] . ' secs';
}
if($lastSeen != '') {
$lastSeen .= ' ago';
}
}
}
}
} catch(StorageSchemaException $e) {
$errors[] = "Error: Database schema is not queryable";
} catch(StorageConnectionException $e) {
$errors[] = "Error: Database is not available";
}
$storage->close();
}
$values = array();
$values['userProfile'] = $userProfile;
$values['username'] = $username;
$values['usernameCanonical'] = $usernameCanonical;
$values['errors'] = $errors;
$values['lastSeen'] = $lastSeen;
$container->setTitle($username);
$container->render('profile.html.php', $values);
}
protected function secondsToTime($inputSeconds) {
$secondsInAMinute = 60;
$secondsInAnHour = 60 * $secondsInAMinute;
$secondsInADay = 24 * $secondsInAnHour;
// extract days
$days = floor($inputSeconds / $secondsInADay);
// extract hours
$hourSeconds = $inputSeconds % $secondsInADay;
$hours = floor($hourSeconds / $secondsInAnHour);
// extract minutes
$minuteSeconds = $hourSeconds % $secondsInAnHour;
$minutes = floor($minuteSeconds / $secondsInAMinute);
// extract the remaining seconds
$remainingSeconds = $minuteSeconds % $secondsInAMinute;
$seconds = ceil($remainingSeconds);
// return the final array
$obj = array(
'd' => (int) $days,
'h' => (int) $hours,
'm' => (int) $minutes,
's' => (int) $seconds,
);
return $obj;
}
}