2025-01-24 19:16:21 +00:00
#!/bin/bash
2025-02-12 21:31:53 +00:00
#Check for mariadb vs. mysql
dbengine = ""
if [ [ -n $( type mariadb) ] ] ; then
dbengine = "mariadb"
elif [ [ -n $( type mysql) ] ] ; then
dbengine = "mysql"
else
exit
fi
2025-03-05 09:21:37 -06:00
intense_optimizations = ${ 1 :- "0" }
2025-01-24 19:16:21 +00:00
db = "friendica"
tmpfile = "/tmp/sitesdown.txt"
idsdownfile = "/tmp/idsdown.txt"
2025-03-05 09:21:37 -06:00
usrfile = "/tmp/usersdown.txt"
2025-02-02 03:25:37 +00:00
url = friendica.example.net
avatarfolder = /var/www/friendica/avatar
avatarfolderescaped = ${ avatarfolder //// \\ / }
2025-01-24 19:16:21 +00:00
loop_1( ) {
2025-02-12 21:31:53 +00:00
site = $( echo " ${ sites } " | sed -e "s/http[s]*:\/\///g" )
2025-02-24 11:00:06 -06:00
# if [[ "${protocol}" == "apub" ]]; then
# #For ActivityPub sites, we test the well-known Webfinger
# #We also need a valid (known) user for the Webfinger test
# user=$("${dbengine}" "${db}" -N -B -q -e "select \`addr\` from contact where baseurl = \"http://${site}\" or url = \"http://${site}\" or baseurl = \"https://${site}\" or url = \"https://${site}\" limit 1")
# site_test="https://${site}/.well-known/webfinger?resource=acct:${user}"
# #If the return message is in "application/jrd+json" format, the site is still up
# #If the message contains a reference to Cloudflare, we don't add it to the list either, just in case
# if ! grep -q -e "application/jrd+json" -e "HTTP.*200" -e "cloudflare" <(curl -s -L -I -m 30 -X HEAD "${site_test}"); then
# echo "${site}" >>"${tmpfile}"
# echo "Added ${site}"
# fi
# fi
2025-02-12 21:31:53 +00:00
#This is mostly for RSS feeds, we only check whether the site itself is up
2025-02-02 21:15:23 +00:00
#Skip check if the message contains a reference to Cloudflare
2025-02-12 21:31:53 +00:00
if [ [ " ${ protocol } " != "bsky" ] ] ; then
if ! grep -q -e "HTTP.*200" -e "cloudflare" <( curl -s -L -I -m 30 -X HEAD " https:// ${ site } " ) ; then
echo " ${ site } " >>" ${ tmpfile } "
echo " Added ${ site } "
fi
2025-01-24 19:16:21 +00:00
fi
}
loop_2( ) {
2025-01-24 19:34:48 +00:00
echo " Finding users for ${ b } "
2025-02-13 18:57:59 +00:00
" ${ dbengine } " " ${ db } " -N -B -q -e " select \`id\`, \`nick\`, \`baseurl\` from contact c where c.\`id\` not in (select \`id\` from \`contact\` where \`id\` in (select \`contact-id\` from \`group_member\`) or \`id\` in (select \`cid\` from \`user-contact\`) or \`id\` in (select \`uid\` from \`user\`)) and (c.baseurl = \"http:// ${ b } \" or c.baseurl = \"https:// ${ b } \") " | sudo tee -a " ${ idsdownfile } " #&> /dev/null
2025-01-24 19:16:21 +00:00
}
loop_3( ) {
2025-02-01 23:12:02 +00:00
baseurltrimmed = $( echo " ${ baseurl } " | sed -e "s/http[s]*:\/\///g" )
2025-02-02 03:25:37 +00:00
#Find the pictures in the avatar folders and delete them
2025-03-05 09:21:37 -06:00
picturecount = 0
while read -r photo thumb micro; do
2025-02-02 03:25:37 +00:00
#If stored in avatar folder
2025-02-07 16:21:07 +00:00
if grep -v -q " ${ url } /avatar " <( echo " ${ photo } " ) ; then
2025-02-05 14:59:57 +00:00
#if [[ -z "${isavatar}" ]]
2025-02-02 03:25:37 +00:00
phototrimmed = $( echo " ${ photo } " | sed -e " s/https:\/\/ ${ url } \/avatar/ ${ avatarfolderescaped } /g " -e "s/\?ts.*//g" )
rm -rfv " ${ phototrimmed } "
thumbtrimmed = $( echo " ${ thumb } " | sed -e " s/https:\/\/ ${ url } \/avatar/ ${ avatarfolderescaped } /g " -e "s/\?ts.*//g" )
rm -rfv " ${ thumbtrimmed } "
microtrimmed = $( echo " ${ micro } " | sed -e " s/https:\/\/ ${ url } \/avatar/ ${ avatarfolderescaped } /g " -e "s/\?ts.*//g" )
rm -rfv " ${ microtrimmed } "
2025-03-05 09:21:37 -06:00
picturecount = 1
2025-02-02 03:25:37 +00:00
fi
2025-03-05 09:21:37 -06:00
done < <( " ${ dbengine } " " ${ db } " -N -B -q -e " select \`photo\`, \`thumb\`, \`micro\` from \`contact\` where \`id\` = ${ id } " )
postthreadcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " create temporary table tmp_post_thread (select \`uri-id\` from \`post-thread\` where \`owner-id\` = ${ id } or \`author-id\` = ${ id } or \`causer-id\` = ${ id } ); delete h.* from \`post-thread\` h inner join \`tmp_post_thread\` t where h.\`uri-id\` = t.\`uri-id\`; select_row_count(); " || echo 0)
postthreadusercount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " create temporary table tmp_post_thread_user (select \`uri-id\` from \`post-thread-user\` where \`owner-id\` = ${ id } or \`author-id\` = ${ id } or \`causer-id\` = ${ id } ); delete r.* from \`post-thread-user\` r inner join \`tmp_post_thread_user\` t where r.\`uri-id\` = t.\`uri-id\`; select_row_count(); " || echo 0)
postusercount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " create temporary table tmp_post_user (select \`id\` from \`post-user\` where \`owner-id\` = ${ id } or \`author-id\` = ${ id } or \`causer-id\` = ${ id } ); delete u.* from \`post-user\` u inner join \`tmp_post_user\` t where u.\`id\` = t.\`id\`; select_row_count(); " || echo 0)
posttagcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " delete from \`post-tag\` where cid = ${ id } ; select_row_count(); " || echo 0)
postcontentcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " create temporary table tmp_post (select \`uri-id\` from \`post\` where \`owner-id\` = ${ id } or \`author-id\` = ${ id } or \`causer-id\` = ${ id } ); delete p.* from \`post-content\` p inner join \`tmp_post\` t where p.\`uri-id\` = t.\`uri-id\`; select_row_count(); " || echo 0)
postcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " create temporary table tmp_post (select \`uri-id\` from \`post\` where \`owner-id\` = ${ id } or \`author-id\` = ${ id } or \`causer-id\` = ${ id } ); delete p.* from \`post\` p inner join \`tmp_post\` t where p.\`uri-id\` = t.\`uri-id\`; select_row_count(); " || echo 0)
photocount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " delete from \`photo\` where \`contact-id\` = ${ id } ; select_row_count(); " || echo 0)
contactcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " delete from \`contact\` where \`id\` = ${ id } ; select_row_count(); " || echo 0)
apcontactcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " delete from \`apcontact\` where \`uri-id\` = ${ id } ; select_row_count(); " || echo 0)
diasporacontactcount = $( " ${ dbengine } " " ${ db } " -N -B -q -e " delete from \`diaspora-contact\` where \`uri-id\` = ${ id } ; select_row_count(); " || echo 0)
while read -r tmp_picturecount tmp_postthreadcount tmp_postthreadusercount tmp_postusercount tmp_posttagcount tmp_postcontentcount tmp_postcount tmp_photocount tmp_contactcount tmp_apcontactcount tmp_diasporacontactcount; do
picturecount = $(( picturecount + tmp_picturecount))
postthreadcount = $(( postthreadcount + tmp_postthreadcount))
postthreadusercount = $(( postthreadusercount + tmp_postthreadusercount))
postusercount = $(( postusercount + tmp_postusercount))
posttagcount = $(( posttagcount + tmp_posttagcount))
postcontentcount = $(( postcontentcount + tmp_postcontentcount))
postcount = $(( postcount + tmp_postcount))
photocount = $(( photocount + tmp_photocount))
contactcount = $(( contactcount + tmp_contactcount))
apcontactcount = $(( apcontactcount + tmp_apcontactcount))
diasporacontactcount = $(( diasporacontactcount + tmp_diasporacontactcount))
done <" ${ usrfile } "
response_left = $( printf "%s %s@%s " " ${ id } " " ${ nick } " " ${ baseurltrimmed } " )
response = $( printf "%spicture:%s " " ${ response } " " ${ picturecount } " )
response = $( printf "%spost-thread:%s " " ${ response } " " ${ postthreadcount } " )
response = $( printf "%spost-thread-user:%s " " ${ response } " " ${ postthreadusercount } " )
response = $( printf "%spost-user:%s " " ${ response } " " ${ postusercount } " )
response = $( printf "%spost-tag:%s " " ${ response } " " ${ posttagcount } " )
response = $( printf "%spost-content:%s " " ${ response } " " ${ postcontentcount } " )
response = $( printf "%spost:%s " " ${ response } " " ${ postcount } " )
response = $( printf "%sphoto:%s " " ${ response } " " ${ photocount } " )
response = $( printf "%scontact:%s " " ${ response } " " ${ contactcount } " )
response = $( printf "%sapcontact:%s " " ${ response } " " ${ apcontactcount } " )
response = $( printf "%sdiaspora-contact:%s " " ${ response } " " ${ diasporacontactcount } " )
echo " ${ picturecount } " " ${ postthreadcount } ${ postthreadusercount } ${ postusercount } ${ posttagcount } ${ postcontentcount } ${ postcount } ${ photocount } ${ contactcount } ${ apcontactcount } ${ diasporacontactcount } " >" ${ usrfile } "
#Previous line clearance
#Measure length of string, blank only the excess
2025-03-06 09:31:04 -06:00
#Since this string is panned to both sides, we will need to account for two lengths
2025-03-05 09:21:37 -06:00
final_string_length_left = " ${# response_left } "
final_string_length_right = " ${# response } "
final_string_length = $(( final_string_length_left + final_string_length_right))
2025-03-06 09:31:04 -06:00
#The string that will be used to insert the blanks
2025-03-05 09:21:37 -06:00
blank_string = ""
columns_length = " ${ COLUMNS } "
2025-03-06 09:31:04 -06:00
#Account for the case where the string is more than a terminal line long
2025-03-05 09:21:37 -06:00
while [ [ " ${ final_string_length } " -gt " ${ columns_length } " ] ] ; do
columns_length = $(( columns_length + COLUMNS))
2025-02-02 03:25:37 +00:00
done
2025-03-05 09:21:37 -06:00
blank_string_length = $(( columns_length - final_string_length))
2025-03-06 09:31:04 -06:00
#Add enough blank spaces to fill the rest of the line
2025-03-05 09:21:37 -06:00
for ( ( count = 0; count < " ${ blank_string_length } " ; count++) ) ; do
blank_string = $( printf "%s " " ${ blank_string } " )
done
2025-03-06 09:31:04 -06:00
#Add backspaces to align the next output
for ( ( count = 0; count < $(( final_string_length + blank_string_length)) ; count++) ) ; do
response_left = $( printf "\b%s" " ${ response_left } " )
2025-03-05 09:21:37 -06:00
done
2025-03-06 09:31:04 -06:00
response = $( printf "%s%s%s" " ${ response_left } " " ${ blank_string } " " ${ response } " )
2025-03-05 09:21:37 -06:00
printf "%s\r" " ${ response } "
2025-01-24 19:16:21 +00:00
}
#Check if our dependencies are installed
2025-02-05 14:59:57 +00:00
if [ [ -n $( type curl) && -n " ${ dbengine } " && -n $( type " ${ dbengine } " ) && -n $( type date) ] ] ; then
2025-01-24 19:16:21 +00:00
date
2025-03-05 09:21:37 -06:00
if [ [ " ${ intense_optimizations } " -gt 0 ] ] ; then
" ${ dbengine } " " ${ db } " -N -B -q -e "alter table \`contact\` add index if not exists \`contact_baseurl\` (\`baseurl\`)"
" ${ dbengine } " " ${ db } " -N -B -q -e "alter table \`post-user\` add index if not exists \`post_user_id\` (\`author-id\`, \`causer-id\`, \`owner-id\`)"
fi
2025-02-05 14:59:57 +00:00
if [ [ ! -f " ${ tmpfile } " ] ] ; then
2025-01-24 19:16:21 +00:00
echo "Listing sites"
2025-02-12 21:31:53 +00:00
siteslist = $( " ${ dbengine } " " ${ db } " -N -B -q -e "select distinct baseurl, protocol from contact where baseurl != ''" | sort -b -f -n | sed -e "s/http:/https:/g" | uniq -i)
2025-02-13 18:57:59 +00:00
siteslistamount = $( echo " ${ siteslist } " | wc -l)
echo " Amount of unique sites: ${ siteslistamount } "
2025-02-12 21:31:53 +00:00
while read -r sites protocol; do
loop_1 " ${ sites } " " ${ protocol } " &
2025-02-05 14:59:57 +00:00
if [ [ $( jobs -r -p | wc -l) -ge $(( $( getconf _NPROCESSORS_ONLN) * 2 )) ] ] ; then
2025-01-24 19:16:21 +00:00
wait -n
fi
2025-02-12 21:31:53 +00:00
done < <( echo " ${ siteslist } " )
2025-01-24 19:16:21 +00:00
wait
fi
sitesdown = ( )
while read -r line; do
2025-02-02 21:15:23 +00:00
sitesdown += ( " ${ line } " )
2025-02-05 14:59:57 +00:00
done <" ${ tmpfile } "
2025-02-12 21:31:53 +00:00
t = $( sort -n " ${ tmpfile } " | uniq)
echo " ${ t } " >" ${ tmpfile } "
2025-02-13 18:57:59 +00:00
echo " Amount of sites down: ${# sitesdown [@] } / ${ siteslistamount } "
2025-02-05 14:59:57 +00:00
if [ [ ! -f " ${ idsdownfile } " ] ] ; then
for b in " ${ sitesdown [@] } " ; do
2025-01-24 19:34:48 +00:00
loop_2 " ${ b } " &
2025-02-05 14:59:57 +00:00
if [ [ $( jobs -r -p | wc -l) -ge $(( $( getconf _NPROCESSORS_ONLN) / 2 )) ] ] ; then
2025-01-24 19:16:21 +00:00
wait -n
fi
done
wait
2025-02-12 21:31:53 +00:00
u = $( sort -n " ${ idsdownfile } " | uniq)
echo " ${ u } " >" ${ idsdownfile } "
2025-01-24 19:16:21 +00:00
fi
2025-03-05 09:21:37 -06:00
touch " ${ usrfile } "
echo "0 0 0 0 0 0 0 0 0 0 0" >" ${ usrfile } "
while read -r id nick baseurl; do
2025-01-24 19:16:21 +00:00
#The community no longer exists, delete
2025-03-05 09:21:37 -06:00
loop_3 " ${ id } " " ${ nick } " " ${ baseurl } " &
2025-02-05 14:59:57 +00:00
if [ [ $( jobs -r -p | wc -l) -ge $(( $( getconf _NPROCESSORS_ONLN) / 2 )) ] ] ; then
2025-01-24 19:16:21 +00:00
wait -n
fi
wait
2025-02-05 14:59:57 +00:00
done <" ${ idsdownfile } "
2025-03-06 09:31:04 -06:00
printf "\n\r"
2025-02-05 14:59:57 +00:00
rm " ${ tmpfile } " 2>/dev/null
rm " ${ idsdownfile } " 2>/dev/null
2025-03-05 09:21:37 -06:00
rm " ${ usrfile } " 2>/dev/null
" ${ dbengine } " " ${ db } " -N -B -q -e " alter table \`post-thread\` auto_increment = 1; \
alter table \` post-thread-user\` auto_increment = 1; \
alter table \` post-user\` auto_increment = 1; \
alter table \` post-tag\` auto_increment = 1; \
alter table \` post\` auto_increment = 1; \
alter table \` photo\` auto_increment = 1; \
alter table \` contact\` auto_increment = 1"
if [ [ " ${ intense_optimizations } " -gt 0 ] ] ; then
" ${ dbengine } " " ${ db } " -N -B -q -e "alter table \`contact\` drop index \`contact_baseurl\`"
" ${ dbengine } " " ${ db } " -N -B -q -e "alter table \`post-user\` drop index \`post_user_id\`"
fi
2025-01-24 19:16:21 +00:00
date
fi