diff --git a/lib/PoorBooru/API/V0.pm b/lib/PoorBooru/API/V0.pm index ce702ed..1f1fc50 100644 --- a/lib/PoorBooru/API/V0.pm +++ b/lib/PoorBooru/API/V0.pm @@ -32,6 +32,7 @@ sub startup ($self) $r->get("/media")->to("media#list")->name("media_list"); $r->get("/media/:media_id")->to("media#show")->name("media_show"); + $r->get("/media/tags/:media_id")->to("media#tags")->name("media_tags"); $r->get("/random/tag")->to("random#tag")->name("tag_random"); $r->get("/random/media")->to("random#media")->name("media_random"); diff --git a/lib/PoorBooru/API/V0/Controller/Media.pm b/lib/PoorBooru/API/V0/Controller/Media.pm index 6aa40a9..d892561 100644 --- a/lib/PoorBooru/API/V0/Controller/Media.pm +++ b/lib/PoorBooru/API/V0/Controller/Media.pm @@ -41,6 +41,25 @@ sub list ($self) }; sub show ($self) +{ + my $media_id = $self->stash("media_id"); + my $media = $self->schema->resultset("Media") + ->single({ media_id => $media_id }); + + return $self->render( + json => {error => "Media not found"}, + status => 404, + ) if !defined($media); + + return $self->render(json => { + id => $media->media_id, + name => $media->filename, + download => $media->seaweedfs_fid, + content_type => $media->content_type, + }); +}; + +sub tags ($self) { my $v = $self->validation; my $page = $v->optional("page")->num(1, undef)->param // 1; @@ -65,10 +84,6 @@ sub show ($self) my @tags = map { $_->tag_name } $paged_media_tags->all; return $self->render(json => { - id => $media->media_id, - name => $media->filename, - download => $media->seaweedfs_fid, - content_type => $media->content_type, tags => [ @tags ], pager => { $self->pager($paged_media_tags->pager) }, }); diff --git a/lib/PoorBooru/API/V0/Controller/Meta.pm b/lib/PoorBooru/API/V0/Controller/Meta.pm index ae8e0c7..b5e97c9 100644 --- a/lib/PoorBooru/API/V0/Controller/Meta.pm +++ b/lib/PoorBooru/API/V0/Controller/Meta.pm @@ -13,8 +13,9 @@ sub index ($self) { path => "/tags", verb => "GET" }, { path => "/tag/:tag_id_or_name", verb => "GET" }, - { path => "/media", verb => "GET" }, - { path => "/media/:media_id", verb => "GET" }, + { path => "/media", verb => "GET" }, + { path => "/media/:media_id", verb => "GET" }, + { path => "/media/tags/:media_id", verb => "GET" }, { path => "/random/media", verb => "GET" }, { path => "/random/tag", verb => "GET" },