#!/bin/sh
instance=$(jj -i config.json instance)
instance_point="https://$instance/api/v1"
instance_hist='instance.hist'
max_statuses=$(jj -i config.json max_statuses)
default_visibility=$(jj -i config.json default_visibility)
default_content_type=$(jj -i config.json default_content_type)
format_time='+%d.%m.%Y %H:%M:%S'
mkdir -m 711 -p .app_sessions
touch .auth.json
chmod 600 .auth.json
auth="$(jj -i .auth.json "$(echo $instance | sed 's/\./\\\./g')")"
echo "Instance: $instance"
if [ -n "$auth" ]; then
default_curl_opt()
{
curl -s --compressed -H "Authorization: Bearer $auth" $1
}
echo '+Authorized account+'
else
default_curl_opt()
{
curl -s --compressed $1
}
echo 'Please make auth and restart'
fi
auth_api_create_client()
{
if [ ! -e ".app_sessions/$instance" ]; then
curl -s --compressed --url $instance_point/apps \
--data-urlencode 'client_name=pleroma-cli' \
--data-urlencode 'redirect_uris=urn:ietf:wg:oauth:2.0:oob' \
--data-urlencode 'scopes=read write follow' \
--data-urlencode 'website=https://gitea.phreedom.club/localhost_frssoft/pleroma-cli' \
--output .app_sessions/$instance
chmod 600 .app_sessions/$instance
fi
}
auth_api_get_code()
{
auth_api_create_client
client_id=$(jj -i .app_sessions/$instance client_id)
links "https://$instance/oauth/authorize?client_id=$client_id&response_type=code&redirect_uri=urn:ietf:wg:oauth:2.0:oob&scope=read+write+follow"
echo 'Input token-code:'
read pass
}
auth_api_get_token()
{
auth_api_get_code
clear
client_id=$(jj -i .app_sessions/$instance client_id)
client_secret=$(jj -i .app_sessions/$instance client_secret)
token=$(curl -s --compressed --url https://$instance/oauth/token \
--data-urlencode 'grant_type=authorization_code' \
--data-urlencode "client_id=$client_id" \
--data-urlencode "client_secret=$client_secret" \
--data-urlencode "redirect_uri=urn:ietf:wg:oauth:2.0:oob" \
--data-urlencode 'scope=read write follow' \
--data-urlencode "code=$pass" | jj access_token)
jj -p -i .auth.json -v "$token" "$(echo $instance | sed 's/\./\\\./g')" -o .auth.json
}
timeline_api()
{
default_curl_opt "$instance_point/$timeline?limit=$max_statuses&max_id=$1" | tee preload
}
timeline_menu()
{
json=$(timeline_api)
indexator=$(expr $max_statuses - 1)
sub_menu_lvl=1
echo '#EXTM3U' > attachments.m3u8
while [ $sub_menu_lvl -eq 1 ]; do
while [ $indexator -gt 0 ]; do
status=$(echo $json | jj $indexator)
uri=$(echo $status | jj uri)
id_status=$(echo $status | jj id)
dateutc=$(echo $status | jj created_at)
echo "$(date -d $dateutc "$format_time") <$id_status> $uri"
echo $status | jj content | sed -e "s/
]*>/\n/g
; s/
]*>/\n/g ; s/<[^>]*>//g ; s/>*/>/g ; s/<*/> attachments.m3u8 echo "$attachments" >> attachments.m3u8 fi indexator=$(expr $indexator - 1) echo '_____' done menu=$(echo 'Prev\nNext\nShare\nMain menu' | fzy) case $menu in "Prev") indexator=$(expr $max_statuses - 1) echo '#EXTM3U' > attachments.m3u8 clear offset=$(jj -i preload 39.id) json=$(timeline_api $offset) ;; "Next") indexator=$(expr $max_statuses - 1) echo '#EXTM3U' > attachments.m3u8 clear offset=$(jj -i preload 0.id) json=$(timeline_api $offset) ;; "Share") echo 'Input id (s - stop)' sharemode=1 while [ $sharemode -eq 1 ]; do read status_id if [ "$status_id" = 's' ]; then sharemode=0 else share_api_status $status_id echo $http_code fi done ;; "Main menu") sub_menu_lvl=0 ;; esac done } share_api_status() { curl -w "%{http_code}" -X POST -s --compressed -H "Authorization: Bearer $auth" --url $instance_point/statuses/$1/reblog --output /dev/null } write_api_status() { curl -s --compressed -H "Authorization: Bearer $auth" --url $instance_point/statuses \ --data-urlencode "status=$1" \ --data-urlencode "content_type=$content_type" \ --data-urlencode "visibility=$status_visibility" } write_status_menu() { touch tmp_status.md content_type="$default_content_type" status_visibility="$default_visibility" sub_menu_lvl=1 while [ $sub_menu_lvl -eq 1 ]; do clear echo 'Status:' cat tmp_status.md echo '\==========/' echo "Chars: $(cat tmp_status.md | wc -m)" echo "Visiblity: $status_visibility" echo "Content type: $content_type" wrirepostmenu=$(echo "Write\nSend\nChange type\nVisiblity\nMain menu" | fzy) case $wrirepostmenu in "Write") echo > tmp_status.md; $EDITOR tmp_status.md ;; "Send") write_api_status "$(cat tmp_status.md)" | jj -p ;; "Change type") content_type=$(echo 'text/plain\ntext/markdown\ntext/html' | fzy) ;; "Visiblity") status_visibility=$(echo 'public\nunlisted\nlocal\nprivate\ndirect\nlist' | fzy) ;; "Main menu") sub_menu_lvl=0 ;; esac done } notif_menu() { sub_menu_lvl=1 clrnotif='Clear all notifications' json=$(notif_api_get_all) while [ $sub_menu_lvl -eq 1 ]; do clear echo "Notifications: $(echo $json | jj \#)" for i in $(echo $json | jj -l \#.id); do date_utc=$(echo $json | jj \#[id=$i].created_at) date -d "$date_utc" "$format_time" acct=$(echo $json | jj \#[id=$i].account.acct) typenotif=$(echo $json | jj \#[id=$i].type) echo "$typenotif <- $acct" echo $json | jj \#[id=$i].status.pleroma.content.text/plain echo '___' done menu_choice=$(echo "Main menu\nRefresh\n$clrnotif" | fzy) case "$menu_choice" in "Main menu") sub_menu_lvl=0 ;; "Refresh") json=$(notif_api_get_all) ;; "$clrnotif") notif_api_remove_all && json=$(notif_api_get_all) ;; esac done } notif_api_get_all() { default_curl_opt "$instance_point/notifications" | jj -p } notif_api_remove_all() { curl -X POST --compressed -H "Authorization: Bearer $auth" --url $instance_point/notifications/clear } menu_write_status='Write status' menu_timeline='Timelines' notif='Notifications' authmake='Auth' switchinstance='Switch instance' Exit='Exit' while true; do if [ -n "$auth" ]; then main_menu=$(echo "$menu_write_status\n$menu_timeline\n$notif\n$switchinstance\n$Exit" | fzy) else main_menu=$(echo "$menu_write_status\n$menu_timeline\n$notif\n$authmake\n$switchinstance\n$Exit" | fzy) fi case $main_menu in "$menu_write_status") write_status_menu ;; "$menu_timeline") timeline=$(echo 'timelines/home\nfavourites\ntimelines/direct\ntimelines/public' | fzy) timeline_menu ;; "$notif") notif_menu ;; "$clrnotif") notif_api_remove_all ;; "$switchinstance") empty=0 case $(echo 'Recently used\nChoice from list\nManual input' | fzy) in "Recently used") if [ -s $instance_hist ]; then touch $instance_hist && instance=$(cat $instance_hist | fzy) else echo 'No recently used instances...' empty=1 fi ;; "Choice from list") instance=$(jj -l -i config.json public_list_instances | sed 's/"//g' | fzy) ;; "Manual input") echo "Type instance (ex. $instance):" && read instance ;; esac if [ $empty -eq 0 ]; then echo $instance >> $instance_hist cat $instance_hist | sort | uniq | tee $instance_hist 1>>/dev/null export instance export instance_point="https://$instance/api/v1" conf_instance_state=$(echo 'Permanent\nTemporaly' | fzy) if [ "$conf_instance_state" = 'Permanent' ]; then jj -i config.json instance -v $instance -o config.json else echo '' fi clear auth="$(jj -i .auth.json "$(echo $instance | sed 's/\./\\\./g')")" echo "Instance: $instance" if [ -n "$auth" ]; then default_curl_opt() { curl -s --compressed -H "Authorization: Bearer $auth" $1 } echo '+Authorized account+' else default_curl_opt() { curl -s --compressed $1 } echo 'Please make auth and restart' fi fi ;; "$authmake") auth_api_get_token ;; "$Exit") exit 0 ;; esac done