set_title("Login"); $page->set_heading("Login"); $page->add_block(new NavBlock()); $page->add_block(new Block( "Login There", "There should be a login box to the left" )); } /** * #param User[] $users */ public function display_user_list(Page $page, array $users, User $user, int $page_num, int $page_total) { $page->set_title("User List"); $page->set_heading("User List"); $page->add_block(new NavBlock()); $html = ""; $html .= ""; $html .= ""; if ($user->can(Permissions::DELETE_USER)) { $html .= ""; } $html .= ""; $html .= ""; $html .= ""; $h_username = html_escape(@$_GET['username']); $h_email = html_escape(@$_GET['email']); $h_class = html_escape(@$_GET['class']); $html .= "" . make_form("user_admin/list", "GET"); $html .= ""; if ($user->can(Permissions::DELETE_USER)) { $html .= ""; } $html .= ""; $html .= ""; $html .= ""; foreach ($users as $duser) { $h_name = html_escape($duser->name); $h_email = html_escape($duser->email); $h_class = html_escape($duser->class->name); $u_link = make_link("user/" . url_escape($duser->name)); $u_posts = make_link("post/list/user_id=" . url_escape($duser->id) . "/1"); $html .= ""; $html .= ""; if ($user->can(Permissions::DELETE_USER)) { $html .= ""; } $html .= ""; $html .= ""; $html .= ""; } $html .= "
NameEmailClassAction
$h_name$h_email$h_classShow Posts
"; $page->add_block(new Block("Users", $html)); $this->display_paginator($page, "user_admin/list", $this->get_args(), $page_num, $page_total); } protected function ueie($var) { if (isset($_GET[$var])) { return $var."=".url_escape($_GET[$var]); } else { return ""; } } protected function get_args() { $args = ""; // Check if each arg is actually empty and skip it if so if (strlen($this->ueie("username"))) { $args .= $this->ueie("username")."&"; } if (strlen($this->ueie("email"))) { $args .= $this->ueie("email")."&"; } if (strlen($this->ueie("class"))) { $args .= $this->ueie("class")."&"; } // If there are no args at all, set $args to null to prevent an unnecessary ? at the end of the paginator url if (strlen($args) == 0) { $args = null; } return $args; } public function display_user_links(Page $page, User $user, $parts) { # $page->add_block(new Block("User Links", join(", ", $parts), "main", 10)); } public function display_user_block(Page $page, User $user, $parts) { $h_name = html_escape($user->name); $html = 'Logged in as '.$h_name; foreach ($parts as $part) { $html .= '
'.$part["name"].''; } $page->add_block(new Block("User Links", $html, "left", 90)); } public function display_signup_page(Page $page) { global $config; $tac = $config->get_string("login_tac", ""); if ($config->get_bool("login_tac_bbcode")) { $tfe = new TextFormattingEvent($tac); send_event($tfe); $tac = $tfe->formatted; } if (empty($tac)) { $html = ""; } else { $html = '

'.$tac.'

'; } $h_reca = "".captcha_get_html().""; $html .= ' '.make_form(make_link("user_admin/create"))." $h_reca
Name
Password
Repeat Password
Email (Optional)
"; $page->set_title("Create Account"); $page->set_heading("Create Account"); $page->add_block(new NavBlock()); $page->add_block(new Block("Signup", $html)); } public function display_signups_disabled(Page $page) { $page->set_title("Signups Disabled"); $page->set_heading("Signups Disabled"); $page->add_block(new NavBlock()); $page->add_block(new Block( "Signups Disabled", "The board admin has disabled the ability to create new accounts~" )); } public function display_login_block(Page $page) { global $config; $html = ' '.make_form(make_link("user_admin/login"))."
"; if ($config->get_bool("login_signup_enabled")) { $html .= "Create Account"; } $page->add_block(new Block("Login", $html, "left", 90)); } public function display_ip_list(Page $page, array $uploads, array $comments, array $events) { $html = ""; $html .= ""; $html .= "
Uploaded from: "; $n = 0; foreach ($uploads as $ip => $count) { $html .= '
'.$ip.' ('.$count.')'; if (++$n >= 20) { $html .= "
..."; break; } } $html .= "
Commented from:"; $n = 0; foreach ($comments as $ip => $count) { $html .= '
'.$ip.' ('.$count.')'; if (++$n >= 20) { $html .= "
..."; break; } } $html .= "
Logged Events:"; $n = 0; foreach ($events as $ip => $count) { $html .= '
'.$ip.' ('.$count.')'; if (++$n >= 20) { $html .= "
..."; break; } } $html .= "
(Most recent at top)
"; $page->add_block(new Block("IPs", $html, "main", 70)); } public function display_user_page(User $duser, $stats) { global $page; assert(is_array($stats)); $stats[] = 'User ID: '.$duser->id; $page->set_title(html_escape($duser->name)."'s Page"); $page->set_heading(html_escape($duser->name)."'s Page"); $page->add_block(new NavBlock()); $page->add_block(new Block("Stats", join("
", $stats), "main", 10)); } public function build_options(User $duser, UserOptionsBuildingEvent $event) { global $config, $user; $html = ""; if ($duser->id != $config->get_int('anon_id')) { //justa fool-admin protection so they dont mess around with anon users. if ($user->can(Permissions::EDIT_USER_NAME)) { $html .= "

".make_form(make_link("user_admin/change_name"))."
Change Name
New name

"; } $html .= "

".make_form(make_link("user_admin/change_pass"))."
Change Password
Password
Repeat Password

".make_form(make_link("user_admin/change_email"))."
Change Email
Address

"; $i_user_id = int_escape($duser->id); if ($user->can(Permissions::EDIT_USER_CLASS)) { global $_shm_user_classes; $class_html = ""; foreach ($_shm_user_classes as $name => $values) { $h_name = html_escape($name); $h_title = html_escape(ucwords($name)); $h_selected = ($name == $duser->class->name ? " selected" : ""); $class_html .= "\n"; } $html .= "

".make_form(make_link("user_admin/change_class"))."
Change Class

"; } if ($user->can(Permissions::DELETE_USER)) { $html .= "

".make_form(make_link("user_admin/delete_user"))."
Delete User
Delete images
Delete comments

"; } foreach ($event->parts as $part) { $html .= $part; } } return $html; } // }}} public function get_help_html() { global $user; $output = '

Search for images posted by particular individuals.

poster=username

Returns images posted by "username".

poster_id=123

Returns images posted by user 123.

'; if ($user->can(Permissions::VIEW_IP)) { $output .="
poster_ip=127.0.0.1

Returns images posted from IP 127.0.0.1.

"; } return $output; } }