feature/adding_youtube_support_and_a_js_interpreter #1
@ -16,10 +16,20 @@ get '/' => sub {
|
|||||||
|
|
||||||
post '/api' => sub {
|
post '/api' => sub {
|
||||||
my $c = shift;
|
my $c = shift;
|
||||||
my $url = $c->req->json->{url}
|
my $url = $c->req->json->{url} // (
|
||||||
// ( return $c->render( text => 'Malformed request due missing url json parameter.', status => 400 ) );
|
return $c->render(
|
||||||
|
text => 'Malformed request due missing url json parameter.',
|
||||||
|
status => 400
|
||||||
|
)
|
||||||
|
);
|
||||||
my $render_returned;
|
my $render_returned;
|
||||||
eval { $render_returned = $c->render( json => Peertube::DL::URLHandler::getDownloadDataFromURL($url) ); };
|
eval {
|
||||||
|
$render_returned = $c->render(
|
||||||
|
json => Peertube::DL::URLHandler::getDownloadDataFromURL(
|
||||||
|
$url, { format => 18 }
|
||||||
|
)
|
||||||
|
);
|
||||||
|
};
|
||||||
if ($@) {
|
if ($@) {
|
||||||
return $c->render( text => $@, status => 500 );
|
return $c->render( text => $@, status => 500 );
|
||||||
}
|
}
|
||||||
@ -28,9 +38,15 @@ post '/api' => sub {
|
|||||||
|
|
||||||
post '/proxy_to_get' => sub {
|
post '/proxy_to_get' => sub {
|
||||||
my $c = shift;
|
my $c = shift;
|
||||||
my $url = $c->req->json->{url}
|
my $url = $c->req->json->{url} // (
|
||||||
// ( return $c->render( text => 'Malformed request due missing url json parameter.', status => 400 ) );
|
return $c->render(
|
||||||
die "Not supported url" unless $url =~ s/^https:\/\///r =~ /^storage\.googleapis\.com/;
|
text => 'Malformed request due missing url json parameter.',
|
||||||
|
status => 400
|
||||||
|
)
|
||||||
|
);
|
||||||
|
die "Not supported url"
|
||||||
|
unless ( $url =~ s/^https?:\/\///r =~ /^storage\.googleapis\.com/
|
||||||
|
|| $url =~ s/https?:\/\///r =~ s/\/.*$//r =~ /googlevideo\.com$/ );
|
||||||
my $ua = Peertube::DL::URLHandler::generateUA();
|
my $ua = Peertube::DL::URLHandler::generateUA();
|
||||||
return $c->render(
|
return $c->render(
|
||||||
data => $ua->get($url)->decoded_content,
|
data => $ua->get($url)->decoded_content,
|
||||||
@ -38,8 +54,10 @@ post '/proxy_to_get' => sub {
|
|||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
push @{ app->renderer->paths }, ( Peertube::DL::getDir() . '/Peertube/DL/templates' );
|
push @{ app->renderer->paths },
|
||||||
push @{ app->static->paths }, ( Peertube::DL::getDir() . '/Peertube/DL/public' );
|
( Peertube::DL::getDir() . '/Peertube/DL/templates' );
|
||||||
|
push @{ app->static->paths },
|
||||||
|
( Peertube::DL::getDir() . '/Peertube/DL/public' );
|
||||||
|
|
||||||
my $config = plugin 'Config';
|
my $config = plugin 'Config';
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user