less global user, more event->user

git-svn-id: file:///home/shish/svn/shimmie2/trunk@478 7f39781d-f577-437e-ae19-be835c7a54ca
This commit is contained in:
shish 2007-08-24 22:29:34 +00:00
parent 6993bc2fdf
commit 88336cc323
13 changed files with 41 additions and 46 deletions

View file

@ -9,13 +9,12 @@
class AdminUtils extends Extension { class AdminUtils extends Extension {
var $theme; var $theme;
// event handler {{{
public function receive_event($event) { public function receive_event($event) {
if(is_null($this->theme)) $this->theme = get_theme_object("admin_utils", "AdminUtilsTheme"); if(is_null($this->theme)) $this->theme = get_theme_object("admin_utils", "AdminUtilsTheme");
if(is_a($event, 'PageRequestEvent') && ($event->page_name == "admin_utils")) { if(is_a($event, 'PageRequestEvent') && ($event->page_name == "admin_utils")) {
global $user; if($event->user->is_admin()) {
if($user->is_admin()) {
set_time_limit(0); set_time_limit(0);
switch($_POST['action']) { switch($_POST['action']) {
@ -40,8 +39,7 @@ class AdminUtils extends Extension {
$this->theme->display_form($page); $this->theme->display_form($page);
} }
} }
// }}}
// do things {{{
private function lowercase_all_tags() { private function lowercase_all_tags() {
global $database; global $database;
$database->execute("UPDATE tags SET tag=lower(tag)"); $database->execute("UPDATE tags SET tag=lower(tag)");
@ -66,7 +64,6 @@ class AdminUtils extends Extension {
} }
} }
} }
// }}}
} }
add_event_listener(new AdminUtils()); add_event_listener(new AdminUtils());
?> ?>

View file

@ -18,9 +18,8 @@ class EventLog extends Extension {
} }
if(is_a($event, 'PageRequestEvent') && $event->page_name == "event_log") { if(is_a($event, 'PageRequestEvent') && $event->page_name == "event_log") {
global $user;
global $database; global $database;
if($user->is_admin()) { if($event->user->is_admin()) {
if(isset($_POST['action'])) { if(isset($_POST['action'])) {
switch($_POST['action']) { switch($_POST['action']) {
case 'clear': case 'clear':
@ -68,9 +67,8 @@ class EventLog extends Extension {
} }
global $user; // bad global $user; // bad
// TODO: log comments, uploads
if(is_a($event, 'UploadingImageEvent')) { if(is_a($event, 'UploadingImageEvent')) {
$this->add_to_log($user, 'Uploading Image', "Uploaded a new image"); $this->add_to_log($event->user, 'Uploading Image', "Uploaded a new image");
} }
if(is_a($event, 'CommentPostingEvent')) { if(is_a($event, 'CommentPostingEvent')) {
$this->add_to_log($event->user, 'Comment Posting', "Posted a comment on image #{$event->image_id}"); $this->add_to_log($event->user, 'Comment Posting', "Posted a comment on image #{$event->image_id}");

View file

@ -15,11 +15,13 @@ class PageRequestEvent extends Event {
var $page_name; var $page_name;
var $args; var $args;
var $page; var $page;
var $user;
public function PageRequestEvent($page_name, $args, $page) { public function PageRequestEvent($page_name, $args, $page, $user) {
$this->page_name = $page_name; $this->page_name = $page_name;
$this->args = $args; $this->args = $args;
$this->page = $page; $this->page = $page;
$this->user = $user;
} }
public function get_arg($n) { public function get_arg($n) {

View file

@ -7,11 +7,11 @@
*/ */
class UploadingImageEvent extends Event { class UploadingImageEvent extends Event {
var $image; var $image;
var $ok; var $user;
public function UploadingImageEvent($image) { public function UploadingImageEvent($image, $user) {
$this->image = $image; $this->image = $image;
$this->ok = false; $this->user = $user;
} }
} }
?> ?>

View file

@ -404,7 +404,7 @@ function _get_query_parts() {
return $parts; return $parts;
} }
function _get_page_request($page) { function _get_page_request($page, $user) {
global $config; global $config;
$args = _get_query_parts(); $args = _get_query_parts();
@ -422,7 +422,7 @@ function _get_page_request($page) {
$args = array_slice($args, 1); $args = array_slice($args, 1);
} }
return new PageRequestEvent($page_name, $args, $page); return new PageRequestEvent($page_name, $args, $page, $user);
} }
function _get_user() { function _get_user() {

View file

@ -14,13 +14,11 @@ class AdminBuildingEvent extends Event {
class AdminPage extends Extension { class AdminPage extends Extension {
var $theme; var $theme;
// event handler {{{
public function receive_event($event) { public function receive_event($event) {
if(is_null($this->theme)) $this->theme = get_theme_object("admin", "AdminPageTheme"); if(is_null($this->theme)) $this->theme = get_theme_object("admin", "AdminPageTheme");
if(is_a($event, 'PageRequestEvent') && ($event->page_name == "admin")) { if(is_a($event, 'PageRequestEvent') && ($event->page_name == "admin")) {
global $user; if(!$event->user->is_admin()) {
if(!$user->is_admin()) {
$this->theme->display_error($event->page, "Permission Denied", "This page is for admins only"); $this->theme->display_error($event->page, "Permission Denied", "This page is for admins only");
} }
else { else {
@ -59,7 +57,6 @@ class AdminPage extends Extension {
} }
} }
} }
// }}}
} }
add_event_listener(new AdminPage()); add_event_listener(new AdminPage());
?> ?>

View file

@ -17,20 +17,18 @@ class AliasEditor extends Extension {
if(is_null($this->theme)) $this->theme = get_theme_object("alias_editor", "AliasEditorTheme"); if(is_null($this->theme)) $this->theme = get_theme_object("alias_editor", "AliasEditorTheme");
if(is_a($event, 'PageRequestEvent') && ($event->page_name == "alias")) { if(is_a($event, 'PageRequestEvent') && ($event->page_name == "alias")) {
global $user;
if($event->get_arg(0) == "add") { if($event->get_arg(0) == "add") {
if($user->is_admin()) { if($event->user->is_admin()) {
if(isset($_POST['oldtag']) && isset($_POST['newtag'])) { if(isset($_POST['oldtag']) && isset($_POST['newtag'])) {
send_event(new AddAliasEvent($_POST['oldtag'], $_POST['newtag'])); send_event(new AddAliasEvent($_POST['oldtag'], $_POST['newtag']));
global $page;
$event->page->set_mode("redirect"); $event->page->set_mode("redirect");
$event->page->set_redirect(make_link("alias/list")); $event->page->set_redirect(make_link("alias/list"));
} }
} }
} }
else if($event->get_arg(0) == "remove") { else if($event->get_arg(0) == "remove") {
if($user->is_admin()) { if($event->user->is_admin()) {
if(isset($_POST['oldtag'])) { if(isset($_POST['oldtag'])) {
global $database; global $database;
$database->Execute("DELETE FROM aliases WHERE oldtag=?", array($_POST['oldtag'])); $database->Execute("DELETE FROM aliases WHERE oldtag=?", array($_POST['oldtag']));
@ -42,7 +40,7 @@ class AliasEditor extends Extension {
} }
else if($event->get_arg(0) == "list") { else if($event->get_arg(0) == "list") {
global $database; global $database;
$this->theme->display_aliases($event->page, $database->db->GetAssoc("SELECT oldtag, newtag FROM aliases"), $user->is_admin()); $this->theme->display_aliases($event->page, $database->db->GetAssoc("SELECT oldtag, newtag FROM aliases"), $event->user->is_admin());
} }
else if($event->get_arg(0) == "export") { else if($event->get_arg(0) == "export") {
$event->page->set_mode("data"); $event->page->set_mode("data");

View file

@ -2,13 +2,12 @@
class BulkAdd extends Extension { class BulkAdd extends Extension {
var $theme; var $theme;
// event handler {{{
public function receive_event($event) { public function receive_event($event) {
if(is_null($this->theme)) $this->theme = get_theme_object("bulk_add", "BulkAddTheme"); if(is_null($this->theme)) $this->theme = get_theme_object("bulk_add", "BulkAddTheme");
if(is_a($event, 'PageRequestEvent') && ($event->page_name == "bulk_add")) { if(is_a($event, 'PageRequestEvent') && ($event->page_name == "bulk_add")) {
global $user; if($event->user->is_admin() && isset($_POST['dir'])) {
if($user->is_admin() && isset($_POST['dir'])) {
set_time_limit(0); set_time_limit(0);
$this->add_dir($_POST['dir']); $this->add_dir($_POST['dir']);
@ -21,7 +20,7 @@ class BulkAdd extends Extension {
$this->theme->display_admin_block($page); $this->theme->display_admin_block($page);
} }
} }
// }}}
// do the adding {{{ // do the adding {{{
private function add_image($tmpname, $filename, $tags) { private function add_image($tmpname, $filename, $tags) {
global $config; global $config;

View file

@ -68,12 +68,10 @@ class CommentList extends Extension {
if(is_a($event, 'PageRequestEvent') && ($event->page_name == "comment")) { if(is_a($event, 'PageRequestEvent') && ($event->page_name == "comment")) {
if($event->get_arg(0) == "add") { if($event->get_arg(0) == "add") {
global $user; send_event(new CommentPostingEvent($_POST['image_id'], $event->user, $_POST['comment']));
send_event(new CommentPostingEvent($_POST['image_id'], $user, $_POST['comment']));
} }
else if($event->get_arg(0) == "delete") { else if($event->get_arg(0) == "delete") {
global $user; if($event->user->is_admin()) {
if($user->is_admin()) {
// FIXME: post, not args // FIXME: post, not args
if($event->count_args() == 3) { if($event->count_args() == 3) {
send_event(new CommentDeletionEvent($event->get_arg(1))); send_event(new CommentDeletionEvent($event->get_arg(1)));

View file

@ -6,7 +6,9 @@ class Downtime extends Extension {
public function receive_event($event) { public function receive_event($event) {
if(is_null($this->theme)) $this->theme = get_theme_object("downtime", "DowntimeTheme"); if(is_null($this->theme)) $this->theme = get_theme_object("downtime", "DowntimeTheme");
$this->check_downtime($event); if(is_a($event, 'InitExtEvent')) {
$this->check_downtime($event);
}
if(is_a($event, 'SetupBuildingEvent')) { if(is_a($event, 'SetupBuildingEvent')) {
$sb = new SetupBlock("Downtime"); $sb = new SetupBlock("Downtime");
@ -14,6 +16,7 @@ class Downtime extends Extension {
$sb->add_longtext_option("downtime_message", "<br>"); $sb->add_longtext_option("downtime_message", "<br>");
$event->panel->add_block($sb); $event->panel->add_block($sb);
} }
if(is_a($event, 'PageRequestEvent')) { if(is_a($event, 'PageRequestEvent')) {
global $config; global $config;
if($config->get_bool("downtime")) { if($config->get_bool("downtime")) {

View file

@ -2,13 +2,12 @@
class ET extends Extension { class ET extends Extension {
var $theme; var $theme;
// event handler {{{
public function receive_event($event) { public function receive_event($event) {
if(is_null($this->theme)) $this->theme = get_theme_object("et", "ETTheme"); if(is_null($this->theme)) $this->theme = get_theme_object("et", "ETTheme");
if(is_a($event, 'PageRequestEvent') && ($event->page_name == "system_info")) { if(is_a($event, 'PageRequestEvent') && ($event->page_name == "system_info")) {
global $user; if($event->user->is_admin()) {
if($user->is_admin()) {
$this->theme->display_info_page($event->page, $this->get_info()); $this->theme->display_info_page($event->page, $this->get_info());
} }
} }
@ -19,7 +18,7 @@ class ET extends Extension {
} }
} }
} }
// }}}
// do it {{{ // do it {{{
private function get_info() { private function get_info() {
global $database; global $database;

View file

@ -14,7 +14,8 @@ class Upload extends Extension {
} }
if(is_a($event, 'PostListBuildingEvent')) { if(is_a($event, 'PostListBuildingEvent')) {
if($this->can_upload()) { global $user;
if($this->can_upload($user)) {
$this->theme->display_block($event->page); $this->theme->display_block($event->page);
} }
} }
@ -23,7 +24,8 @@ class Upload extends Extension {
if(count($_FILES) + count($_POST) > 0) { if(count($_FILES) + count($_POST) > 0) {
$tags = tag_explode($_POST['tags']); $tags = tag_explode($_POST['tags']);
$source = isset($_POST['source']) ? $_POST['source'] : null; $source = isset($_POST['source']) ? $_POST['source'] : null;
if($this->can_upload()) { global $user;
if($this->can_upload($user)) {
$ok = true; $ok = true;
foreach($_FILES as $file) { foreach($_FILES as $file) {
$ok = $ok & $this->try_upload($file, $tags, $source); $ok = $ok & $this->try_upload($file, $tags, $source);
@ -61,9 +63,9 @@ class Upload extends Extension {
} }
// }}} // }}}
// do things {{{ // do things {{{
private function can_upload() { private function can_upload($user) {
global $config, $user; global $config;
return $config->get_bool("upload_anon") || !$user->is_anonymous(); return ($config->get_bool("upload_anon") || !$user->is_anonymous());
} }
private function try_upload($file, $tags, $source) { private function try_upload($file, $tags, $source) {
@ -91,7 +93,8 @@ class Upload extends Extension {
$image = new Image($file['tmp_name'], $file['name'], $tags, $source); $image = new Image($file['tmp_name'], $file['name'], $tags, $source);
if($image->is_ok()) { if($image->is_ok()) {
$event = new UploadingImageEvent($image); global $user;
$event = new UploadingImageEvent($user, $image);
send_event($event); send_event($event);
$ok = !$event->vetoed; $ok = !$event->vetoed;
if(!$ok) { if(!$ok) {
@ -170,7 +173,8 @@ class Upload extends Extension {
$image = new Image($tmp_filename, basename($url), $tags, $source); $image = new Image($tmp_filename, basename($url), $tags, $source);
if($image->is_ok()) { if($image->is_ok()) {
$event = new UploadingImageEvent($image); global $user;
$event = new UploadingImageEvent($user, $image);
send_event($event); send_event($event);
$ok = !$event->vetoed; $ok = !$event->vetoed;
if(!$ok) { if(!$ok) {

View file

@ -45,6 +45,6 @@ foreach($themelets as $filename) {
$page = new Page(); $page = new Page();
$user = _get_user(); $user = _get_user();
send_event(new InitExtEvent()); send_event(new InitExtEvent());
send_event(_get_page_request($page)); send_event(_get_page_request($page, $user));
$page->display(); $page->display();
?> ?>