Added channel support

This commit is contained in:
Jaidyn Ann 2016-12-22 19:14:27 -06:00
parent 5ecf3515bd
commit d0585eef1f
8 changed files with 271 additions and 30 deletions

4
INSTALL.md Normal file
View File

@ -0,0 +1,4 @@
Simple. Just move the "shelltube" script along with
the scripts in lib/ into your PATH.
Then-- boom, installed.
Groovy.

23
lib/st-download Executable file
View File

@ -0,0 +1,23 @@
#!/bin/sh
#####################
# Name: st-download.sh
# Date: 2016-12-22
# Lisc: ISC
# Main: jadedctrl
# Desc: No beer and no TV
# make Homer go
# something-something
# Cxu ne?
#####################
if type "wget" &> /dev/null
then
wget -q "$1" -O "$2"
elif type "curl" &> /dev/null
then
curl -s "$1" -o "$2"
else
echo "Please install wget or curl."
sleep 2
exit 1
fi

28
lib/st-video Executable file
View File

@ -0,0 +1,28 @@
#!/bin/sh
#####################
# Name: st-video.sh
# Date: 2016-12-22
# Lisc: ISC
# Main: jadedctrl
# Desc: Does a thing with
# a video-thingy thing
# dsfgbvesrht fd
#####################
if type "vlc" &> /dev/null
then
vlc "${1}"
elif type "mplayer" &> /dev/null
then
mplayer "${1}"
elif type "kaffeine" &> /dev/null
then
kaffeine "${2}"
else
sleep 2
echo "Please install either vlc, mplayer, or kaffeine."
exit 1
fi
# Mi sxatas iom da komputoro
# ... sed, gxi estas tre bona kaj mojosas

156
lib/yt-channel Executable file
View File

@ -0,0 +1,156 @@
#####################
# Name: yt-channel.sh
# Date: 2016-12-22
# Lisc: ISC
# Main: jadedctrl
# Desc: Display a channel's videos
# or details in easy-to-read
# and easy-to-parse results.
#####################
# Usage: yt-channel.sh [-uci] userid||channel
interactive_mode=0
channel_file="/tmp/yt-channel_$RANDOM"
# I really need to work out a better way to take flags.
# This is just awful.
# ... I'll cross that bridge later.
if [ "$1" == "-u" ]
then
type="user"
st-download https://youtube.com/user/$2/videos $channel_file
elif [ "$1" == "-iu" ]
then
output="$3"
interactive_mode=1
type="user"
st-download https://youtube.com/user/$2/videos $channel_file
elif [ "$1" == "-c" ]
then
type="channel"
st-download https://youtube.com/channel/$2/videos $channel_file
elif [ "$1" == "-ic" ]
then
output="$3"
interactive_mode=1
type="channel"
st-download https://youtube.com/channel/$2/videos $channel_file
elif [ "$1" == "-uc" ] || [ -k "$2" ]
then
echo "Usage: yt-channel.sh [-uci] userid||channel [output]"
echo "Make sure to use either the -u flag or the -c flag--"
echo "*not* both! Also, specify a userid or channel name."
exit 1
else
echo "Usage: yt-channel.sh [-uc] userid||channel"
exit 1
fi
function get_input() {
printf "\033[0;32m>>>\033[0m "
read -r n
if [ "$n" == "exit" ]
then
exit
fi
test $n -ge 0 &> /dev/null
if [ $? -gt 1 ]
then
echo "Bad input, mate. Type in a valid number or 'exit'."
get_input
elif [ $n -gt 20 ]
then
echo "Out of range. Type in a valid number or 'exit'."
get_input
elif [ $n -gt 0 ] && [ $n -lt 20 ]
then
sed -n ${n}p $temp_file | sed 's/.*href="\/watch?v=//' | sed 's/".*//' > $output
else
echo "Bad input, mate. Type in a valid number or 'exit'."
get_input
fi
}
row=0
# Now for displaying the search results
temp_file="/tmp/yt-channel_$RANDOM"
grep "href=\"\/watch?v=" $channel_file | grep "title=" | grep -v \
"<span class=\"yt-thumb-simple\"" > $temp_file
item_num=0
cat $temp_file | while IFS='' read -r CUR_LINE
do
item_num=$(($item_num+1))
LINE="$(echo $CUR_LINE | sed 's/<span class=\"yt-badge \" >.*//')"
LINE="$(echo $LINE | sed 's/views<\/li>.*//')"
LINE="$(echo $LINE | sed 's/title="Verified"//')"
if [ $row -eq 1 ]
then
color='\033[1;34m'
color2='\033[1;34m'
row=0
elif [ $row -eq 0 ]
then
color='\033[1;31m'
color2='\033[1;31m'
row=1
fi
if echo "$LINE" | grep "View full playlist" > /dev/null
then
type="Playlist"
printf "${color}$item_num. "
title=$(echo "$LINE" | sed 's/.*title="//' | sed 's/".*//')
items=$(echo "$LINE" | sed 's/.*View full playlist (//' | sed 's/).*//')
echo -e "${color}$title"
echo -e "${color2}$type | $items | $itemid"
else
type="Video"
duration=$(echo "$LINE" | sed 's/.*Duration: //' | sed 's/\..*//')
itemid=$(echo "$LINE" | sed 's/.*href="\/watch?v=//' | sed 's/".*//')
title=$(echo "$LINE" | sed 's/.* title="//' | sed 's/".*//')
if [ $item_num -lt 10 ]
then
printf "${color}$item_num. "
elif [ $item_num -lt 20 ]
then
printf "${color}$item_num. "
else
break
fi
echo -e "${color}$title${color2}"
printf " "
i=0
while [ $i -lt 9 ]
do
i=$((i+1))
char=$(echo $duration | cut -c$i)
if [ -z $char ]
then
printf " "
else
printf "$char"
fi
done
printf " | $itemid\n"
fi
done
if [ $interactive_mode -eq 1 ]
then
get_input
fi
rm $temp_file

