api: initial migration
This commit is contained in:
parent
13a6d287af
commit
7ccbc3af12
20
lib/PoorBooru.pm
Normal file
20
lib/PoorBooru.pm
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
package PoorBooru;
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::Base "Mojolicious";
|
||||||
|
|
||||||
|
sub startup ($self)
|
||||||
|
{
|
||||||
|
$self->moniker("poorbooru");
|
||||||
|
|
||||||
|
my $config = $self->plugin("Config");
|
||||||
|
$self->secrets($config->{secrets});
|
||||||
|
|
||||||
|
$self->plugin(Mount => {
|
||||||
|
"/api/v0" => $self->home->child("script", "poorbooru-api-v0"),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
29
lib/PoorBooru/API/V0.pm
Normal file
29
lib/PoorBooru/API/V0.pm
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
package PoorBooru::API::V0;
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::Base "Mojolicious";
|
||||||
|
|
||||||
|
use PoorBooru::Schema;
|
||||||
|
|
||||||
|
sub startup ($self)
|
||||||
|
{
|
||||||
|
$self->moniker("poorbooru-api-v0");
|
||||||
|
|
||||||
|
my $config = $self->plugin("Config");
|
||||||
|
$self->secrets($config->{secrets});
|
||||||
|
|
||||||
|
$self->helper(schema => sub {
|
||||||
|
state $schema = PoorBooru::Schema->connect($config->{dsn})
|
||||||
|
});
|
||||||
|
|
||||||
|
my $r = $self->routes;
|
||||||
|
|
||||||
|
$r->get("/meta")->to("meta#index");
|
||||||
|
|
||||||
|
$r->get("/tags")->to("tags#list");
|
||||||
|
$r->get("/tag/:tag_id_or_name")->to("tags#show");
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
25
lib/PoorBooru/API/V0/Controller/Meta.pm
Normal file
25
lib/PoorBooru/API/V0/Controller/Meta.pm
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
package PoorBooru::API::V0::Controller::Meta;
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::Base "Mojolicious::Controller";
|
||||||
|
|
||||||
|
sub index ($self)
|
||||||
|
{
|
||||||
|
return $self->render(json => [
|
||||||
|
{ path => "/meta", verb => "GET" },
|
||||||
|
|
||||||
|
{ path => "/tags", verb => "GET" },
|
||||||
|
{ path => "/tags", verb => "POST" },
|
||||||
|
{ path => "/tag/:tag_id_or_name", verb => "GET" },
|
||||||
|
|
||||||
|
{ path => "/media/:media_id", verb => "GET" },
|
||||||
|
{ path => "/media/download/:media_id", verb => "GET" },
|
||||||
|
|
||||||
|
{ path => "/random/media", verb => "GET" },
|
||||||
|
{ path => "/random/tag", verb => "GET" },
|
||||||
|
]);
|
||||||
|
};
|
||||||
|
|
||||||
|
1;
|
82
lib/PoorBooru/API/V0/Controller/Tags.pm
Normal file
82
lib/PoorBooru/API/V0/Controller/Tags.pm
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
package PoorBooru::API::V0::Controller::Tags;
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::Base "Mojolicious::Controller";
|
||||||
|
|
||||||
|
my $MEDIA_SEARCH_OPTS = {
|
||||||
|
order_by => { -desc => "media_id" },
|
||||||
|
rows => 5,
|
||||||
|
};
|
||||||
|
my $TAGS_COUNT_VIEW_SEARCH_OPTS = {
|
||||||
|
order_by => { -desc => "count" },
|
||||||
|
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_tags = $self->schema->resultset("TagCountView")
|
||||||
|
->search({}, $TAGS_COUNT_VIEW_SEARCH_OPTS)->page($page);
|
||||||
|
my @tags = map +{
|
||||||
|
id => $_->tag_id,
|
||||||
|
name => $_->name,
|
||||||
|
count => $_->count,
|
||||||
|
}, $paged_tags->all;
|
||||||
|
|
||||||
|
return $self->render(json => {
|
||||||
|
pager => _pager_links($self, $paged_tags->pager),
|
||||||
|
tags => \@tags,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
sub show ($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 $tag_id_or_name = $self->stash("tag_id_or_name");
|
||||||
|
my $tag = $self->schema->resultset("Tag")->single([
|
||||||
|
{ tag_id => $tag_id_or_name },
|
||||||
|
{ name => $tag_id_or_name },
|
||||||
|
]);
|
||||||
|
|
||||||
|
return $self->render(
|
||||||
|
json => {error => "Tag not found"},
|
||||||
|
status => 404,
|
||||||
|
) if !defined($tag);
|
||||||
|
|
||||||
|
my $paged_media = $self->schema->resultset("MediaTag")
|
||||||
|
->search({ tag_id => $tag->tag_id }, $MEDIA_SEARCH_OPTS)
|
||||||
|
->page($page);
|
||||||
|
my @media = map { $_->media_id } $paged_media->all;
|
||||||
|
|
||||||
|
return $self->render(json => {
|
||||||
|
id => $tag->tag_id,
|
||||||
|
name => $tag->name,
|
||||||
|
pager => _pager_links($self, $paged_media->pager),
|
||||||
|
media => \@media,
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
1;
|
8
poorbooru-api-v0.conf
Normal file
8
poorbooru-api-v0.conf
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
dsn => "dbi:SQLite:dbname=db/PoorBooru.db",
|
||||||
|
|
||||||
|
secrets => [
|
||||||
|
# Generate with "openssl rand -hex 32".
|
||||||
|
pack("H*", "a0b1..."),
|
||||||
|
],
|
||||||
|
}
|
6
poorbooru.conf
Normal file
6
poorbooru.conf
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
secrets => [
|
||||||
|
# Generate with "openssl rand -hex 32".
|
||||||
|
pack("H*", "a0b1..."),
|
||||||
|
],
|
||||||
|
}
|
10
script/poorbooru
Executable file
10
script/poorbooru
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/env perl
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::File qw(curfile);
|
||||||
|
use lib curfile->dirname->sibling("lib")->to_string;
|
||||||
|
use Mojolicious::Commands;
|
||||||
|
|
||||||
|
Mojolicious::Commands->start_app("PoorBooru");
|
10
script/poorbooru-api-v0
Executable file
10
script/poorbooru-api-v0
Executable file
@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/env perl
|
||||||
|
use v5.36;
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
use Mojo::File qw(curfile);
|
||||||
|
use lib curfile->dirname->sibling("lib")->to_string;
|
||||||
|
use Mojolicious::Commands;
|
||||||
|
|
||||||
|
Mojolicious::Commands->start_app("PoorBooru::API::V0");
|
Loading…
Reference in New Issue
Block a user