api: add /media and /media/:media_id
This commit is contained in:
parent
8655e5fa04
commit
0c4ab53586
@ -25,6 +25,9 @@ sub startup ($self)
|
|||||||
$r->get("/tags")->to("tags#list");
|
$r->get("/tags")->to("tags#list");
|
||||||
$r->get("/tag/:tag_id_or_name")->to("tags#show");
|
$r->get("/tag/:tag_id_or_name")->to("tags#show");
|
||||||
|
|
||||||
|
$r->get("/media")->to("media#list");
|
||||||
|
$r->get("/media/:media_id")->to("media#show");
|
||||||
|
|
||||||
$r->get("/random/tag")->to("random#tag");
|
$r->get("/random/tag")->to("random#tag");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
62
lib/PoorBooru/API/V0/Controller/Media.pm
Normal file
62
lib/PoorBooru/API/V0/Controller/Media.pm
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
package PoorBooru::API::V0::Controller::Media;
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::Base "Mojolicious::Controller";
|
||||||
|
|
||||||
|
my $MEDIA_SEARCH_OPTS = {
|
||||||
|
order_by => { -desc => "media_id" },
|
||||||
|
rows => 5,
|
||||||
|
};
|
||||||
|
|
||||||
|
sub _pager_links ($c, $pager)
|
||||||
|
{
|
||||||
|
+{ map +( $_ => ($pager->$_ and
|
||||||
|
$c->url_with->query({page => $pager->$_})) ),
|
||||||
|
qw(first_page previous_page current_page next_page last_page) }
|
||||||
|
}
|
||||||
|
|
||||||
|
sub list ($self)
|
||||||
|
{
|
||||||
|
my $v = $self->validation;
|
||||||
|
my $page = $v->optional("page")->num(1, undef)->param // 1;
|
||||||
|
|
||||||
|
return $self->render(
|
||||||
|
json => {error => "Invalid page number"},
|
||||||
|
status => 400,
|
||||||
|
) if $v->has_error;
|
||||||
|
|
||||||
|
my $paged_media = $self->schema->resultset("Media")
|
||||||
|
->search({}, $MEDIA_SEARCH_OPTS)->page($page);
|
||||||
|
my @media = map +{
|
||||||
|
media_id => $_->media_id,
|
||||||
|
seaweedfs_fid => $_->seaweedfs_fid,
|
||||||
|
}, $paged_media->all;
|
||||||
|
|
||||||
|
return $self->render(json => {
|
||||||
|
pager => _pager_links($self, $paged_media->pager),
|
||||||
|
media => \@media,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
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,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
1;
|
Loading…
Reference in New Issue
Block a user