151 lines
3 KiB
PHP
151 lines
3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* 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)
|
|
{
|
|
$this->image = $image;
|
|
}
|
|
}
|
|
|
|
class ImageAdditionException extends SCoreException
|
|
{
|
|
public $error;
|
|
|
|
public function __construct(string $error)
|
|
{
|
|
$this->error = $error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* An image is being deleted.
|
|
*/
|
|
class ImageDeletionEvent extends Event
|
|
{
|
|
/** @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)
|
|
{
|
|
$this->image = $image;
|
|
$this->force = $force;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* An image is being replaced.
|
|
*/
|
|
class ImageReplaceEvent extends Event
|
|
{
|
|
/** @var int */
|
|
public $id;
|
|
/** @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)
|
|
{
|
|
$this->id = $id;
|
|
$this->image = $image;
|
|
}
|
|
}
|
|
|
|
class ImageReplaceException extends SCoreException
|
|
{
|
|
/** @var string */
|
|
public $error;
|
|
|
|
public function __construct(string $error)
|
|
{
|
|
$this->error = $error;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Request a thumbnail be made for an image object.
|
|
*/
|
|
class ThumbnailGenerationEvent extends Event
|
|
{
|
|
/** @var string */
|
|
public $hash;
|
|
/** @var string */
|
|
public $type;
|
|
/** @var bool */
|
|
public $force;
|
|
|
|
/** @var bool */
|
|
public $generated;
|
|
|
|
|
|
/**
|
|
* Request a thumbnail be made for an image object
|
|
*/
|
|
public function __construct(string $hash, string $type, bool $force=false)
|
|
{
|
|
$this->hash = $hash;
|
|
$this->type = $type;
|
|
$this->force = $force;
|
|
$this->generated = false;
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* ParseLinkTemplateEvent:
|
|
* $link -- the formatted link
|
|
* $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 $original;
|
|
/** @var Image */
|
|
public $image;
|
|
|
|
public function __construct(string $link, Image $image)
|
|
{
|
|
$this->link = $link;
|
|
$this->original = $link;
|
|
$this->image = $image;
|
|
}
|
|
|
|
public function replace(string $needle, string $replace): void
|
|
{
|
|
$this->link = str_replace($needle, $replace, $this->link);
|
|
}
|
|
}
|