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/imageboard/event.php

150 lines
3.2 KiB
PHP
Raw Normal View History

2020-01-26 13:19:35 +00:00
<?php declare(strict_types=1);
2019-02-22 19:57:45 +00:00
/**
* An image is being added to the database.
*/
class ImageAdditionEvent extends Event
{
/** @var User */
public $user;
/** @var Image */
public $image;
public $merged = false;
/**
* Inserts a new image into the database with its associated
* information. Also calls TagSetEvent to set the tags for
* this new image.
*/
public function __construct(Image $image)
{
2020-01-26 13:19:35 +00:00
parent::__construct();
$this->image = $image;
}
2019-02-22 19:57:45 +00:00
}
class ImageAdditionException extends SCoreException
{
2019-02-22 19:57:45 +00:00
}
/**
* An image is being deleted.
*/
class ImageDeletionEvent extends Event
{
2019-05-28 20:27:23 +01:00
/** @var Image */
public $image;
/** @var bool */
public $force = false;
/**
* Deletes an image.
*
* Used by things like tags and comments handlers to
* clean out related rows in their tables.
*/
public function __construct(Image $image, bool $force = false)
{
2020-01-26 13:19:35 +00:00
parent::__construct();
$this->image = $image;
$this->force = $force;
}
2019-02-22 19:57:45 +00:00
}
/**
* An image is being replaced.
*/
class ImageReplaceEvent extends Event
{
/** @var int */
public $id;
2019-05-28 20:27:23 +01:00
/** @var Image */
public $image;
/**
* Replaces an image.
*
* Updates an existing ID in the database to use a new image
* file, leaving the tags and such unchanged. Also removes
* the old image file and thumbnail from the disk.
*/
public function __construct(int $id, Image $image)
{
2020-01-26 13:19:35 +00:00
parent::__construct();
$this->id = $id;
$this->image = $image;
}
2019-02-22 19:57:45 +00:00
}
class ImageReplaceException extends SCoreException
{
2019-02-22 19:57:45 +00:00
}
/**
* Request a thumbnail be made for an image object.
*/
class ThumbnailGenerationEvent extends Event
{
/** @var string */
public $hash;
/** @var string */
2020-06-14 11:05:55 -05:00
public $mime;
/** @var bool */
public $force;
/** @var bool */
public $generated;
/**
* Request a thumbnail be made for an image object
*/
2020-06-14 11:05:55 -05:00
public function __construct(string $hash, string $mime, bool $force=false)
{
2020-01-26 13:19:35 +00:00
parent::__construct();
$this->hash = $hash;
2020-06-14 11:05:55 -05:00
$this->mime = $mime;
$this->force = $force;
$this->generated = false;
}
2019-02-22 19:57:45 +00:00
}
/*
* ParseLinkTemplateEvent:
* $link -- the formatted text (with each element URL Escape'd)
* $text -- the formatted text (not escaped)
2019-02-22 19:57:45 +00:00
* $original -- the formatting string, for reference
* $image -- the image who's link is being parsed
*/
class ParseLinkTemplateEvent extends Event
{
/** @var string */
public $link;
/** @var string */
public $text;
/** @var string */
public $original;
2019-05-28 20:27:23 +01:00
/** @var Image */
public $image;
public function __construct(string $link, Image $image)
{
2020-01-26 13:19:35 +00:00
parent::__construct();
$this->link = $link;
$this->text = $link;
$this->original = $link;
$this->image = $image;
}
public function replace(string $needle, ?string $replace): void
{
2020-02-23 18:12:14 +00:00
if (!is_null($replace)) {
$this->link = str_replace($needle, url_escape($replace), $this->link);
$this->text = str_replace($needle, $replace, $this->text);
}
}
2019-02-22 19:57:45 +00:00
}