2
yt-down.sh → lib/yt-down Normal file → Executable file
View File

@ -43,7 +43,7 @@ function select_option ()
line=$((line+1))
echo "${line}. $i"
done
printf "\033[0;32m>>\033[0m "
printf "\033[0;32m>>>\033[0m "
read -r n
if [ "$n" -le "$line" ];

0
yt-meta.sh → lib/yt-meta Normal file → Executable file
View File

17
yt-search.sh → lib/yt-search Normal file → Executable file
View File

@ -19,7 +19,8 @@ then
query="$(echo "$2" | sed 's/ /+/g')"
output="$3"
else
query="$(echo "$arg" | sed 's/ /+/g')"
interactive_mode=0
query="$(echo "$1" | sed 's/ /+/g')"
fi
function get_input() {
@ -56,13 +57,7 @@ function get_input() {
search_file="/tmp/yt-search_$RANDOM"
if type "wget" &> /dev/null
then
wget -q https://youtube.com/results?search_query=$query -O $search_file
elif type "curl" &> /dev/null
then
curl -s https://youtube.com/results?search_query=$query -o $search_file
fi
st-download https://youtube.com/results?search_query=$query $search_file
# Now for displaying the search results
temp_file="/tmp/yt-result_$RANDOM"
@ -113,8 +108,6 @@ do
author=$(echo "$LINE" | sed 's/.*\/user\///' | sed 's/".*//')
fi
if [ $interactive_mode -eq 1 ]
then
if [ $item_num -lt 10 ]
then
printf "${color}$item_num. "
@ -150,13 +143,9 @@ do
fi
done
printf " | $itemid\n"
fi
done
if [ $interactive_mode -eq 1 ]
then
get_input
fi
rm $temp_file

61
shelltube.sh → shelltube Normal file → Executable file
View File

@ -1,3 +1,5 @@
#!/bin/sh
####################
# Name: shelltube.sh
# Date: 2016-12-11
@ -7,9 +9,33 @@
# avoids the YT API.
#####################
# Roadmap:
# v1.0 - [ ] Playlist support
# [X] Channel support
# [ ] Audio dl/stream
# [ ] Show related videos
# [ ] Channel & Playlist search
# [ ] Search filters
# [ ] Search & Channel sort-by
# [ ] Config video player, etc
# [ ] Overall better interface
# [ ] Cli args as commands
function search() {
output="/tmp/yt-search-$RANDOM"
sh yt-search.sh -i "$1" $output
yt-search -i "$1" $output
selected_video=$(cat $output)
metadata
}
function channel() {
output="/tmp/yt-channel-$RANDOM"
if echo "$1" | grep "^UC" > /dev/null
then
yt-channel -ic "$1" $output
else
yt-channel -iu "$1" $output
fi
selected_video=$(cat $output)
metadata
}
@ -19,22 +45,22 @@ function interactive() {
}
function about() {
echo -e "\033[0;35mShelltube v0.3"
echo -e "\033[0;35mShelltube v0.4"
echo -e "\033[0;32mDesc: \033[0;34mYT client written in shell."
echo -e "\033[0;32mMain: \033[0;34mjadedml@openmailbox.org"
echo -e "\033[0;32mLisc: \033[0;34mISC; yt-down.sh & yt-stream.sh GPLv2\033[0m"
echo -e "\033[0;32mLisc: \033[0;34mISC; yt-down GPLv2\033[0m"
}
function metadata() {
sh yt-meta.sh "$selected_video"
yt-meta "$selected_video"
}
function download() {
sh yt-down.sh "$selected_video"
yt-down "$selected_video"
}
function stream() {
sh yt-down.sh -s "$selected_video"
yt-down -s "$selected_video"
}
function get_input() {
@ -52,9 +78,13 @@ function get_input() {
then
search "$(echo "$n" | sed 's^/^^')"
interactive
elif echo "$n" | grep "^/ " > /dev/null
elif echo "$n" | grep "^channel " > /dev/null
then
search "$(echo "$n" | sed 's^/ ^^')"
channel "$(echo "$n" | sed 's/channel //')"
interactive
elif echo "$n" | grep "^chan " > /dev/null
then
channel "$(echo "$n" | sed 's/chan //')"
interactive
elif echo "$n" | grep "^video " > /dev/null
then
@ -62,7 +92,7 @@ function get_input() {
then
selected_video="$(echo "$n" | sed 's/.*watch?v=//')"
else
selected_video="$(echo "$n" | sed 's/sel //')"
selected_video="$(echo "$n" | sed 's/video //')"
fi
metadata
interactive
@ -76,6 +106,16 @@ function get_input() {
fi
metadata
interactive
elif echo "$n" | grep "^url " > /dev/null
then
if echo "$n" | grep "youtube.com"
then
selected_video="$(echo "$n" | sed 's/.*watch?v=//')"
else
selected_video="$(echo "$n" | sed 's/url //')"
fi
metadata
interactive
elif [ "$n" == "download" ] || [ "$n" == "dl" ]
then
download
@ -113,8 +153,9 @@ function help() {
echo "help | ? Display this message."
echo "metadata | md Display selected video's metadata."
echo "search | / Perform a search."
echo "channel | chan Show newest videos of a channel."
echo "stream | str Stream the selected video."
echo "video | sel Select video based on URL or ID."
echo "video | sel | url Select video based on URL or ID."
echo "Note about usage:"
echo "Both 'video ID; download' and 'download ID' are valid."
echo "You don't need to select a video to run commands on it,"