Initial commit. Seems to work
This commit is contained in:
commit
3a575bbe3e
2 changed files with 128 additions and 0 deletions
25
README.md
Normal file
25
README.md
Normal file
|
@ -0,0 +1,25 @@
|
|||
# peertube-cli
|
||||
|
||||
A CLI client for peertube
|
||||
|
||||
## Why?
|
||||
|
||||
JavaScript sucks and i'm not willing to enable it.
|
||||
|
||||
## How?
|
||||
|
||||
`./peertube-cli <search query>`
|
||||
|
||||
If search query is not given, `peertube-cli` will prompt an
|
||||
interactive search.
|
||||
|
||||
## TODO
|
||||
|
||||
* Config file
|
||||
* let user select video player (though config file)
|
||||
* getopt for instance, and maybe video player :^)
|
||||
|
||||
## Bugs
|
||||
|
||||
Sure.
|
||||
|
103
peertube-cli.pl
Normal file
103
peertube-cli.pl
Normal file
|
@ -0,0 +1,103 @@
|
|||
#!/usr/bin/perl
|
||||
|
||||
# peertube-cli
|
||||
# A peertube cli client.
|
||||
# author: qorg11
|
||||
|
||||
use LWP::UserAgent;
|
||||
use JSON;
|
||||
use Term::ReadLine;
|
||||
use Term::ANSIColor;
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
# Objects
|
||||
|
||||
my $json = new JSON;
|
||||
my $ua = new LWP::UserAgent;
|
||||
my $term = new Term::ReadLine("ptcli");
|
||||
|
||||
# Configuration
|
||||
# TODO: config file or something
|
||||
|
||||
our $INSTANCE = "https://vid.qorg11.net";
|
||||
|
||||
# Prototypes
|
||||
|
||||
sub search_video($);
|
||||
sub select_video($);
|
||||
sub get_video_data($);
|
||||
sub play_video($);
|
||||
|
||||
# Main program
|
||||
|
||||
if (!$ARGV[0]) {
|
||||
print <STDERR>, "No argument given\n";
|
||||
my $input = $term->readline("=> ");
|
||||
my $response = search_video($input);
|
||||
my $json_obj = $json->decode($response);
|
||||
my $uuid = &select_video($json_obj);
|
||||
my @selected_video_data = get_video_data($uuid);
|
||||
play_video(\@selected_video_data);
|
||||
|
||||
} else {
|
||||
my $response = search_video(join(" ",@ARGV));
|
||||
my $json_obj = $json->decode($response);
|
||||
my $uuid = &select_video($json_obj);
|
||||
my @selected_video_data = get_video_data($uuid);
|
||||
play_video(\@selected_video_data);
|
||||
}
|
||||
|
||||
# Functions
|
||||
|
||||
sub search_video($) {
|
||||
my $search_string = shift;
|
||||
my $response = $ua->get("$INSTANCE/api/v1/search/videos?search=$search_string");
|
||||
if ($response->{_rc} == 200) {
|
||||
return $response->content;
|
||||
} else {
|
||||
print color('red');
|
||||
return sprintf("ERROR: server returned status code $response->{_rc}\n");
|
||||
}
|
||||
}
|
||||
|
||||
sub select_video($) {
|
||||
my $json_obj = shift;
|
||||
my @videos_data;
|
||||
|
||||
my $total = $json_obj->{total};
|
||||
for (my $i = 0; $i < $total; $i++) {
|
||||
$videos_data[$i] = $json_obj->{data}->[$i];
|
||||
print "$i: " . $videos_data[$i]->{name} . "\n";
|
||||
|
||||
}
|
||||
my $input = $term->readline("=> ");
|
||||
return $videos_data[$input]->{uuid};
|
||||
}
|
||||
|
||||
sub get_video_data($) {
|
||||
my $uuid = shift;
|
||||
my $response = $ua->get("$INSTANCE/api/v1/videos/$uuid");
|
||||
|
||||
if($response->{_rc} == 200) {
|
||||
my $json_obj = $json->decode($response->content);
|
||||
return ($json_obj->{files}->[0]->{fileUrl},
|
||||
$json_obj->{name},
|
||||
$json_obj->{description},
|
||||
$json_obj->{account}->{name});
|
||||
} else {
|
||||
return "error\n";
|
||||
}
|
||||
}
|
||||
|
||||
sub play_video($) {
|
||||
my $ref = $_[0];
|
||||
my $url = $ref->[0];
|
||||
my $title = $ref->[1];
|
||||
my $description = $ref->[2];
|
||||
my $author = $ref->[3];
|
||||
print "Video title: $title\n";
|
||||
print "Description: $description\n\n";
|
||||
print "Video author: $author\n";
|
||||
`mpv $url`;
|
||||
}
|
Loading…
Add table
Reference in a new issue