From d0faacb85a2b963d021477603d7838b923d6ce7b Mon Sep 17 00:00:00 2001 From: qorg11 Date: Wed, 3 Nov 2021 19:53:19 +0100 Subject: [PATCH] Added :s and :i option :s allows you to perform another search without having to restart peertube-cli :i allows you to change the instance you're searching it withotu having to restart peertube-cli. It will perform your last search automatically. So if you want to change something you'll have to use :s --- peertube-cli.pl | 50 ++++++++++++++++++++++++++++++++----------------- 1 file changed, 33 insertions(+), 17 deletions(-) diff --git a/peertube-cli.pl b/peertube-cli.pl index ffbe7a7..8b6359b 100755 --- a/peertube-cli.pl +++ b/peertube-cli.pl @@ -14,6 +14,7 @@ use warnings; use strict; our %config; +my $input; # Objects @@ -30,7 +31,7 @@ do $conf_path or die "Could not load configuration: $!"; # Prototypes -sub search_video($$); +sub search_video($$$); sub select_video($); sub get_video_data($); sub play_video($); @@ -47,13 +48,16 @@ GetOptions( if (!$ARGV[0]) { print "No argument given\n"; - my $input = $term->readline("=> "); + $input = $term->readline("=> "); my $response; my $uuid = -1; my @selected_video_data; - while($uuid == -1) { - $response = search_video($input, $counter); + while ($uuid == -1) { + $response = search_video($config{instance}, $input, $counter); + if ($response eq "-1") { + print colored['bold red'], "ERROR\n"; + } my $json_obj = $json->decode($response); $uuid = &select_video($json_obj); @selected_video_data = get_video_data($uuid); @@ -65,10 +69,12 @@ if (!$ARGV[0]) { my $response; my $uuid = -1; my @selected_video_data; - while($uuid == -1) { - $response = search_video(join("",@ARGV), $counter); - if($response eq "-1") { + $input = join("",@ARGV); + while ($uuid == -1) { + $response = search_video($config{instance}, $input, $counter); + if ($response eq "-1") { print colored['bold red'], "ERROR\n"; + die $!; } my $json_obj = $json->decode($response); $uuid = &select_video($json_obj); @@ -80,12 +86,14 @@ if (!$ARGV[0]) { # Functions -sub search_video($$) { - my ($search_string, $counter) = @_; - my $response = $ua->get("$config{instance}/api/v1/search/videos?search=$search_string&count=25&start=$counter"); +sub search_video($$$) { + my ($instance, $search_string, $counter) = @_; + print $instance . "\n"; + my $response = $ua->get("$instance/api/v1/search/videos?search=$search_string&count=25&start=$counter"); if ($response->{_rc} == 200) { return $response->content; } else { + print $response->content; return -1; } } @@ -105,20 +113,26 @@ sub select_video($) { "--- " . colored(['green'], $videos_data[$i]->{account}->{name}), ); } - my $input = $term->readline("=> "); - if ($input eq "n" || $input eq "N") { + my $prompt_input = $term->readline("=> "); + if ($prompt_input eq "n" || $prompt_input eq "N") { $counter += 25; return -1; - } - elsif ($input eq "p" || $input eq "P") { + } elsif ($prompt_input eq "p" || $prompt_input eq "P") { $counter -= 25; return -1; - } elsif($input eq ":h") { + } elsif ($prompt_input eq ":h") { &help_prompt(); return -1; - } + } elsif($prompt_input =~ /^:s/) { + $prompt_input =~ s/^:s //; + return -1; + } elsif($prompt_input =~ /^:i/) { + $config{instance} = $prompt_input; + $config{instance} =~ s/^:i //; + return -1; +} - return $videos_data[$input]->{uuid}; + return "$videos_data[$input]->{uuid}"; } sub get_video_data($) { @@ -152,6 +166,8 @@ sub help_prompt() { print "n: next page\n"; print "p: previous page\n"; print ":h show this\n"; + print ":s search for something else\n"; + print ":i change instance\n"; print "Press enter to continue\n"; ; }