2007-04-16 11:58:25 +00:00
|
|
|
<?php
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* Generic parent class for all events.
|
|
|
|
*
|
|
|
|
* An event is anything that can be passed around via send_event($blah)
|
2007-04-16 11:58:25 +00:00
|
|
|
*/
|
2008-08-23 12:05:24 +00:00
|
|
|
abstract class Event {
|
2009-05-11 14:04:33 +00:00
|
|
|
public function __construct() {}
|
2007-04-16 11:58:25 +00:00
|
|
|
}
|
2007-12-06 10:21:23 +00:00
|
|
|
|
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
2009-07-21 03:18:40 +00:00
|
|
|
* A wake-up call for extensions. Upon recieving an InitExtEvent an extension
|
|
|
|
* should check that it's database tables are there and install them if not,
|
|
|
|
* and set any defaults with Config::set_default_int() and such.
|
2007-12-06 10:21:23 +00:00
|
|
|
*/
|
2008-08-23 12:05:24 +00:00
|
|
|
class InitExtEvent extends Event {}
|
2007-12-06 10:21:23 +00:00
|
|
|
|
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* A signal that a page has been requested.
|
|
|
|
*
|
2009-01-03 21:00:09 +00:00
|
|
|
* User requests /view/42 -> an event is generated with $args = array("view",
|
|
|
|
* "42"); when an event handler asks $event->page_matches("view"), it returns
|
|
|
|
* true and ignores the matched part, such that $event->count_args() = 1 and
|
|
|
|
* $event->get_arg(0) = "42"
|
2007-12-06 10:21:23 +00:00
|
|
|
*/
|
|
|
|
class PageRequestEvent extends Event {
|
2014-04-27 19:33:57 +00:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $args;
|
2014-04-27 19:33:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var int
|
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $arg_count;
|
2014-04-27 19:33:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var int
|
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $part_count;
|
2008-09-06 17:05:21 +00:00
|
|
|
|
2014-04-26 09:01:49 +00:00
|
|
|
/**
|
|
|
|
* @param string $path
|
|
|
|
*/
|
2012-06-17 23:00:21 +00:00
|
|
|
public function __construct($path) {
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
// trim starting slashes
|
2013-06-13 11:20:27 +00:00
|
|
|
$path = ltrim($path, "/");
|
2012-06-17 23:00:21 +00:00
|
|
|
|
|
|
|
// if path is not specified, use the default front page
|
2013-05-14 00:40:01 +00:00
|
|
|
if(empty($path)) { /* empty is faster than strlen */
|
2012-06-17 23:00:21 +00:00
|
|
|
$path = $config->get_string('front_page');
|
|
|
|
}
|
|
|
|
|
|
|
|
// break the path into parts
|
|
|
|
$args = explode('/', $path);
|
|
|
|
|
|
|
|
// voodoo so that an arg can contain a slash; is
|
|
|
|
// this still needed?
|
|
|
|
if(strpos($path, "^") !== FALSE) {
|
|
|
|
$unescaped = array();
|
2012-06-24 06:13:53 +00:00
|
|
|
foreach($args as $part) {
|
2012-06-17 23:00:21 +00:00
|
|
|
$unescaped[] = _decaret($part);
|
|
|
|
}
|
|
|
|
$args = $unescaped;
|
|
|
|
}
|
|
|
|
|
2007-12-06 10:21:23 +00:00
|
|
|
$this->args = $args;
|
2008-09-06 17:05:21 +00:00
|
|
|
$this->arg_count = count($args);
|
2007-12-06 10:21:23 +00:00
|
|
|
}
|
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* Test if the requested path matches a given pattern.
|
|
|
|
*
|
|
|
|
* If it matches, store the remaining path elements in $args
|
2012-02-08 01:13:58 +00:00
|
|
|
*
|
2014-04-26 09:01:49 +00:00
|
|
|
* @param string $name
|
2014-04-24 23:08:23 +00:00
|
|
|
* @return bool
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2012-02-02 13:58:48 +00:00
|
|
|
public function page_matches(/*string*/ $name) {
|
2008-08-23 12:05:24 +00:00
|
|
|
$parts = explode("/", $name);
|
2008-09-06 17:05:21 +00:00
|
|
|
$this->part_count = count($parts);
|
2009-01-04 19:18:37 +00:00
|
|
|
|
2008-09-06 17:05:21 +00:00
|
|
|
if($this->part_count > $this->arg_count) {
|
2008-08-23 12:05:24 +00:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2008-09-06 17:05:21 +00:00
|
|
|
for($i=0; $i<$this->part_count; $i++) {
|
2008-08-23 12:05:24 +00:00
|
|
|
if($parts[$i] != $this->args[$i]) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2012-02-08 01:13:58 +00:00
|
|
|
/**
|
|
|
|
* Get the n th argument of the page request (if it exists.)
|
2014-04-26 09:01:49 +00:00
|
|
|
*
|
|
|
|
* @param int $n
|
2014-04-27 19:33:57 +00:00
|
|
|
* @return string|null The argument (string) or NULL
|
2012-02-08 01:13:58 +00:00
|
|
|
*/
|
2012-02-02 13:58:48 +00:00
|
|
|
public function get_arg(/*int*/ $n) {
|
2008-09-06 17:05:21 +00:00
|
|
|
$offset = $this->part_count + $n;
|
|
|
|
if($offset >= 0 && $offset < $this->arg_count) {
|
|
|
|
return $this->args[$offset];
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return null;
|
|
|
|
}
|
2007-12-06 10:21:23 +00:00
|
|
|
}
|
|
|
|
|
2012-02-08 01:13:58 +00:00
|
|
|
/**
|
|
|
|
* Returns the number of arguments the page request has.
|
2014-04-24 23:08:23 +00:00
|
|
|
* @return int
|
2012-02-08 01:13:58 +00:00
|
|
|
*/
|
2007-12-06 10:21:23 +00:00
|
|
|
public function count_args() {
|
2012-01-11 20:57:00 +00:00
|
|
|
return (int)($this->arg_count - $this->part_count);
|
2007-12-06 10:21:23 +00:00
|
|
|
}
|
2010-04-26 01:35:53 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Many things use these functions
|
|
|
|
*/
|
2014-04-26 09:01:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2010-04-26 01:35:53 +00:00
|
|
|
public function get_search_terms() {
|
|
|
|
$search_terms = array();
|
2012-01-11 20:57:00 +00:00
|
|
|
if($this->count_args() === 2) {
|
2010-04-26 05:07:34 +00:00
|
|
|
$search_terms = explode(' ', $this->get_arg(0));
|
2010-04-26 01:35:53 +00:00
|
|
|
}
|
|
|
|
return $search_terms;
|
|
|
|
}
|
2014-04-26 09:01:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
2010-04-26 01:35:53 +00:00
|
|
|
public function get_page_number() {
|
|
|
|
$page_number = 1;
|
2012-01-11 20:57:00 +00:00
|
|
|
if($this->count_args() === 1) {
|
2010-04-26 02:39:02 +00:00
|
|
|
$page_number = int_escape($this->get_arg(0));
|
2010-04-26 01:35:53 +00:00
|
|
|
}
|
2012-01-11 20:57:00 +00:00
|
|
|
else if($this->count_args() === 2) {
|
2010-04-26 02:39:02 +00:00
|
|
|
$page_number = int_escape($this->get_arg(1));
|
2010-04-26 01:35:53 +00:00
|
|
|
}
|
2012-01-11 20:57:00 +00:00
|
|
|
if($page_number === 0) $page_number = 1; // invalid -> 0
|
2010-04-26 01:35:53 +00:00
|
|
|
return $page_number;
|
|
|
|
}
|
2014-04-26 09:01:49 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
2010-04-26 01:35:53 +00:00
|
|
|
public function get_page_size() {
|
|
|
|
global $config;
|
2012-04-01 16:47:39 +00:00
|
|
|
return $config->get_int('index_images');
|
2010-04-26 01:35:53 +00:00
|
|
|
}
|
2007-12-06 10:21:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-06-17 19:05:16 +00:00
|
|
|
/**
|
|
|
|
* Sent when index.php is called from the command line
|
|
|
|
*/
|
|
|
|
class CommandEvent extends Event {
|
2014-04-27 19:33:57 +00:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
2012-06-17 19:05:16 +00:00
|
|
|
public $cmd = "help";
|
2014-04-27 19:33:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2012-06-17 19:05:16 +00:00
|
|
|
public $args = array();
|
|
|
|
|
2014-04-27 19:33:57 +00:00
|
|
|
/**
|
|
|
|
* @param string[] $args
|
|
|
|
*/
|
2012-06-17 19:05:16 +00:00
|
|
|
public function __construct(/*array(string)*/ $args) {
|
|
|
|
global $user;
|
|
|
|
|
|
|
|
$opts = array();
|
|
|
|
$log_level = SCORE_LOG_WARNING;
|
2013-05-14 00:40:01 +00:00
|
|
|
$arg_count = count($args);
|
2014-02-22 20:42:09 +00:00
|
|
|
|
2013-05-14 00:40:01 +00:00
|
|
|
for($i=1; $i<$arg_count; $i++) {
|
2012-06-17 19:05:16 +00:00
|
|
|
switch($args[$i]) {
|
|
|
|
case '-u':
|
|
|
|
$user = User::by_name($args[++$i]);
|
|
|
|
if(is_null($user)) {
|
|
|
|
die("Unknown user");
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '-q':
|
|
|
|
$log_level += 10;
|
|
|
|
break;
|
|
|
|
case '-v':
|
|
|
|
$log_level -= 10;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$opts[] = $args[$i];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
define("CLI_LOG_LEVEL", $log_level);
|
|
|
|
|
|
|
|
if(count($opts) > 0) {
|
|
|
|
$this->cmd = $opts[0];
|
|
|
|
$this->args = array_slice($opts, 1);
|
|
|
|
}
|
|
|
|
else {
|
2012-06-17 23:00:21 +00:00
|
|
|
print "\n";
|
|
|
|
print "Usage: php {$args[0]} [flags] [command]\n";
|
|
|
|
print "\n";
|
2012-06-17 19:05:16 +00:00
|
|
|
print "Flags:\n";
|
|
|
|
print " -u [username]\n";
|
|
|
|
print " Log in as the specified user\n";
|
|
|
|
print " -q / -v\n";
|
|
|
|
print " Be quieter / more verbose\n";
|
2012-06-17 23:00:21 +00:00
|
|
|
print " Scale is debug - info - warning - error - critical\n";
|
|
|
|
print " Default is to show warnings and above\n";
|
2012-06-17 19:05:16 +00:00
|
|
|
print " \n";
|
2012-06-17 23:00:21 +00:00
|
|
|
print "Currently known commands:\n";
|
2012-06-17 19:05:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* A signal that some text needs formatting, the event carries
|
|
|
|
* both the text and the result
|
2007-12-06 10:21:23 +00:00
|
|
|
*/
|
|
|
|
class TextFormattingEvent extends Event {
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* For reference
|
2014-04-27 19:33:57 +00:00
|
|
|
*
|
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $original;
|
2009-07-19 07:38:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* with formatting applied
|
2014-04-27 19:33:57 +00:00
|
|
|
*
|
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $formatted;
|
2009-07-19 07:38:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* with formatting removed
|
2014-04-27 19:33:57 +00:00
|
|
|
*
|
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $stripped;
|
2007-12-06 10:21:23 +00:00
|
|
|
|
2014-04-27 19:33:57 +00:00
|
|
|
/**
|
|
|
|
* @param string $text
|
|
|
|
*/
|
2012-02-02 13:58:48 +00:00
|
|
|
public function __construct(/*string*/ $text) {
|
2008-01-12 07:44:08 +00:00
|
|
|
$h_text = html_escape(trim($text));
|
|
|
|
$this->original = $h_text;
|
|
|
|
$this->formatted = $h_text;
|
|
|
|
$this->stripped = $h_text;
|
2007-12-06 10:21:23 +00:00
|
|
|
}
|
|
|
|
}
|
2009-05-08 10:52:29 +00:00
|
|
|
|
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* A signal that something needs logging
|
2009-05-08 10:52:29 +00:00
|
|
|
*/
|
|
|
|
class LogEvent extends Event {
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* a category, normally the extension name
|
|
|
|
*
|
2014-04-27 19:33:57 +00:00
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $section;
|
2009-07-19 07:38:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* See python...
|
|
|
|
*
|
2014-04-27 19:33:57 +00:00
|
|
|
* @var int
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $priority = 0;
|
2009-07-19 07:38:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Free text to be logged
|
|
|
|
*
|
2014-04-27 19:33:57 +00:00
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $message;
|
2009-07-19 07:38:13 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The time that the event was created
|
|
|
|
*
|
2014-04-27 19:33:57 +00:00
|
|
|
* @var int
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $time;
|
2009-05-08 10:52:29 +00:00
|
|
|
|
2013-08-29 19:23:08 +00:00
|
|
|
/**
|
|
|
|
* Extra data to be held separate
|
|
|
|
*/
|
2014-04-27 19:33:57 +00:00
|
|
|
public $args;
|
2013-08-29 19:23:08 +00:00
|
|
|
|
2014-04-27 19:33:57 +00:00
|
|
|
/**
|
|
|
|
* @param string $section
|
|
|
|
* @param int $priority
|
|
|
|
* @param string $message
|
|
|
|
* @param $args
|
|
|
|
*/
|
2013-08-29 19:23:08 +00:00
|
|
|
public function __construct($section, $priority, $message, $args) {
|
2009-05-08 10:52:29 +00:00
|
|
|
$this->section = $section;
|
|
|
|
$this->priority = $priority;
|
|
|
|
$this->message = $message;
|
2013-08-29 19:23:08 +00:00
|
|
|
$this->args = $args;
|
2009-05-08 10:52:29 +00:00
|
|
|
$this->time = time();
|
|
|
|
}
|
|
|
|
}
|
2014-04-24 23:01:47 +00:00
|
|
|
|