2020-12-12 01:26:39 +01:00
#!/bin/bash
########################################################################
# Author: Fred (support@qo-op.com)
# Version: 2020.03.24
# License: AGPL-3.0 (https://choosealicense.com/licenses/agpl-3.0/)
########################################################################
MY_PATH = " `dirname \" $0 \"` " # relative
MY_PATH = " `( cd \" $MY_PATH \" && pwd )` " # absolutized and normalized
ME = " ${ 0 ##*/ } "
2021-04-01 17:04:30 +02:00
YOU = $( ps auxf --sort= +utime | grep -w ipfs | grep -v -E 'color=auto|grep' | tail -n 1 | cut -d " " -f 1) && [ [ ! $YOU ] ] && echo "ipfs NOT RUNNING. EXIT" && exit 1
G1PUB = $( cat ~/.zen/secret.dunikey | grep 'pub:' | cut -d ' ' -f 2) && [ [ ! $G1PUB ] ] && echo "ERREUR G1PUB. EXIT" && exit 1
IPFSNODEID = $( ipfs id -f= '<id>\n' ) && [ [ " $IPFSNODEID " = = "" ] ] && echo 'ERROR missing IPFS Node id !! IPFS is not installed !?' && exit 1
2020-12-12 01:26:39 +01:00
########################################################################
########################################################################
# This script is controling IPFS swarm
# Sync friends peers ~/.zen/ipfs/ into ~/.zen/ipfs_swarm/.IPFSNODEID's/ directories
# add not friend_of_mine IPs to fail2ban
########################################################################
########################################################################
mkdir -p ~/.zen/ipfs_swarm
echo '
___ _ _ __ __ _ _ _ _ _ _ __
| | _) | _( _ ( _\ //\ | _) | \/ | | _) | _| _| _) | _( _ | _|
_| _| | __) __) \/ \/ /--\| \| | | \| _| | \| ___) | |
'
2021-03-18 00:46:55 +01:00
echo " I am $IPFSNODEID CONTROLING MY SWARM "
2021-01-31 17:21:20 +01:00
timestamp = $( date -u +%s%N | cut -b1-13)
2020-12-12 01:26:39 +01:00
2021-02-17 15:25:35 +01:00
########################################################################
2021-03-11 22:56:12 +01:00
# Delete "ipfs" & "ipfs_swarm" after reboot
2021-03-18 00:46:55 +01:00
# [[ ! -f /tmp/swarm_cleaned ]] && rm -Rf ~/.zen/ipfs/* && rm -Rf ~/.zen/ipfs_swarm/ && mkdir -p ~/.zen/ipfs_swarm && echo "IPFS CLEANING OK" > /tmp/swarm_cleaned
2021-02-17 15:25:35 +01:00
########################################################################
2021-04-07 23:01:20 +02:00
[ [ " $1 " = = "quick" ] ] && echo "" > /tmp/A_swarm || cat ~/.zen/A_swarm_map.txt > /tmp/A_swarm
2021-02-16 23:53:09 +01:00
rm /tmp/treated.ipfs.swarm
touch /tmp/treated.ipfs.swarm
2020-12-12 01:26:39 +01:00
2021-04-02 23:26:47 +02:00
## RESET BOOTSTRAP LIST
2021-04-30 14:30:46 +02:00
# ipfs bootstrap rm --all > /dev/null 2>&1
2021-04-02 23:26:47 +02:00
2021-04-04 21:55:32 +02:00
########################################################################
########################################################################
echo "******************************************************************"
echo "RETRIEVING MY OWN DATA FROM IPNS TO ~/.zen/ipfs_swarm"
ipfs get --output= /home/$YOU /.zen/ipfs_swarm/ /ipns/$IPFSNODEID
########################################################################
2020-12-12 01:26:39 +01:00
count = 1
2021-05-15 21:26:16 +02:00
ipfs swarm peers > /tmp/ipfs_swarm_peers
for ipfsnodeid in $( ( cat /tmp/ipfs_swarm_peers | grep -o '[^/]*$' && cat /tmp/A_swarm | grep -o '[^/]*$' ) | sort | uniq) ;
2020-12-12 01:26:39 +01:00
do
2021-04-01 01:50:27 +02:00
## $ipfsnodeid already Treated ?
2021-05-15 22:53:03 +02:00
[ [ -f ~/.zen/ipfs_swarm/.$ipfsnodeid /_xbian.zuid ] ] && XID = $( cat ~/.zen/ipfs_swarm/.$ipfsnodeid /_xbian.zuid) || XID = ''
[ [ -f ~/.zen/ipfs_swarm/.$ipfsnodeid /G1SSB/_g1.gchange_title ] ] && XZUID = $( cat ~/.zen/ipfs_swarm/.$ipfsnodeid /G1SSB/_g1.gchange_title) || XZUID = ''
2021-05-17 23:46:34 +02:00
[ [ " $XID " = = "" ] ] && ipfs swarm disconnect /ipfs/$ipfsnodeid ## NOT COMPLIANT STATION
2021-05-17 23:54:31 +02:00
# [[ $(cat /tmp/treated.ipfs.swarm | grep "$ipfsnodeid") ]] && continue
2021-03-18 00:46:55 +01:00
[ [ $( cat ~/.zen/A_dead_swarm.txt | grep " $ipfsnodeid " ) ] ] && continue
2021-04-02 23:26:47 +02:00
[ [ " $ipfsnodeid " = = " $IPFSNODEID " ] ] && continue
2021-02-21 20:33:38 +01:00
# Convert ipfsnodeid into g1pub
2020-12-25 18:27:47 +01:00
whoisg1 = $( ~/.zen/astrXbian/zen/tools/ipfs_to_g1.py $ipfsnodeid )
2021-02-16 12:48:46 +01:00
2021-02-21 20:33:38 +01:00
# control ip isLAN?
2021-04-01 01:50:27 +02:00
peerline = $( cat ~/.zen/A_swarm_map.txt | grep " $ipfsnodeid " | head -n 1)
2021-05-15 21:26:16 +02:00
[ [ ! $peerline ] ] && peerline = $( cat /tmp/ipfs_swarm_peers | grep " $ipfsnodeid " | head -n 1)
2021-04-01 01:50:27 +02:00
ip = $( cat ~/.zen/A_swarm_map.txt | grep " $ipfsnodeid " | awk -F '/' '{print $3}' | head -n 1)
2020-12-12 01:26:39 +01:00
isLAN = $( echo $ip | cut -f3 -d '/' | grep -E " (^127\.)|(^192\.168\.)|(^fd42\:)|(^10\.)|(^172\.1[6-9]\.)|(^172\.2[0-9]\.)|(^172\.3[0-1]\.)|(^::1 $)|(^[fF][cCdD])/ " )
2020-12-25 18:27:47 +01:00
nowdate = $( date)
2021-04-02 23:26:47 +02:00
2021-04-02 19:48:16 +02:00
echo "#############################################################"
2021-04-02 23:26:47 +02:00
echo " ### ANALYZING $whoisg1 = $ipfsnodeid ( $ip ) $XID $XZUID ### "
2021-04-02 19:48:16 +02:00
echo " $peerline "
2020-12-25 18:27:47 +01:00
myfriendpeer = $( cat ~/.zen/A_my_swarm.txt | grep $ipfsnodeid )
if [ [ " $myfriendpeer " != "" ] ] ; then
2021-05-15 21:26:16 +02:00
if [ [ ! $( cat /tmp/ipfs_swarm_peers | grep $ipfsnodeid ) ] ] ; then
2021-04-02 23:26:47 +02:00
ipfs swarm connect " $peerline "
if [ $? != 0 ] ; then
grep -vEi $ip ~/.zen/A_my_swarm.txt
2021-04-16 13:27:29 +02:00
echo $ipfsnodeid >> ~/.zen/A_dead_swarm.txt
2021-04-02 23:26:47 +02:00
echo " SEND MESSAGE ABOUT UNREACHABLE FRIEND $whoisg1 ( $XID ) ( $XZUID ) "
2021-04-29 19:08:13 +02:00
~/.zen/astrXbian/zen/jaklis/jaklis.py -k ~/.zen/secret.dunikey -n "https://data.gchange.fr" send -d $G1PUB -t "ALERT" -m " Impossible de se synchroniser avec $whoisg1 ( $XID ) ( $XZUID ) "
2021-04-02 23:26:47 +02:00
# KEEPING LAST 10 ALERT MESSAGES
nbmessage = 0
2021-04-29 19:08:13 +02:00
for messageid in $( ~/.zen/astrXbian/zen/jaklis/jaklis.py -k ~/.zen/secret.dunikey -n "https://data.gchange.fr" read -n300 -j | jq -r --arg friendKEY " $G1PUB " '.[] | select(.pubkey == $friendKEY)' | jq 'select(.title == "ALERT")' | jq -r '.id' )
2021-04-02 23:26:47 +02:00
do
nbmessage = $(( nbmessage+1))
2021-04-29 19:08:13 +02:00
[ $nbmessage -gt 10 ] && echo " Delete $nbmessage OLD 'ALERT' messages from $G1PUB " && ~/.zen/astrXbian/zen/jaklis/jaklis.py -k ~/.zen/secret.dunikey -n "https://data.gchange.fr" delete -i $messageid && sleep 0.5
2021-04-02 23:26:47 +02:00
done
continue
fi
fi
ipfs bootstrap add " $peerline "
2020-12-25 20:32:28 +01:00
echo " OK Friend REFRESH /ipns/ $ipfsnodeid INTO ~/.zen/ipfs_swarm/ "
2021-01-31 14:23:01 +01:00
$MY_PATH /tools/timeout.sh -t 12 ipfs get --output= /home/$YOU /.zen/ipfs_swarm/ /ipns/$ipfsnodeid
2021-02-01 04:00:38 +01:00
if [ $? != 0 ] ; then
echo " TIMEOUT REACHED ___ REMOVE $ipfsnodeid FROM ~/.zen/A_my_swarm.txt " ;
2021-04-08 03:06:17 +02:00
else
################################################################
## REFRESH stargates keys from my friend
################################################################
2021-04-08 03:11:59 +02:00
mkdir -p ~/.zen/key/stargates/$whoisg1
2021-04-16 13:36:06 +02:00
ipfs get --output= $HOME /.zen/key/stargates/$whoisg1 / /ipns/$ipfsnodeid /.$ipfsnodeid /FRIENDS/$G1PUB /
2021-04-08 03:06:17 +02:00
## DECRYPT
2021-04-08 03:11:59 +02:00
[ [ -f $HOME /.zen/key/stargates/$whoisg1 /stargate1.encrypt ] ] && $MY_PATH /tools/natools.py decrypt -f pubsec -k " $HOME /.zen/secret.dunikey " -i " $HOME /.zen/key/stargates/ $whoisg1 /stargate1.encrypt " -o " $HOME /.zen/key/stargates/ $whoisg1 /stargate1 "
[ [ -f $HOME /.zen/key/stargates/$whoisg1 /stargate2.encrypt ] ] && $MY_PATH /tools/natools.py decrypt -f pubsec -k " $HOME /.zen/secret.dunikey " -i " $HOME /.zen/key/stargates/ $whoisg1 /stargate2.encrypt " -o " $HOME /.zen/key/stargates/ $whoisg1 /stargate2 "
[ [ -f $HOME /.zen/key/stargates/$whoisg1 /stargate3.encrypt ] ] && $MY_PATH /tools/natools.py decrypt -f pubsec -k " $HOME /.zen/secret.dunikey " -i " $HOME /.zen/key/stargates/ $whoisg1 /stargate3.encrypt " -o " $HOME /.zen/key/stargates/ $whoisg1 /stargate3 "
[ [ -f $HOME /.zen/key/stargates/$whoisg1 /stargate4.encrypt ] ] && $MY_PATH /tools/natools.py decrypt -f pubsec -k " $HOME /.zen/secret.dunikey " -i " $HOME /.zen/key/stargates/ $whoisg1 /stargate4.encrypt " -o " $HOME /.zen/key/stargates/ $whoisg1 /stargate4 "
[ [ -f $HOME /.zen/key/stargates/$whoisg1 /stargate5.encrypt ] ] && $MY_PATH /tools/natools.py decrypt -f pubsec -k " $HOME /.zen/secret.dunikey " -i " $HOME /.zen/key/stargates/ $whoisg1 /stargate5.encrypt " -o " $HOME /.zen/key/stargates/ $whoisg1 /stargate5 "
2021-02-01 04:00:38 +01:00
fi
2020-12-25 18:27:47 +01:00
else
2021-02-21 20:33:38 +01:00
[ [ -f ~/.zen/DEFCON ] ] && export DEFCON = $( cat ~/.zen/DEFCON) || export DEFCON = $( cat ~/.zen/astrXbian/DEFCON) # like in crom_MINUTE.sh
2021-04-01 01:50:27 +02:00
echo " !!! UNKNOWN FRIEND !!! $ip ___ $ipfsnodeid ________ # DEFCON : $DEFCON "
2021-04-02 23:26:47 +02:00
rm -Rf ~/.zen/ipfs_swarm/.$ipfsnodeid
2021-05-15 21:26:16 +02:00
ip = $( cat /tmp/ipfs_swarm_peers | grep " $ipfsnodeid " | awk -F '/' '{print $3}' | head -n 1)
2021-05-15 22:20:09 +02:00
[ [ $ip ] ] && anybodyelseipfsid = $( cat /tmp/ipfs_swarm_peers | grep " $ip " | grep -Ev " $ipfsnodeid " | head -n 1 | rev | cut -d '/' -f 1 | rev )
[ [ $anybodyelseipfsid ] ] && isanybodyelseipmyfriend = $( cat ~/.zen/A_my_swarm.txt | grep $anybodyelseipfsid ) ## AVOID BANNING IP IF A FRIEND IS IN SAME LAN PUBLIC IP
2021-05-15 22:20:56 +02:00
[ [ $isanybodyelseipmyfriend ] ] && echo " TODO: SEND MESSAGE TO $isanybodyelseipmyfriend WARNING ABOUT $ipfsnodeid SAME SEEN IP $ip "
2021-05-15 22:20:09 +02:00
if [ [ $ip && ! $isanybodyelseipmyfriend && ( $DEFCON < 5 ) && ! $isLAN ] ]
2021-01-31 17:21:20 +01:00
then
2021-04-01 01:50:27 +02:00
## DEFCON 4
2021-02-01 04:06:35 +01:00
### SECURITY CHOICE TO MAKE IN /etc/sudoers ###
# $USER ALL=(ALL:ALL) NOPASSWD:ALL
2021-01-31 22:53:23 +01:00
# $USER ALL=(ALL:ALL) NOPASSWD:/usr/bin/fail2ban-client
sudo fail2ban-client add recidive 2>/dev/null 1>& 2
sudo fail2ban-client start recidive
2021-05-18 00:12:32 +02:00
sudo fail2ban-client set recidive bantime 3600 # 1 Hour bantime
2021-01-31 22:53:23 +01:00
sudo fail2ban-client set recidive banip $ip
2021-01-31 17:21:20 +01:00
# Show ALL banned IP
2021-01-31 22:53:23 +01:00
sudo fail2ban-client status recidive
2021-04-02 19:48:16 +02:00
2021-04-01 01:50:27 +02:00
## DEFCON 3
2021-04-02 19:48:16 +02:00
# Ban all known ipfsnodeid ip
2021-04-01 01:50:27 +02:00
## DEFCON 2
# nmap NOT FRIEND
2021-04-02 19:48:16 +02:00
2021-04-01 01:50:27 +02:00
## DEFCON 1
# DDOS NOT FRIEND
2021-04-02 19:48:16 +02:00
2021-01-31 17:21:20 +01:00
fi
2021-02-01 04:06:35 +01:00
if [ [ ! $isLAN ] ] ; then
ipfs swarm disconnect " $peerline "
2021-02-16 12:48:46 +01:00
fi
2021-04-30 14:30:46 +02:00
ipfs bootstrap rm " $peerline "
2020-12-25 18:27:47 +01:00
fi
2021-02-16 12:48:46 +01:00
echo " $ipfsnodeid " >> /tmp/treated.ipfs.swarm
2020-12-12 01:26:39 +01:00
done
2021-02-01 02:43:19 +01:00
########################################################################
2021-03-06 13:09:39 +01:00
# REFRESH Film Serie Anime Youtube ${PREFIX}ASTRXBIAN index
2021-02-01 02:43:19 +01:00
########################################################################
2021-04-02 23:26:47 +02:00
echo "******************************************************************"
echo " ### REFRESH Film Serie Anime Youtube ${ PREFIX } ASTRXBIAN ### "
2021-02-13 11:30:52 +01:00
mkdir -p ~/.zen/ipfs/.${ IPFSNODEID } /astroport/kodi/vstream/
2021-04-02 19:48:16 +02:00
AXID = $( cat ~/.zen/ipfs/.$IPFSNODEID /_xbian.zuid) ;
2021-02-13 11:30:52 +01:00
2021-04-02 19:48:16 +02:00
for PREFIX in F S A Y
2021-03-07 19:41:59 +01:00
do
2021-03-06 13:09:39 +01:00
echo "CAT;TMDB;YEAR;TITLE;SAISON;GENRES;GROUPES;RES;URLS=http://127.0.0.1:8181" > ~/.zen/ipfs/.${ IPFSNODEID } /${ PREFIX } ASTRXBIAN
2021-04-01 00:16:05 +02:00
cat ~/.zen/ipfs_swarm/.12D*/astroport/kodi/vstream/${ PREFIX } ASTRXBIAN | sed "s/anime;/film;/g" | sed '/^[[:space:]]*$/d' | grep -Ev "CAT;TMDB" | sort | uniq >> ~/.zen/ipfs/.${ IPFSNODEID } /${ PREFIX } ASTRXBIAN
2021-03-06 13:09:39 +01:00
done
2021-04-03 23:07:04 +02:00
# Remove old database
# rm ~/.kodi/userdata/addon_data/plugin.video.vstream/astroport_cache.db
2021-03-05 01:16:46 +01:00
2021-02-24 22:32:26 +01:00
########################################################################
2021-04-04 21:55:32 +02:00
# REFRESH tiddlywiki WALL OF FRIENDS
2021-02-24 22:32:26 +01:00
########################################################################
2021-04-02 23:26:47 +02:00
echo "******************************************************************"
echo "### PUBLISH tiddlywiki WALL OF FRIENDS ###"
2021-03-31 02:02:20 +02:00
echo "<html><body>" > ~/.zen/ipfs/.${ IPFSNODEID } /FRIENDS/index.html
2021-03-18 01:18:24 +01:00
for wiki in $( ls ~/.zen/ipfs_swarm/.12D*/index.html 2>/dev/null) ; do
2021-03-31 02:02:20 +02:00
ipfsnodeid = $( echo $wiki | cut -d '.' -f 3- | cut -d '/' -f 1)
2021-03-18 01:18:24 +01:00
whoisg1 = $( ~/.zen/astrXbian/zen/tools/ipfs_to_g1.py $ipfsnodeid )
2021-03-31 02:02:20 +02:00
2021-03-18 01:18:24 +01:00
echo " <iframe id=\" $ipfsnodeid \"
title = 'tiddlywiki $whoisg1'
2021-03-31 02:02:20 +02:00
width = '600'
2021-03-18 01:18:24 +01:00
src = \" http://127.0.0.1:8181/ipns/$ipfsnodeid /.$ipfsnodeid /index.html\" >
</iframe>" >> ~/.zen/ipfs/. ${ IPFSNODEID } /FRIENDS/index.html
2021-03-18 00:46:55 +01:00
done
2021-03-31 02:02:20 +02:00
echo "</body></html>" >> ~/.zen/ipfs/.${ IPFSNODEID } /FRIENDS/index.html
2021-02-24 22:32:26 +01:00
2021-04-08 04:02:56 +02:00
########################################################################
# ACTIVATE WORDPRESS CHANNEL
########################################################################
2021-05-15 22:23:29 +02:00
[ [ $( which wp) ] ] && ~/.zen/astrXbian/zen/wordpress_channel.sh
2021-04-08 04:02:56 +02:00
2021-02-15 11:09:43 +01:00
# REFRESH IPNS SELF PUBLISH
2021-02-01 02:43:19 +01:00
########################################################################
2021-02-15 11:09:43 +01:00
~/.zen/astrXbian/zen/ipns_self_publish.sh
2021-02-01 03:39:46 +01:00
########################################################################
2021-02-01 02:43:19 +01:00
2020-12-12 01:26:39 +01:00
exit 0