Compare commits

..

No commits in common. "eefc247b649ea9e9b4fe3d0515e4481f8f7fe539" and "6be73701cd248ddc844dd3ee4625fc88c58da903" have entirely different histories.

View file

@ -4,21 +4,20 @@ instance=$(jj -i config.json instance)
ordering='title' ordering='title'
default_player_command='mpv --no-vid --no-ytdl --network-timeout=30' default_player_command='mpv --no-vid --no-ytdl --network-timeout=30'
instance_point="https://$instance/api/v1"
funkwhale_api_check_api_limits() funkwhale_api_check_api_limits()
{ {
curl -s --compressed "$instance_point/rate-limit/" | jj -p curl -s --compressed "https://$instance/api/v1/rate-limit/" | jj -p
} }
funkwhale_api_get_tracks() funkwhale_api_get_tracks()
{ {
get_json=$(curl -s --compressed "$instance_point/tracks?ordering=$ordering&playable=true&page=$1&tag=$tag" 2>&1 | tee preload) get_json=$(curl -s --compressed "https://$instance/api/v1/tracks?ordering=$ordering&playable=true&page=$1&tag=$tag" 2>&1 | tee preload)
jj -i preload -l 'results.#.uploads.0.listen_url' | sed 's/"//g' jj -i preload -l 'results.#.uploads.0.listen_url' | sed 's/"//g'
} }
funkwhale_api_get_tracks_from_channel() funkwhale_api_get_tracks_from_channel()
{ {
track_list=$(curl -s --compressed "$instance_point/tracks?channel=$1&playable=true&include_channels=true") track_list=$(curl -s --compressed "https://$instance/api/v1/tracks?channel=$1&playable=true&include_channels=true")
echo "Loaded $(echo $track_list | jj count) podcasts" echo "Loaded $(echo $track_list | jj count) podcasts"
echo $track_list | jj -l results.#.title echo $track_list | jj -l results.#.title
listen_urls=$(echo $track_list | jj -l results.#.listen_url | sed 's/"//g') listen_urls=$(echo $track_list | jj -l results.#.listen_url | sed 's/"//g')
@ -32,7 +31,7 @@ funkwhale_api_get_tracks_from_channel()
funkwhale_get_podcasts_artists() funkwhale_get_podcasts_artists()
{ {
echo 'Loading podcast artists...' echo 'Loading podcast artists...'
curl -s --compressed --output preload "$instance_point/artists?ordering=-creation_date&playable=true&include_channels=true&content_category=podcast&page=$1" curl -s --compressed --output preload "https://$instance/api/v1/artists?ordering=-creation_date&playable=true&include_channels=true&content_category=podcast&page=$1"
counter=0 counter=0
count_artists=$(jj -i preload count) count_artists=$(jj -i preload count)
echo "$count_artists avalaible" echo "$count_artists avalaible"
@ -63,8 +62,8 @@ load_tracks_to_playlist()
echo "https://$instance$i\n" >> playlist.m3u8 echo "https://$instance$i\n" >> playlist.m3u8
done done
count_tracks_results=$(jj -i preload 'results.#') count_tracks_results=$(jj -i preload 'results.#')
if [ -z $count_tracks_results ] || [ $count_tracks_results -eq 0 ]; then if [ -z $count_tracks_results ]; then
echo 'Error: Page empty or connection error' echo 'Error: Page empty or 500 Internal Server Error'
else else
echo "Loaded $count_tracks_results tracks" echo "Loaded $count_tracks_results tracks"
fi fi
@ -74,13 +73,7 @@ get_all_avalaible_count_tracks()
{ {
funkwhale_api_get_tracks 1 1>> /dev/null funkwhale_api_get_tracks 1 1>> /dev/null
count_all_tracks=$(jj -i preload -l count) count_all_tracks=$(jj -i preload -l count)
if [ -z $count_all_tracks ]; then
echo 'Error: Connection error or API limit expired'
elif [ $count_all_tracks -eq 0 ]; then
echo 'Error: No tracks'
else
echo "Tracks avalaible on $instance: $count_all_tracks\n" echo "Tracks avalaible on $instance: $count_all_tracks\n"
fi
} }
get_all_avalaible_count_tracks get_all_avalaible_count_tracks
@ -95,8 +88,7 @@ Exit='Exit'
while true; do while true; do
choice=$(echo "$downloadtrackspls\n$startplayer\n$podcasts\n$changepod\n$checkapilimits\n$Exit" | fzy) choice=$(echo "$downloadtrackspls\n$startplayer\n$podcasts\n$changepod\n$checkapilimits\n$Exit" | fzy)
case "$choice" in if [ "$choice" = "$downloadtrackspls" ]; then
"$downloadtrackspls")
echo 'Order by (prefix - is DESC ordering):' echo 'Order by (prefix - is DESC ordering):'
ordering=$(echo 'title\n-title\ncreation_date\n-creation_date\nrelease_date\n-release_date\nrandom' | fzy) ordering=$(echo 'title\n-title\ncreation_date\n-creation_date\nrelease_date\n-release_date\nrandom' | fzy)
export ordering export ordering
@ -108,29 +100,21 @@ case "$choice" in
export tag export tag
echo 'Enter page number: ' echo 'Enter page number: '
read page read page
load_tracks_to_playlist $page ;; load_tracks_to_playlist $page
elif [ "$choice" = "$startplayer" ]; then
$default_player_command playlist.m3u8
"$startplayer") elif [ "$choice" = "$podcasts" ]; then
$default_player_command playlist.m3u8 ;;
"$podcasts")
echo 'Enter page number: ' echo 'Enter page number: '
read page read page
funkwhale_get_podcasts_artists $page ;; funkwhale_get_podcasts_artists $page
elif [ "$choice" = "$changepod" ]; then
"$changepod")
if [ 'Choice from list' = "$(echo 'Choice from list\nManual input' | fzy)" ]; then if [ 'Choice from list' = "$(echo 'Choice from list\nManual input' | fzy)" ]; then
instance=$(jj -l -i config.json public_list_instances | sed 's/"//g' | fzy) instance=$(jj -l -i config.json public_list_instances | sed 's/"//g' | fzy)
else else
echo "Type instance (ex. $instance):" echo "Type instance (ex. $instance):"
read instance read instance
fi fi
export instance export instance
export instance_point="https://$instance/api/v1"
conf_instance_state=$(echo 'Permanent\nTemporaly' | fzy) conf_instance_state=$(echo 'Permanent\nTemporaly' | fzy)
if [ "$conf_instance_state" = 'Permanent' ]; then if [ "$conf_instance_state" = 'Permanent' ]; then
jj -i config.json instance -v $instance -o config.json jj -i config.json instance -v $instance -o config.json
@ -138,14 +122,10 @@ case "$choice" in
echo '' echo ''
fi fi
clear clear
get_all_avalaible_count_tracks ;; get_all_avalaible_count_tracks
elif [ "$choice" = "$checkapilimits" ]; then
funkwhale_api_check_api_limits | more
"$checkapilimits") elif [ "$choice" = "$Exit" ]; then
funkwhale_api_check_api_limits | more ;; exit 0
fi
"$Exit")
exit 0 ;;
esac
done done