Astroport.ONE/20h12.process.sh

198 lines
6.8 KiB
Bash
Raw Permalink Normal View History

#!/bin/bash
########################################################################
# Version: 0.4
# License: AGPL-3.0 (https://choosealicense.com/licenses/agpl-3.0/)
########################################################################
MY_PATH="`dirname \"$0\"`" # relative
2024-02-11 19:46:02 +01:00
MY_PATH="`( cd \"${MY_PATH}\" && pwd )`" # absolutized and normalized
. "${MY_PATH}/tools/my.sh"
2022-09-12 11:36:39 +02:00
start=`date +%s`
2022-12-29 14:51:05 +01:00
echo "20H12 (♥‿‿♥) $(hostname -f) $(date)"
2022-11-17 13:15:23 +01:00
espeak "Ding" > /dev/null 2>&1
########################################################################
## IPFS DAEMON STATUS
2023-04-14 17:42:58 +02:00
LOWMODE=$(sudo systemctl status ipfs | grep disabled) ## IPFS DISABLED - START ONLY FOR SYNC -
2024-01-12 21:04:18 +01:00
[[ ! $(netstat -tan | grep 5001 | grep LISTEN) ]] && LOWMODE="NO 5001" ## IPFS IS STOPPED
[[ ! $isLAN ]] && LOWMODE="" ## LOWMODE ONLY FOR LAN STATION
2024-02-16 13:07:53 +01:00
########################################################################
2024-03-13 14:14:34 +01:00
## CHECK IF IPFS NODE IS RESPONDING (ipfs name resolve ?)
########################################################################
2024-03-05 02:30:21 +01:00
ipfs --timeout=30s swarm peers 2>/dev/null > ~/.zen/tmp/ipfs.swarm.peers
[[ ! -s ~/.zen/tmp/ipfs.swarm.peers || $? != 0 ]] \
&& echo "---- SWARM COMMUNICATION BROKEN / RESTARTING IPFS DAEMON ----" \
&& sudo systemctl restart ipfs \
2024-03-05 02:30:21 +01:00
&& sleep 60
2024-02-16 13:07:53 +01:00
2024-01-19 15:48:21 +01:00
floop=0
while [[ ! $(netstat -tan | grep 5001 | grep LISTEN) ]]; do
sleep 10
2024-01-22 17:45:05 +01:00
((floop++)) && [ $floop -gt 36 ] \
2024-01-19 15:48:21 +01:00
&& echo "ERROR. IPFS daemon not restarting" \
2024-02-11 19:46:02 +01:00
&& ${MY_PATH}/tools/mailjet.sh "support@qo-op.com" "/tmp/20h12.log" "IPFS RESTART ERROR 20H12" \
2024-01-22 17:45:05 +01:00
&& exit 1
2024-01-19 15:48:21 +01:00
done
2024-02-16 13:07:53 +01:00
########################################################################
2024-02-15 14:53:26 +01:00
# show ZONE.sh cache of the day
2024-02-21 18:25:53 +01:00
echo "TODAY UPlanet landings"
ls ~/.zen/tmp/ZONE_* 2>/dev/null
2024-02-15 14:53:26 +01:00
########################################################################
## REMOVE TMP BUT KEEP swarm, flashmem and coucou
2024-01-19 15:48:21 +01:00
mv ~/.zen/tmp/swarm ~/.zen/swarm
mv ~/.zen/tmp/coucou ~/.zen/coucou
mv ~/.zen/tmp/flashmem ~/.zen/flashmem
2024-01-19 15:48:21 +01:00
rm -Rf ~/.zen/tmp/*
mv ~/.zen/swarm ~/.zen/tmp/swarm
mv ~/.zen/coucou ~/.zen/tmp/coucou
mv ~/.zen/flashmem ~/.zen/tmp/flashmem
2024-01-19 15:48:21 +01:00
########################################################################
2024-03-15 10:50:46 +01:00
### DELAY _12345 ASTROPORT DURING 20H12 UPDATE ###
if [[ "${LOWMODE}" == "" ]]; then
### NOT REFRESHING SWARM
MOATS=$(date -u +"%Y%m%d%H%M%S%4N")
MOATS_plus_5_hours=$(date -d "now + 5 hours" +"%Y%m%d%H%M%S%4N")
mkdir ~/.zen/tmp/${IPFSNODEID}
echo ${MOATS_plus_5_hours} > ~/.zen/tmp/${IPFSNODEID}/_MySwarm.moats
echo 9000 > ~/.zen/tmp/random.sleep
else
# REFRESHING SWARM
echo 0 > ~/.zen/tmp/${IPFSNODEID}/_MySwarm.moats
curl -s "http://127.0.0.1:12345"
sleep 300 ## WAIT FOR 5MN
fi
########################################################################
2024-01-19 15:48:21 +01:00
## UPDATE G1BILLETS code
2023-04-08 15:20:16 +02:00
[[ -s ~/.zen/G1BILLET/G1BILLETS.sh ]] \
&& cd ~/.zen/G1BILLET/ && git pull \
&& rm -Rf ~/.zen/G1BILLET/tmp/*
2023-04-05 14:48:08 +02:00
########################################################################
2024-01-19 15:48:21 +01:00
## UPDATE Astroport.ONE code
2024-02-16 13:07:53 +01:00
cd ${MY_PATH}/
2022-09-14 14:29:19 +02:00
git pull
2023-04-05 14:48:08 +02:00
########################################################################
2022-12-18 21:26:57 +01:00
## Updating yt-dlp
2024-02-11 19:46:02 +01:00
${MY_PATH}/youtube-dl.sh
2022-12-18 21:26:57 +01:00
sudo youtube-dl -U
########################################################################
2024-02-26 22:44:43 +01:00
## DRAGON SSH WOT
echo "DRAGONS WOT OFF"
${MY_PATH}/RUNTIME/DRAGON_p2p_ssh.sh off
########################################################################
2024-02-16 13:07:53 +01:00
## PING BOOSTRAP & SWARM NODES
2024-02-25 05:21:36 +01:00
${MY_PATH}/ping_bootstrap.sh > /dev/null 2>&1
2022-09-12 11:36:39 +02:00
########################################################################
######################################################### UPLANET ######
2024-02-16 13:07:53 +01:00
#####################################
# GeoKeys UMAP / SECTOR / REGION ...
2024-02-16 13:07:53 +01:00
#####################################
${MY_PATH}/RUNTIME/UPLANET.refresh.sh
2024-02-16 13:07:53 +01:00
#####################################
#####################################
# Players TW analyse & ASTROBOT run
2024-02-16 13:07:53 +01:00
#####################################
${MY_PATH}/RUNTIME/PLAYER.refresh.sh
2024-02-16 13:07:53 +01:00
#####################################
#####################################
# Node refreshing
2024-02-16 13:07:53 +01:00
#####################################
${MY_PATH}/RUNTIME/NODE.refresh.sh
#####################################
########################################################################
########################################################################
########################################################################
## REMOVE TMP BUT KEEP swarm, flashmem and coucou
mv ~/.zen/tmp/${IPFSNODEID} ~/.zen/${IPFSNODEID}
mv ~/.zen/tmp/swarm ~/.zen/swarm
mv ~/.zen/tmp/coucou ~/.zen/coucou
mv ~/.zen/tmp/flashmem ~/.zen/flashmem
rm -Rf ~/.zen/tmp/*
mv ~/.zen/${IPFSNODEID} ~/.zen/tmp/${IPFSNODEID}
mv ~/.zen/swarm ~/.zen/tmp/swarm
mv ~/.zen/coucou ~/.zen/tmp/coucou
mv ~/.zen/flashmem ~/.zen/tmp/flashmem
########################################################################
################################# updating ipfs bootstrap
2022-12-25 23:39:22 +01:00
espeak "bootstrap refresh" > /dev/null 2>&1
ipfs bootstrap rm --all > /dev/null 2>&1
[[ -s ${HOME}/.zen/MY_boostrap_nodes.txt ]] \
&& STRAPFILE="${HOME}/.zen/MY_boostrap_nodes.txt" \
|| STRAPFILE="${MY_PATH}/A_boostrap_nodes.txt"
for bootnode in $(cat ${STRAPFILE} | grep -Ev "#") # remove comments
do
ipfsnodeid=${bootnode##*/}
ipfs bootstrap add $bootnode
done
2023-10-26 11:09:19 +02:00
2022-09-23 14:57:04 +02:00
2022-09-12 11:36:39 +02:00
########################################################################
########################################################################
2022-09-12 11:36:39 +02:00
end=`date +%s`
2022-12-09 02:54:13 +01:00
dur=`expr $end - $start`
2023-12-18 15:32:45 +01:00
hours=$((dur / 3600))
minutes=$(( (dur % 3600) / 60 ))
seconds=$((dur % 60))
echo "DURATION ${hours} hours ${minutes} minutes ${seconds} seconds"
echo "20H12 (♥‿‿♥) Execution time was $dur seconds."
2022-11-04 20:08:33 +01:00
2023-01-08 04:54:12 +01:00
## MAIL LOG : support@qo-op.com ##
2024-02-11 19:46:02 +01:00
${MY_PATH}/tools/mailjet.sh "support@qo-op.com" "/tmp/20h12.log" "20H12"
2022-11-04 20:08:33 +01:00
2023-12-18 15:32:45 +01:00
espeak "DURATION ${hours} hours ${minutes} minutes ${seconds} seconds" > /dev/null 2>&1
2022-12-25 23:39:22 +01:00
2024-02-26 22:44:43 +01:00
## RESTART
2023-12-18 15:32:45 +01:00
# espeak "Restarting Astroport Services" > /dev/null 2>&1
2022-12-25 23:39:22 +01:00
## CLOSING API PORT
[[ -s ~/.zen/.pid ]] && kill -9 $(cat ~/.zen/.pid) > /dev/null 2>&1
2023-02-03 22:35:05 +01:00
## KILL ALL REMAINING nc
killall nc 12345.sh > /dev/null 2>&1
2024-02-16 13:07:53 +01:00
## SYSTEMD OR NOT SYSTEMD
2023-03-12 22:31:11 +01:00
if [[ ! -f /etc/systemd/system/astroport.service ]]; then
2024-02-16 13:07:53 +01:00
${MY_PATH}/12345.sh > ~/.zen/tmp/12345.log &
2023-03-12 22:31:11 +01:00
PID=$!
echo $PID > ~/.zen/.pid
else
2024-03-05 02:30:21 +01:00
sudo systemctl restart astroport
2023-04-05 14:48:08 +02:00
[[ -s ~/.zen/G1BILLET/G1BILLETS.sh ]] && sudo systemctl restart g1billet
echo "Astroport processes systemd restart"
2023-03-12 22:31:11 +01:00
fi
2024-02-16 13:07:53 +01:00
echo "IPFS DAEMON LEVEL"
######### IPFS DAMEON NOT RUNNING ALL DAY
## IF IPFS DAEMON DISABLED : WAIT 1H & STOP IT
[[ $LOWMODE != "" ]] \
2024-02-16 13:07:53 +01:00
&& echo "STOP IPFS $LOWMODE" \
&& sleep 3600 \
2024-01-10 23:03:25 +01:00
&& sudo systemctl stop ipfs \
&& exit 0
2024-02-16 13:07:53 +01:00
echo "HIGH. RESTART IPFS"
sleep 60
sudo systemctl restart ipfs
2024-02-16 13:07:53 +01:00
#################################
### DRAGON WOT : SSH P2P RING OPENING
#################################
2024-02-11 20:30:43 +01:00
sleep 30
2024-02-22 23:19:44 +01:00
echo "DRAGONS WOT ON"
2024-02-13 19:55:56 +01:00
${MY_PATH}/RUNTIME/DRAGON_p2p_ssh.sh
2022-09-12 11:36:39 +02:00
exit 0