astrXbian/zen/ipfs_SWARM_refresh.sh

86 lines
3.3 KiB
Bash
Raw Normal View History

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)
export IPFSNODEID=$(ipfs id -f='<id>\n')
########################################################################
mkdir -p ~/.zen/ipfs_swarm
echo '
___ _ _ __ __ _ _ _ _ _ _ __
| |_)|_(_ (_\ //\ |_)|\/| |_)|_|_|_)|_(_ |_|
_|_| | __) __)\/\//--\| \| | | \|_| | \|___)| |
'
echo "I am $IPFSNODEID"
echo "REFRESHING /home/$YOU/.zen/ipfs_swarm/ from my SWARM peers"
rm -Rf /home/$YOU/.zen/ipfs_swarm/.12D3KooW*
rm -Rf /home/$YOU/.zen/ipfs_swarm/.Qm*
rm -Rf /home/$YOU/.zen/ipfs_swarm/*
count=1
for peer in $(ipfs swarm peers);
do
2020-12-23 13:13:59 +01:00
ipfsnodeid=$(echo "$peer" | awk -F '/' '{print $8}')
2020-12-12 01:26:39 +01:00
ip=$(echo "$peer" | awk -F '/' '{print $3}')
nowdate=$(date)
timestamp=$(date -u +%s%N | cut -b1-13)
2020-12-16 00:02:00 +01:00
echo "$nowdate - $ipfsnodeid - $ip"
2020-12-12 01:26:39 +01:00
foundIp=$(cat ~/.zen/A_allow_ip.txt | grep "$ip")
2020-12-12 20:59:40 +01:00
foundIpfs=$(cat ~/.zen/A_allow_ipfsid.txt | grep "$ipfsnodeid")
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-12 20:59:40 +01:00
if [[ ! $foundIpfs && ! $isLAN ]] ; then
2020-12-12 01:26:39 +01:00
echo "${ip} of peer ${id} is not in the authorized ip list."
echo "${peer} will be removed from the swarm"
ipfs swarm disconnect $peer
ipfs bootstrap rm $peer
echo "# FAIL2BAN # $USER must activate no password sudo (Rpi & Xbian OK)"
2020-12-12 20:59:40 +01:00
if [[ $USER == "pi" || $USER == "xbian" ]]; then
2020-12-23 01:45:40 +01:00
echo "TODO BAN $ip ($ipfsnodeid)"
# sudo fail2ban-client add recidive 2>/dev/null 1>&2
# sudo fail2ban-client start recidive
# sudo fail2ban-client set recidive banip $ip
2020-12-17 20:47:20 +01:00
# Show banned IP
2020-12-23 01:45:40 +01:00
# sudo fail2ban-client status recidive
2020-12-12 20:59:40 +01:00
fi
2020-12-12 01:26:39 +01:00
else
echo "${peer}"
echo "REFRESH /ipns/$ipfsnodeid INTO ~/.zen/ipfs_swarm/"
2020-12-15 13:27:32 +01:00
$MY_PATH/tools/timeout.sh -t 30 ipfs get --output=/home/$YOU/.zen/ipfs_swarm/ /ipns/$ipfsnodeid
2020-12-12 01:26:39 +01:00
fi
done
echo "$IPFSNODEID PUBLISHING /home/$YOU/.zen/ipfs/ to SWARM"
[[ ! -d /home/$YOU/.zen/ipfs ]] && echo "ERROR : /home/$YOU/.zen/ipfs/ NOT FOUND" && exit 1
IWALLETS=$(ipfs add -rHq /home/$YOU/.zen/ipfs | tail -n 1)
NODEIPNS=$(ipfs name publish --quieter /ipfs/$IWALLETS)
2020-12-15 13:27:32 +01:00
# Retrieve my own data in /home/$YOU/.zen/ipfs_swarm/
2020-12-12 01:26:39 +01:00
ipfs get --output=/home/$YOU/.zen/ipfs_swarm/ /ipns/$IPFSNODEID
exit 0