This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/core/extension.class.php

295 lines
8.2 KiB
PHP
Raw Normal View History

<?php
2009-07-19 07:38:13 +00:00
/**
* \page eande Events and Extensions
2014-02-22 20:42:09 +00:00
*
2009-07-21 03:18:40 +00:00
* An event is a little blob of data saying "something happened", possibly
* "something happened, here's the specific data". Events are sent with the
* send_event() function. Since events can store data, they can be used to
* return data to the extension which sent them, for example:
2014-02-22 20:42:09 +00:00
*
2009-07-21 03:18:40 +00:00
* \code
* $tfe = new TextFormattingEvent($original_text);
* send_event($tfe);
* $formatted_text = $tfe->formatted;
* \endcode
2014-02-22 20:42:09 +00:00
*
* An extension is something which is capable of reacting to events.
*
*
* \page hello The Hello World Extension
*
* \code
* // ext/hello/main.php
2012-03-05 13:56:36 +00:00
* public class HelloEvent extends Event {
* public function __construct($username) {
* $this->username = $username;
* }
* }
2014-02-22 20:42:09 +00:00
*
* public class Hello extends Extension {
2012-03-05 18:42:05 +00:00
* public function onPageRequest(PageRequestEvent $event) { // Every time a page request is sent
* global $user; // Look at the global "currently logged in user" object
* send_event(new HelloEvent($user->name)); // Broadcast a signal saying hello to that user
2012-03-05 13:56:36 +00:00
* }
2012-03-05 18:42:05 +00:00
* public function onHello(HelloEvent $event) { // When the "Hello" signal is recieved
* $this->theme->display_hello($event->username); // Display a message on the web page
* }
* }
*
* // ext/hello/theme.php
* public class HelloTheme extends Themelet {
2012-03-05 13:58:04 +00:00
* public function display_hello($username) {
2012-03-05 13:56:36 +00:00
* global $page;
2012-03-05 18:42:05 +00:00
* $h_user = html_escape($username); // Escape the data before adding it to the page
* $block = new Block("Hello!", "Hello there $h_user"); // HTML-safe variables start with "h_"
* $page->add_block($block); // Add the block to the page
* }
* }
*
* // ext/hello/test.php
2015-08-09 11:14:28 +00:00
* public class HelloTest extends SCorePHPUnitTestCase {
2012-03-05 13:58:04 +00:00
* public function testHello() {
2012-03-05 18:42:05 +00:00
* $this->get_page("post/list"); // View a page, any page
* $this->assert_text("Hello there"); // Check that the specified text is in that page
* }
* }
*
* // themes/mytheme/hello.theme.php
2012-03-05 18:42:05 +00:00
* public class CustomHelloTheme extends HelloTheme { // CustomHelloTheme overrides HelloTheme
* public function display_hello($username) { // the display_hello() function is customised
* global $page;
* $h_user = html_escape($username);
* $page->add_block(new Block(
* "Hello!",
* "Hello there $h_user, look at my snazzy custom theme!"
* );
* }
* }
* \endcode
*
2009-07-19 07:38:13 +00:00
*/
/**
2014-04-29 05:33:03 +00:00
* Class Extension
*
2009-05-15 08:52:55 +00:00
* send_event(BlahEvent()) -> onBlah($event)
*
* Also loads the theme object into $this->theme if available
*
* The original concept came from Artanis's Extension extension
2009-05-15 08:52:55 +00:00
* --> http://github.com/Artanis/simple-extension/tree/master
* Then re-implemented by Shish after he broke the forum and couldn't
* find the thread where the original was posted >_<
*/
abstract class Extension {
/** @var array which DBs this ext supports (blank for 'all') */
protected $db_support = [];
2016-06-19 22:23:34 +00:00
/** @var Themelet this theme's Themelet object */
public $theme;
2012-03-05 13:56:36 +00:00
2016-06-19 22:23:34 +00:00
public function __construct() {
$this->theme = $this->get_theme_object(get_called_class());
}
public function is_live() {
global $database;
return (
empty($this->db_support) ||
in_array($database->get_driver_name(), $this->db_support)
);
}
/**
* Find the theme object for a given extension.
*
2016-06-19 22:23:34 +00:00
* @param string $base
* @return Themelet
*/
2016-06-19 22:23:34 +00:00
private function get_theme_object($base) {
$custom = 'Custom'.$base.'Theme';
$normal = $base.'Theme';
if(class_exists($custom)) {
return new $custom();
}
elseif(class_exists($normal)) {
return new $normal();
}
2016-06-19 22:23:34 +00:00
else {
return null;
}
}
2012-03-05 13:56:36 +00:00
/**
* Override this to change the priority of the extension,
* lower numbered ones will recieve events first.
*
* @return int
2012-03-05 13:56:36 +00:00
*/
public function get_priority() {
return 50;
}
}
2009-07-19 07:38:13 +00:00
/**
2014-04-29 05:33:03 +00:00
* Class FormatterExtension
*
* Several extensions have this in common, make a common API.
*/
abstract class FormatterExtension extends Extension {
/**
* @param TextFormattingEvent $event
*/
2012-02-02 16:08:49 +00:00
public function onTextFormatting(TextFormattingEvent $event) {
$event->formatted = $this->format($event->formatted);
$event->stripped = $this->strip($event->stripped);
}
/**
* @param string $text
* @return string
*/
2012-02-02 13:58:48 +00:00
abstract public function format(/*string*/ $text);
/**
* @param string $text
* @return string
*/
2012-02-02 13:58:48 +00:00
abstract public function strip(/*string*/ $text);
}
2009-07-16 19:20:53 +00:00
2009-07-19 07:38:13 +00:00
/**
2014-04-29 05:33:03 +00:00
* Class DataHandlerExtension
*
2009-07-19 03:48:25 +00:00
* This too is a common class of extension with many methods in common,
2014-04-29 05:33:03 +00:00
* so we have a base class to extend from.
2009-07-19 03:48:25 +00:00
*/
abstract class DataHandlerExtension extends Extension {
/**
* @param DataUploadEvent $event
* @throws UploadException
*/
2012-02-02 13:58:48 +00:00
public function onDataUpload(DataUploadEvent $event) {
2014-04-06 19:47:01 +00:00
$supported_ext = $this->supported_ext($event->type);
$check_contents = $this->check_contents($event->tmpname);
if($supported_ext && $check_contents) {
move_upload_to_archive($event);
2009-07-16 19:20:53 +00:00
send_event(new ThumbnailGenerationEvent($event->hash, $event->type));
/* Check if we are replacing an image */
if(array_key_exists('replace', $event->metadata) && isset($event->metadata['replace'])) {
/* hax: This seems like such a dirty way to do this.. */
2014-02-22 20:42:09 +00:00
/* Validate things */
$image_id = int_escape($event->metadata['replace']);
2014-02-22 20:42:09 +00:00
/* Check to make sure the image exists. */
$existing = Image::by_id($image_id);
2014-02-22 20:42:09 +00:00
if(is_null($existing)) {
throw new UploadException("Image to replace does not exist!");
}
if ($existing->hash === $event->metadata['hash']) {
throw new UploadException("The uploaded image is the same as the one to replace.");
}
// even more hax..
$event->metadata['tags'] = $existing->get_tag_list();
$image = $this->create_image_from_data(warehouse_path("images", $event->metadata['hash']), $event->metadata);
2014-02-22 20:42:09 +00:00
if(is_null($image)) {
throw new UploadException("Data handler failed to create image object from data");
}
$ire = new ImageReplaceEvent($image_id, $image);
send_event($ire);
$event->image_id = $image_id;
}
else {
$image = $this->create_image_from_data(warehouse_path("images", $event->hash), $event->metadata);
if(is_null($image)) {
throw new UploadException("Data handler failed to create image object from data");
}
$iae = new ImageAdditionEvent($image);
send_event($iae);
$event->image_id = $iae->image->id;
2014-02-22 20:42:09 +00:00
// Rating Stuff.
if(!empty($event->metadata['rating'])){
$rating = $event->metadata['rating'];
send_event(new RatingSetEvent($image, $rating));
}
2014-02-22 20:42:09 +00:00
// Locked Stuff.
if(!empty($event->metadata['locked'])){
$locked = $event->metadata['locked'];
send_event(new LockSetEvent($image, !empty($locked)));
}
}
2009-07-16 19:20:53 +00:00
}
elseif($supported_ext && !$check_contents){
throw new UploadException("Invalid or corrupted file");
}
}
2009-07-16 19:20:53 +00:00
/**
* @param ThumbnailGenerationEvent $event
*/
2012-02-05 05:06:55 +00:00
public function onThumbnailGeneration(ThumbnailGenerationEvent $event) {
if($this->supported_ext($event->type)) {
if (method_exists($this, 'create_thumb_force') && $event->force == true) {
$this->create_thumb_force($event->hash);
}
else {
$this->create_thumb($event->hash);
}
2009-07-16 19:20:53 +00:00
}
}
2009-07-16 19:20:53 +00:00
/**
* @param DisplayingImageEvent $event
*/
2012-02-02 13:58:48 +00:00
public function onDisplayingImage(DisplayingImageEvent $event) {
global $page;
if($this->supported_ext($event->image->ext)) {
2009-07-16 19:20:53 +00:00
$this->theme->display_image($page, $event->image);
}
}
2010-08-06 23:24:31 +00:00
/*
2012-02-02 13:58:48 +00:00
public function onSetupBuilding(SetupBuildingEvent $event) {
$sb = $this->setup();
if($sb) $event->panel->add_block($sb);
2009-07-16 19:20:53 +00:00
}
2010-08-06 23:24:31 +00:00
protected function setup() {}
*/
/**
* @param string $ext
* @return bool
*/
2009-07-16 19:20:53 +00:00
abstract protected function supported_ext($ext);
/**
2015-09-27 01:17:44 +00:00
* @param string $tmpname
* @return bool
*/
2009-07-16 19:20:53 +00:00
abstract protected function check_contents($tmpname);
/**
* @param string $filename
* @param array $metadata
* @return Image|null
*/
2009-07-16 19:20:53 +00:00
abstract protected function create_image_from_data($filename, $metadata);
/**
* @param string $hash
* @return bool
*/
2009-07-16 19:20:53 +00:00
abstract protected function create_thumb($hash);
}