Adding a little web still a little ugly to be able to download videos without using the command line.

This commit is contained in:
sergiotarxz 2020-12-29 06:33:37 +01:00
parent b5488d5503
commit 78cbca95b7
Signed by: sergiotarxz
GPG Key ID: E5903508B6510AC2
6 changed files with 180 additions and 0 deletions

View File

@ -1,6 +1,7 @@
.proverc .proverc
AUTHORS AUTHORS
bin/peertube-dl bin/peertube-dl
bin/peertube-dl-web.pl
cpanfile cpanfile
lib/Peertube/DL/Downloaders.pm lib/Peertube/DL/Downloaders.pm
lib/Peertube/DL/URLHandler.pm lib/Peertube/DL/URLHandler.pm
@ -9,6 +10,9 @@ lib/Peertube/DL/Utils.pm
LICENSE LICENSE
Makefile.PL Makefile.PL
MANIFEST This list of files MANIFEST This list of files
public/css/index.css
public/index.html
public/js/peertube-dl-web.js
README.md README.md
t/00-use_ok.t t/00-use_ok.t
t/downloaders/animeflv_example_response.html t/downloaders/animeflv_example_response.html

36
bin/peertube-dl-web.pl Normal file
View File

@ -0,0 +1,36 @@
use Mojolicious::Lite -signatures;
use Peertube::DL::URLHandler;
get '/' => sub {
my $c = shift;
return $c->redirect_to('index.html');
};
post '/api' => sub {
my $c = shift;
my $url = $c->req->json->{url}
// ( return $c->render( text => 'Malformed request due missing url json parameter.', status => 400 ) );
my $render_returned;
eval { $render_returned = $c->render( json => Peertube::DL::URLHandler::getDownloadDataFromURL($url) ); };
if ($@) {
return $c->render( text => $@, status => 500 );
}
return $render_returned;
};
post '/proxy_to_get' => sub {
my $c = shift;
my $url = $c->req->json->{url}
// ( return $c->render( text => 'Malformed request due missing url json parameter.', status => 400 ) );
die "Not supported url" unless $url =~ s/^https:\/\///r =~ /^storage\.googleapis\.com/;
my $ua = Peertube::DL::URLHandler::generateUA();
return $c->render(
data => $ua->get($url)->decoded_content,
format => 'bin'
);
};
push @{ app->renderer->paths }, ('./templates');
push @{ app->static->paths }, ('./public');
app->start;

39
public/css/index.css Normal file
View File

@ -0,0 +1,39 @@
body {
height: 90%;
}
a {
color: blue;
}
a:hover {
text-decoration: underline;
}
#video-container {
display: none;
background: white;
position: fixed;
top: 50%;
left: 50%;
height: 100%;
width: 100%;
transform: translate(-50%, -50%);
border: black 1px solid;
}
.video-container-bar {
display: flex;
justify-content: right;
}
#close-and-reset-video-container {
margin-top: 0.25rem;
margin-right: 0.25rem;
border: 1px solid black;
}
#close-and-reset-video-container:hover {
background: black;
color: white;
}

19
public/index.html Normal file
View File

@ -0,0 +1,19 @@
<html>
<head>
<script src="js/peertube-dl-web.js"></script>
<link rel="stylesheet" href="css/index.css"></script>
</head>
<body>
<form id="download-form">
<input type="text" id="download-form-url" placeholder="Introduce the url you want to download."/>
<button id="download-form-button" >Fetch from api</button>
</form>
<div id="video-container">
<div class="video-container-bar">
<a id="close-and-reset-video-container">X</a>
</div>
<video id="video"></video>
<a id="download-video">Download</a>
</div>
</body>
</html>

View File

@ -0,0 +1,81 @@
"use strict";
let downloadFormButton;
let videoContainer;
let closeAndResetVideoContainer;
let downloadFormUrl;
let downloadVideo;
let downloadForm;
let video;
function downloadFormButtonHandler(event) {
event.preventDefault();
getRealURL(downloadFormUrl.value).then( (response) => {
video.src = response.url;
videoContainer.style.display = 'block';
generateBlobVideo(response.url).then( blob => {
downloadVideo.href = URL.createObjectURL(blob);
downloadVideo.download = response.filename;
});
});
}
function downloadFormHandler(event) {
downloadFormButtonHandler(event);
}
async function generateBlobVideo(url) {
const blob = await fetch(url, {
mode: 'cors',
})
.then(res => res.blob())
.catch( err => generateBlobVideoByProxy(url) );
return blob;
}
async function generateBlobVideoByProxy(url) {
const blob = await fetch( '/proxy_to_get', {
method: 'POST',
mode: 'cors',
cache: 'no-cache',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({url: url}),
}
).then(res => res.blob());
return blob;
}
async function getRealURL(url) {
const response = await fetch('/api', {
method: 'POST',
mode: 'cors',
cache: 'no-cache',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({url: url}),
});
return response.json();
}
function closeAndResetVideoContainerHandler(event) {
event.preventDefault();
videoContainer.style.display = 'none';
}
window.addEventListener('load', (event) => {
downloadFormButton = document.querySelector('#download-form-button');
downloadForm = document.querySelector('#download-form');
videoContainer = document.querySelector('#video-container');
video = document.querySelector('#video');
downloadFormUrl = document.querySelector('#download-form-url');
downloadVideo = document.querySelector('#download-video');
closeAndResetVideoContainer = document.querySelector('#close-and-reset-video-container');
downloadFormButton.addEventListener('click', downloadFormButtonHandler);
downloadForm.addEventListener('submit', downloadFormHandler);
closeAndResetVideoContainer.addEventListener('click', closeAndResetVideoContainerHandler);
});

View File

@ -32,6 +32,7 @@ use JSON;
get => sub { get => sub {
my $self = shift; my $self = shift;
my $url = shift; my $url = shift;
say STDERR $url;
$gocdn_url = $url; $gocdn_url = $url;
return $gocdn_response; return $gocdn_response;
} }