[core] have extensions react to ImageAdditionEvent, instead of sending ImageAddition and other events in parallel
This commit is contained in:
parent
baf5f38a25
commit
267e176658
5 changed files with 67 additions and 64 deletions
|
@ -301,6 +301,8 @@ abstract class DataHandlerExtension extends Extension
|
||||||
|
|
||||||
public function onDataUpload(DataUploadEvent $event)
|
public function onDataUpload(DataUploadEvent $event)
|
||||||
{
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
if ($this->supported_mime($event->mime)) {
|
if ($this->supported_mime($event->mime)) {
|
||||||
if (!$this->check_contents($event->tmpname)) {
|
if (!$this->check_contents($event->tmpname)) {
|
||||||
// We DO support this extension - but the file looks corrupt
|
// We DO support this extension - but the file looks corrupt
|
||||||
|
@ -324,32 +326,27 @@ abstract class DataHandlerExtension extends Extension
|
||||||
}
|
}
|
||||||
|
|
||||||
$replacement = $this->create_image_from_data(warehouse_path(Image::IMAGE_DIR, $event->hash), $event->metadata);
|
$replacement = $this->create_image_from_data(warehouse_path(Image::IMAGE_DIR, $event->hash), $event->metadata);
|
||||||
send_event(new ImageReplaceEvent($existing, $replacement));
|
send_event(new ImageReplaceEvent($existing, $replacement, $event->metadata));
|
||||||
$event->images[] = $replacement;
|
$event->images[] = $replacement;
|
||||||
if(!empty($event->metadata['source'])) {
|
|
||||||
send_event(new SourceSetEvent($existing, $event->metadata['source']));
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
$image = $this->create_image_from_data(warehouse_path(Image::IMAGE_DIR, $event->hash), $event->metadata);
|
$image = $this->create_image_from_data(warehouse_path(Image::IMAGE_DIR, $event->hash), $event->metadata);
|
||||||
$iae = send_event(new ImageAdditionEvent($image));
|
|
||||||
$event->images[] = $iae->image;
|
|
||||||
$event->merged = $iae->merged;
|
|
||||||
|
|
||||||
if(!empty($event->metadata['tags'])) {
|
$existing = Image::by_hash($image->hash);
|
||||||
if($iae->merged) {
|
if (!is_null($existing)) {
|
||||||
$event->metadata['tags'] = array_merge($iae->image->get_tag_array(), $event->metadata['tags']);
|
$handler = $config->get_string(ImageConfig::UPLOAD_COLLISION_HANDLER);
|
||||||
|
if ($handler == ImageConfig::COLLISION_MERGE) {
|
||||||
|
$image = $existing;
|
||||||
|
} else {
|
||||||
|
throw new UploadException(">>{$existing->id} already has hash {$image->hash}");
|
||||||
}
|
}
|
||||||
send_event(new TagSetEvent($image, $event->metadata['tags']));
|
|
||||||
}
|
|
||||||
if(!empty($event->metadata['source'])) {
|
|
||||||
send_event(new SourceSetEvent($image, $event->metadata['source']));
|
|
||||||
}
|
|
||||||
if (!empty($event->metadata['rating'])) {
|
|
||||||
send_event(new RatingSetEvent($image, $event->metadata['rating']));
|
|
||||||
}
|
|
||||||
if (!empty($event->metadata['locked'])) {
|
|
||||||
send_event(new LockSetEvent($image, $event->metadata['locked']));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ensure $image has a database-assigned ID number
|
||||||
|
// before anything else happens
|
||||||
|
$image->save_to_db();
|
||||||
|
|
||||||
|
$iae = send_event(new ImageAdditionEvent($image, $event->metadata, !is_null($existing)));
|
||||||
|
$event->images[] = $iae->image;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,16 +9,16 @@ namespace Shimmie2;
|
||||||
*/
|
*/
|
||||||
class ImageAdditionEvent extends Event
|
class ImageAdditionEvent extends Event
|
||||||
{
|
{
|
||||||
public User $user;
|
|
||||||
public bool $merged = false;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Inserts a new image into the database with its associated
|
* Inserts a new image into the database with its associated
|
||||||
* information. Also calls TagSetEvent to set the tags for
|
* information.
|
||||||
* this new image.
|
*
|
||||||
|
* @param mixed[] $metadata
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public Image $image,
|
public Image $image,
|
||||||
|
public array $metadata,
|
||||||
|
public bool $merged,
|
||||||
) {
|
) {
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
}
|
}
|
||||||
|
@ -58,10 +58,13 @@ class ImageReplaceEvent extends Event
|
||||||
* Updates an existing ID in the database to use a new image
|
* Updates an existing ID in the database to use a new image
|
||||||
* file, leaving the tags and such unchanged. Also removes
|
* file, leaving the tags and such unchanged. Also removes
|
||||||
* the old image file and thumbnail from the disk.
|
* the old image file and thumbnail from the disk.
|
||||||
|
*
|
||||||
|
* @param mixed[] $metadata
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
public Image $original,
|
public Image $original,
|
||||||
public Image $replacement
|
public Image $replacement,
|
||||||
|
public array $metadata = [],
|
||||||
) {
|
) {
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
}
|
}
|
||||||
|
|
|
@ -122,44 +122,6 @@ class ImageIO extends Extension
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function onImageAddition(ImageAdditionEvent $event)
|
|
||||||
{
|
|
||||||
global $config;
|
|
||||||
|
|
||||||
try {
|
|
||||||
$image = $event->image;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Check for an existing image
|
|
||||||
*/
|
|
||||||
$existing = Image::by_hash($image->hash);
|
|
||||||
if (!is_null($existing)) {
|
|
||||||
$handler = $config->get_string(ImageConfig::UPLOAD_COLLISION_HANDLER);
|
|
||||||
if ($handler == ImageConfig::COLLISION_MERGE || isset($_GET['update'])) {
|
|
||||||
$event->merged = true;
|
|
||||||
$event->image = $existing;
|
|
||||||
return;
|
|
||||||
} else {
|
|
||||||
throw new ImageAdditionException(">>{$existing->id} already has hash {$image->hash}");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// actually insert the info
|
|
||||||
$image->save_to_db();
|
|
||||||
|
|
||||||
send_event(new ThumbnailGenerationEvent($image));
|
|
||||||
|
|
||||||
log_info("image", "Uploaded >>{$image->id} ({$image->hash})");
|
|
||||||
} catch (ImageAdditionException $e) {
|
|
||||||
throw new UploadException($e->error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function onImageDeletion(ImageDeletionEvent $event)
|
|
||||||
{
|
|
||||||
$event->image->delete();
|
|
||||||
}
|
|
||||||
|
|
||||||
public function onCommand(CommandEvent $event)
|
public function onCommand(CommandEvent $event)
|
||||||
{
|
{
|
||||||
if ($event->cmd == "help") {
|
if ($event->cmd == "help") {
|
||||||
|
@ -173,6 +135,12 @@ class ImageIO extends Extension
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function onImageAddition(ImageAdditionEvent $event)
|
||||||
|
{
|
||||||
|
send_event(new ThumbnailGenerationEvent($event->image));
|
||||||
|
log_info("image", "Uploaded >>{$event->image->id} ({$event->image->hash})");
|
||||||
|
}
|
||||||
|
|
||||||
public function onImageReplace(ImageReplaceEvent $event)
|
public function onImageReplace(ImageReplaceEvent $event)
|
||||||
{
|
{
|
||||||
$original = $event->original;
|
$original = $event->original;
|
||||||
|
@ -215,6 +183,11 @@ class ImageIO extends Extension
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function onImageDeletion(ImageDeletionEvent $event)
|
||||||
|
{
|
||||||
|
$event->image->delete();
|
||||||
|
}
|
||||||
|
|
||||||
public function onUserPageBuilding(UserPageBuildingEvent $event)
|
public function onUserPageBuilding(UserPageBuildingEvent $event)
|
||||||
{
|
{
|
||||||
$u_name = url_escape($event->display_user->name);
|
$u_name = url_escape($event->display_user->name);
|
||||||
|
|
|
@ -164,6 +164,13 @@ class Ratings extends Extension
|
||||||
$sb->end_table();
|
$sb->end_table();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function onImageAddition(ImageAdditionEvent $event)
|
||||||
|
{
|
||||||
|
if(!empty($event->metadata['rating'])) {
|
||||||
|
send_event(new RatingSetEvent($event->image, $event->metadata['rating']));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public function onDisplayingImage(DisplayingImageEvent $event)
|
public function onDisplayingImage(DisplayingImageEvent $event)
|
||||||
{
|
{
|
||||||
global $page;
|
global $page;
|
||||||
|
|
|
@ -166,6 +166,29 @@ class TagEdit extends Extension
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
public function onImageAddition(ImageAdditionEvent $event)
|
||||||
|
{
|
||||||
|
if(!empty($event->metadata['tags'])) {
|
||||||
|
if($event->merged) {
|
||||||
|
$event->metadata['tags'] = array_merge($event->image->get_tag_array(), $event->metadata['tags']);
|
||||||
|
}
|
||||||
|
send_event(new TagSetEvent($event->image, $event->metadata['tags']));
|
||||||
|
}
|
||||||
|
if(!empty($event->metadata['source'])) {
|
||||||
|
send_event(new SourceSetEvent($event->image, $event->metadata['source']));
|
||||||
|
}
|
||||||
|
if (!empty($event->metadata['locked'])) {
|
||||||
|
send_event(new LockSetEvent($event->image, $event->metadata['locked']));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function onImageReplace(ImageReplaceEvent $event)
|
||||||
|
{
|
||||||
|
if(!empty($event->metadata['source'])) {
|
||||||
|
send_event(new SourceSetEvent($event->replacement, $event->metadata['source']));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public function onImageInfoSet(ImageInfoSetEvent $event)
|
public function onImageInfoSet(ImageInfoSetEvent $event)
|
||||||
{
|
{
|
||||||
global $page, $user;
|
global $page, $user;
|
||||||
|
|
Reference in a new issue