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##*/}"
|
|
|
|
########################################################################
|
|
|
|
# \\///
|
|
|
|
# qo-op
|
|
|
|
############# '$MY_PATH/$ME'
|
|
|
|
########################################################################
|
|
|
|
# ex: ./'$ME'
|
|
|
|
########################################################################
|
|
|
|
# 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
|
|
|
|
########################################################################
|
|
|
|
# TODO remove because now it is in~/.bashrc
|
|
|
|
export YOU=$(ps auxf --sort=+utime | grep -w ipfs | grep -v -E 'color=auto|grep' | tail -n 1 | cut -d " " -f 1)
|
2021-03-11 22:56:12 +01:00
|
|
|
export IPFSNODEID=$(ipfs id -f='<id>\n') && [[ ! $IPFSNODEID ]] && exit 1
|
2020-12-12 01:26:39 +01:00
|
|
|
########################################################################
|
|
|
|
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-02-16 23:53:09 +01:00
|
|
|
rm /tmp/treated.ipfs.swarm
|
|
|
|
touch /tmp/treated.ipfs.swarm
|
2021-03-18 00:46:55 +01:00
|
|
|
touch ~/.zen/A_dead_swarm.txt
|
2020-12-12 01:26:39 +01:00
|
|
|
|
|
|
|
count=1
|
2021-04-01 01:50:27 +02:00
|
|
|
for ipfsnodeid in $(ipfs swarm peers | grep -o '[^/]*$' && cat ~/.zen/A_swarm_map.txt | grep -o '[^/]*$' | sort | uniq);
|
2020-12-12 01:26:39 +01:00
|
|
|
do
|
2021-04-01 01:50:27 +02:00
|
|
|
## $ipfsnodeid already Treated ?
|
|
|
|
[[ $(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-01 01:50:27 +02:00
|
|
|
|
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)
|
|
|
|
[[ ! $peerline ]] && peerline=$(ipfs swarm peers | grep "$ipfsnodeid")
|
|
|
|
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)
|
2020-12-12 01:26:39 +01:00
|
|
|
|
2021-03-18 00:46:55 +01:00
|
|
|
echo "### ANALYZING $whoisg1 = $ipfsnodeid ($ip) ###"
|
2020-12-25 18:27:47 +01:00
|
|
|
myfriendpeer=$(cat ~/.zen/A_my_swarm.txt | grep $ipfsnodeid )
|
|
|
|
if [[ "$myfriendpeer" != "" ]]; then
|
2020-12-25 20:30:11 +01:00
|
|
|
[[ ! $(ipfs swarm peers | grep $ipfsnodeid) ]] && ipfs swarm connect "$peerline" && 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";
|
|
|
|
grep -vEi $ip ~/.zen/A_my_swarm.txt
|
2021-03-18 00:46:55 +01:00
|
|
|
echo $ipfsnodeid > ~/.zen/A_dead_swarm.txt
|
2021-04-01 01:50:27 +02:00
|
|
|
## SEND MESSAGE ABOUT UNREACHABLE FRIEND
|
|
|
|
[[ "$IPFSNODEID" != "$ipfsnodeid" ]] && ~/.zen/astrXbian/zen/jaklis/jaklis.py -k ~/.zen/secret.dunikey send -d $G1PUB -t "ALERT" -m "Impossible de se synchroniser avec $whoisg1"
|
|
|
|
# KEEPING LAST 10 ALERT MESSAGES
|
|
|
|
nbmessage=0
|
|
|
|
for messageid in $(~/.zen/astrXbian/zen/jaklis/jaklis.py -k ~/.zen/secret.dunikey read -n300 -j | jq -r --arg friendKEY "$G1PUB" '.[] | select(.pubkey == $friendKEY)' | jq 'select(.title == "ALERT")' | jq -r '.id')
|
|
|
|
do
|
|
|
|
nbmessage=$((nbmessage+1))
|
2021-04-01 15:40:05 +02:00
|
|
|
[ $nbmessage -gt 10 ] && echo "Delete $nbmessage OLD 'ALERT' messages from $G1PUB" && ~/.zen/astrXbian/zen/jaklis/jaklis.py -k ~/.zen/secret.dunikey delete -i $messageid && sleep 0.5
|
2021-04-01 01:50:27 +02:00
|
|
|
done
|
|
|
|
|
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-01-31 17:34:46 +01:00
|
|
|
if [[ ( $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
|
|
|
|
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-01 01:50:27 +02:00
|
|
|
## DEFCON 3
|
|
|
|
# Ban all known ipfsnodeid ip
|
|
|
|
## DEFCON 2
|
|
|
|
# nmap NOT FRIEND
|
|
|
|
## DEFCON 1
|
|
|
|
# DDOS NOT FRIEND
|
2021-01-31 17:21:20 +01:00
|
|
|
fi
|
2021-02-01 04:06:35 +01:00
|
|
|
if [[ ! $isLAN ]]; then
|
|
|
|
ipfs swarm disconnect "$peerline"
|
|
|
|
ipfs bootstrap rm "$peerline"
|
2021-02-16 12:48:46 +01:00
|
|
|
fi
|
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-02-13 11:30:52 +01:00
|
|
|
mkdir -p ~/.zen/ipfs/.${IPFSNODEID}/astroport/kodi/vstream/
|
|
|
|
|
2021-03-06 13:09:39 +01: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-03-05 01:16:46 +01:00
|
|
|
|
2021-02-24 22:32:26 +01:00
|
|
|
########################################################################
|
2021-03-18 00:46:55 +01:00
|
|
|
# TODO PUBLISH tiddlywiki WALL OF FRIENDS
|
2021-02-24 22:32:26 +01:00
|
|
|
########################################################################
|
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-02-20 17:34:01 +01:00
|
|
|
########################################################################
|
|
|
|
########################################################################
|
|
|
|
echo "RETRIEVING MY OWN DATA FROM IPNS TO ~/.zen/ipfs_swarm"
|
|
|
|
ipfs get --output=/home/$YOU/.zen/ipfs_swarm/ /ipns/$IPFSNODEID
|
|
|
|
|
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
|