Compare commits

..

26 Commits

Author SHA1 Message Date
afde7f237c updated traffmonetizer docker to cli_v2 2023-12-18 22:19:17 +01:00
790f3a497c added a notification about the default start page 2023-05-22 21:07:21 +02:00
7069053d31 removed the default load page, due to errors with the surfbar. 2023-05-22 21:05:46 +02:00
3da8535ab4 Git was out of sync. So: added Cpu core limit (again); fixed RAM allocation; fixed progressbar order (ebesucher); fixed crontab order; fixed cron naming 2023-03-12 17:35:17 +01:00
548c0a841d Merge remote-tracking branch 'origin/master' 2023-03-01 20:05:27 +01:00
3d12186e37 set to root only! 2023-03-01 20:03:35 +01:00
4c7716a913 fixed missing /tmp/ 2023-02-14 20:41:31 +01:00
c9faefa42c added an lock file to exit restarter if restart is already triggered
If you want multiple conditions (if ping is sucessfull, on less than X CPU Usage etc) for the restarter, it will create a lock file now to avoid multiple instances.
2023-02-14 20:36:17 +01:00
f9e234915d Update Readme.md 2023-02-09 21:21:59 +01:00
05f149baf6 fixed repocket mail and select menu size 2023-02-08 20:20:31 +01:00
8b7562d3bf fixed docker function 2023-02-06 22:05:58 +01:00
e463d963ba Added logging for restarter 2023-02-06 16:22:20 +01:00
d15b1919cf added Repocket 2023-02-06 16:19:04 +01:00
1df6f685a0 reworked all ebesucher folder directions to variable 2023-02-06 16:13:33 +01:00
4746e4e57f Fixed Unraid earnapp RID creation (really now) 2023-02-05 15:24:55 +01:00
580ee1e4bb Fixed Unraid LXC RID creation 2023-02-05 15:24:03 +01:00
3a5b5fd006 Fixed unraid LXC earnapp RID stuck 2023-02-05 15:23:26 +01:00
38582d7f8d fixed ebesucher memory allocation 2023-02-05 00:31:42 +01:00
e04d7335bc fixed ebesucher memory allocation 2023-02-05 00:30:21 +01:00
df5f5c8921 fix for lxc in Unraid & watchtower 2023-02-04 22:06:48 +01:00
04f5c25f0e revert -u switch 2023-02-04 20:18:20 +01:00
a7b44d2009 revert -u switch for ebesucher 2023-02-04 20:17:50 +01:00
6a0ebfdf2a added user to ebesucher container 2023-02-04 20:12:34 +01:00
53cb4f58f4 added user for easy deleting folder 2023-02-04 20:10:11 +01:00
a386971342 Rework for better root/user management 2023-02-04 13:54:13 +01:00
2481b00a26 Added CPU Limitation 2023-02-04 13:22:07 +01:00
5 changed files with 76 additions and 492 deletions

View File

@@ -1,74 +0,0 @@
#############################################################################################
# _ _ _ _ __ _ _ _ _ _ _ _ #
# | \ | | ___ | |_(_)/ _(_) ___ __ _| |_(_) ___ _ __ | | | | __ _ _ __ __| | | ___ _ __ #
# | \| |/ _ \| __| | |_| |/ __/ _ | __| |/ _ \| _ \| |_| |/ _ | _ \ / _ | |/ _ \ __| #
# | |\ | (_) | |_| | _| | (_| (_| | |_| | (_) | | | | _ | (_| | | | | (_| | | __/ | #
# |_| \_|\___/ \__|_|_| |_|\___\__,_|\__|_|\___/|_| |_|_| |_|\__,_|_| |_|\__,_|_|\___|_| #
# #
# _ __ __ _ _ _ #
# | |/ /___ _ __ / _(_) __ _ _ _ _ __ __ _| |_(_) ___ _ __ #
# | // _ \| _ \| |_| |/ _ | | | | __/ _ | __| |/ _ \| _ \ #
# | \ (_) | | | | _| | (_| | |_| | | | (_| | |_| | (_) | | | | #
# |_|\_\___/|_| |_|_| |_|\__, |\__,_|_| \__,_|\__|_|\___/|_| |_| #
# |___/ #
#############################################################################################
SurfbarName="" # https://ebesucher.de/surfbar/SURFBARNAME Das in Großbuchstaben muss dann hier eingegeben werden
NotificationHandler="" # Schreibe hier Discord, Telegram, Apprise, Nextcloud, Pushbullet, Mail oder RocketChat ein.
####################
# Discord Settings #
####################
Discord_WebHookLink=""
#####################
# Telegram Settings #
#####################
Telegram_UID=""
Telegram_BT=""
####################
# Apprise Settings #
####################
AppRiseURL=""
AppRiseTAG="" # Optional
######################
# Nextcloud Settings #
######################
NextcloudDomain=""
NextcloudTalkToken=""
NextcloudUser=""
NextcloudPassword=""
#######################
# PushBullet Settings #
#######################
# Achtung! Pushbullet hat ein Limit von maximal 500 Nachrichten pro Monat! Falls ihr viel damit hantiert, kann es sein, dass ich diese Überschreitet!
PushBulletToken=""
#################
# Mail Settings #
#################
smtpURL=""
smtpPORT=""
mailfrom=""
mailrcpt=""
mailuser="" # Ist meistens gleichzeitig auch mailfrom
mailpass="" # Mail Password. Falls Gmail genutzt wird, muss in der Google Konto Verwaltung, Sicherheit, ein App Passwort erstellt werden!
########################
# Rocket.Chat Settings #
########################
RocketChatHook=""
########################
# End of Configuration #
########################

View File

@@ -62,3 +62,4 @@ Die Anbieter sind mit Ref-Links versehen, falls ihr euch erst noch anmelden müs
- [packetstream](https://packetstream.io/?psr=4HUh)
- [IPRoyal Pawn.app](https://pawns.app?r=905162)
- [TraffMonetizer](https://traffmonetizer.com/?aff=607897)
- [Repocket](https://link.repocket.co/undefined)

130
gui_start.sh Executable file → Normal file
View File

@@ -8,6 +8,12 @@ erfolgreich=0
fehler=0
skip=0
export DEBIAN_FRONTEND=noninteractive
if [ "$(whoami)" != "root" ]; then
echo "Es ist leider erforderlich, dass das script als root ausgeführt wird!"
exit
fi
new_task() {
echo -e "\n\n$(printf %"$(tput cols)"s | tr " " "=")\n$1\n$(printf %"$(tput cols)"s | tr " " "=")"
}
@@ -44,11 +50,11 @@ inputbox() {
}
[ -d /etc/needrestart/ ] && sudo sed -i 's/#$nrconf{restart} = '"'"'i'"'"';/$nrconf{restart} = '"'"'a'"'"';/g' /etc/needrestart/needrestart.conf 2>/dev/null
sudo echo
if ! which whiptail >/dev/null; then
sudo apt-get install whiptail -y
fi
linux_user=$(w | awk '{print $1}' | tail -n1)
{
echo 0
sudo apt-get update >/dev/null
@@ -68,14 +74,11 @@ linux_user=$(w | awk '{print $1}' | tail -n1)
sudo apt-get update
fi
echo 100
} | whiptail --gauge "Aktualisiere System installiere Docker" 6 50 0
} | whiptail --gauge "Aktualisiere System installiere Docker PPA" 6 50 0
if ! which docker >/dev/null; then
messagebox "Kleinen Moment Geduld, Docker wird Installiert." "Das Fenster wird sich automatisch schließen, sobald Docker installiert wurde." &
sudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin >/dev/null
messagebox "Docker wurde installiert" "Leider ist es notwendig, dass wir nun den PC Neustarten.\nNach dem Neustart, starte einfach von vorne. Das Skript wird dann aber durchlaufen"
sudo usermod -aG docker $linux_user
sudo reboot
fi
whiptail --title "Passive Income Helperskript" --msgbox "Dieses Skript richtet mehrere Einkommenshelfer für dich ein.
@@ -136,7 +139,7 @@ else
;;
EarnAPP)
wget -qO- https://brightdata.com/static/earnapp/install.sh >/tmp/earnapp.sh && echo "yes" | sudo bash /tmp/earnapp.sh
read -n1 -r -p "Drücke eine Taste, wenn du den Link im Browser geöffnet hast und das Gerät mit deinem Account verlinkt wurde..." key
read -n1 -r -p "Drücke eine Taste, wenn du den Link im Browser geöffnet hast und das Gerät mit deinem Account verlinkt wurde..."
;;
Packetstream)
@@ -165,7 +168,7 @@ else
;;
Traffmonetizer)
trafftoken=$(whiptail --title "TraffMonetizer Token" --inputbox "Gebe deinen TraffMonetizer Token an: " 20 70 3>&1 1>&2 2>&3)
if docker rm -f traffmonetizer || true && docker run -d --name traffmonetizer --restart unless-stopped traffmonetizer/cli start accept --token "$trafftoken"; then
if docker rm -f traffmonetizer || true && docker run -d --name traffmonetizer --restart unless-stopped traffmonetizer/cli_v2 start accept --token "$trafftoken"; then
erfolg "TraffMonetizer wurde eingerichtet"
else
fehler "TraffMonetizer konnte nicht eingerichtet werden"
@@ -181,34 +184,24 @@ Ebesucher braucht leider etwas mehr Einrichtung. Aber keine Sorge, ich mach es d
Zunächst erstellen wir einen Firefox Container.
Dieser soll im Hintergrund die Werbeseiten aufrufen."
if [ -d ~/ebesucher ]; then
if [ -d /root/ebesucher ]; then
skip "Ordner ebesucher exestiert bereits"
if ! [ -f ~/ebesucher/config.zip ]; then
if ! [ -f /root/ebesucher/config.zip ]; then
if whiptail --title "Alte config gefunden" --yesno "Es wurde bereits ein Firefox Profil angelegt, soll dieses gelöscht und überschrieben werden?" 20 100; then
rm -f ~/ebesucher/config.zip
wget -O ~/ebesucher/config.zip https://github.com/Pakobbix/passive-income/raw/master/config.zip
unzip ~/ebesucher/config.zip -d ~/ebesucher/
rm -f /root/ebesucher/config.zip
wget -O /root/ebesucher/config.zip https://github.com/Pakobbix/passive-income/raw/master/config.zip
unzip /root/ebesucher/config.zip -d /root/ebesucher/
else
unzip ~/ebesucher/config.zip -d ~/ebesucher/
unzip /root/ebesucher/config.zip -d /root/ebesucher/
fi
fi
else
if [ "$linux_user" == "root" ]; then
if mkdir /root/ebesucher; then
wget -O /root/ebesucher/config.zip https://github.com/Pakobbix/passive-income/raw/master/config.zip
unzip /root/ebesucher/config.zip -d /root/ebesucher/
erfolg "Ordner für ebesucher konnte erstellt werden"
else
fehler "Der Ordner für ebesucher konnte nicht angelegt werden"
fi
if mkdir /root/ebesucher; then
wget -O /root/ebesucher/config.zip https://github.com/Pakobbix/passive-income/raw/master/config.zip
unzip /root/ebesucher/config.zip -d /root/ebesucher/
erfolg "Ordner für ebesucher konnte erstellt werden"
else
if mkdir /home/"$linux_user"/ebesucher; then
wget -O /home/"$linux_user"/ebesucher/config.zip https://github.com/Pakobbix/passive-income/raw/master/config.zip
unzip /home/"$linux_user"/ebesucher/config.zip -d /home/"$linux_user"/ebesucher/
erfolg "Ordner für ebesucher konnte erstellt werden"
else
fehler "Der Ordner für ebesucher konnte nicht angelegt werden"
fi
fehler "Der Ordner für ebesucher konnte nicht angelegt werden"
fi
fi
ebesucher_docker() {
@@ -219,10 +212,17 @@ Dieser soll im Hintergrund die Werbeseiten aufrufen."
fehler "Firefox-Ebesucher konnte nicht eingerichtet werden"
fi
}
while true; do
max_cores=$(grep -c processor /proc/cpuinfo)
cpucores=$(inputbox "Maximale CPU Cores" "Gebe hier an, wieviele CPU Kerne der Container Maximal nutzen darf. (zwischen 1 - $max_cores)")
if [ "$cpucores" -le "0" ] || [ "$cpucores" -gt "$max_cores" ]; then
messagebox "Ungültige Eingabe" "Es können nicht weniger als 0 oder mehr als $max_cores eingegeben werden"
else
break
fi
done
ram_avail=$(bc <<<"scale=2;$(($(free | awk 'NR==2 {print $2}') / 1000000))")
if [[ $ram_avail -ge "2" ]]; then
ebesucher_docker "1g"
elif [[ $ram_avail -eq "4" ]]; then
if ((ram_avail >= 3 && ram_avail <= 4)); then
ebesucher_docker "3g"
elif [[ $ram_avail -ge "5" ]]; then
ebesucher_docker "4g"
@@ -230,27 +230,30 @@ Dieser soll im Hintergrund die Werbeseiten aufrufen."
messagebox "" "Oben Rechts im Firefox Browser, öffne das Ebesucher addon.
Gebe in das Feld deinen Ebesucher Nutzernamen ein und mache einen Haken bei Privacy"
nutzername=$(inputbox "Ebesucher Nutzername" "Gebe hier deinen Ebesucher Nutzernamen ein: ")
messagebox 'Schließt nun alle Tabs im Browser und fahrt fort.'
messagebox "" "Stellt noch in den Einstellungen von Firefox die Startseite auf eure Surfbar ein.
Schließt nun alle Tabs im Browser und fahrt fort."
messagebox "Erstelle Sicherungen" "Damit die Einstellungen auch für immer gespeichert werden,
erstelle ich eine Sicherung der Firefox-Konfiguration"
{
echo 10
if [ -f ~/ebesucher/config.zip ]; then
rm -f ~/ebesucher/config.zip
if [ -f /root/ebesucher/config.zip ]; then
rm -f /root/ebesucher/config.zip
fi
echo 15
docker stop ebesucher
echo 25
cd ~/ebesucher/ || exit
cd /root/ebesucher/ || exit
echo 30
zip -r config.zip config/
echo 50
wget -O /root/ebesucher/restart.sh https://raw.githubusercontent.com/Pakobbix/passive-income/master/restart.sh 2>&1 >/dev/null
echo 60
wget -O ~/ebesucher/restart.sh https://raw.githubusercontent.com/Pakobbix/passive-income/master/restart.sh
echo 80
chmod +x ~/ebesucher/restart.sh
bash ~/ebesucher/restart.sh
chmod +x /root/ebesucher/restart.sh
echo 70
sed -i "s/CPUcores=/&$cpucores/g" /root/ebesucher/restart.sh
sed -i "s/username=/&$nutzername/g" /root/ebesucher/restart.sh
echo 90
sed -i "s/username=/&$nutzername/g" ~/ebesucher/restart.sh
bash /root/ebesucher/restart.sh
echo 100
} | whiptail --gauge "Erstelle Sicherung und Lade Restarter Skript herunter" 6 50 0
@@ -263,48 +266,27 @@ Dies wird gemacht, damit sich nicht zuviel Müll ansammelt und um zu gewährleis
dass es für immer läuft.
Selbst wenn der Container mal abstürzen sollte, wird er nächste Stunde wieder neugestartet."
crontab -l >/tmp/ebesucher 2>/dev/null
if [ "$linux_user" == "root" ]; then
if ! grep -q "ebesucher/restart.sh" "/tmp/ebesucher"; then
echo "0 * * * * /bin/bash /root/ebesucher/restart.sh
@reboot /bin/bash /root/ebesucher/restart.sh" >>/tmp/ebesucher
fi
else
if ! grep -q "ebesucher/restart.sh" "/tmp/ebesucher"; then
echo "0 * * * * /bin/bash /home/$linux_user/ebesucher/restart.sh
@reboot /bin/bash /home/$linux_user/ebesucher/restart.sh" >>/tmp/ebesucher
crontab /tmp/ebesucher
rm /tmp/ebesucher
fi
crontab -l >/tmp/rootcron
echo "0 0 * * 0 reboot" >>/tmp/rootcron
sudo crontab /tmp/rootcron
rm /tmp/rootcron
if ! grep -q "ebesucher/restart.sh" "/tmp/ebesucher"; then
echo "0 * * * * /bin/bash /root/ebesucher/restart.sh
@reboot /bin/bash /root/ebesucher/restart.sh
0 0 * * 0 reboot" >>/tmp/ebesucher
crontab /tmp/ebesucher
rm /tmp/ebesucher
fi
;;
esac
done
fi
if [ "$linux_user" == "root" ]; then
echo -e "#!/bin/bash\n\nexport DEBIAN_FRONTEND=noninteractive\n\nsudo apt-get update\n\nsudo apt-get upgrade -y\n\nsudo apt-get autoremove -y" >/root/update_system.sh
chmod +x /root/update_system.sh
else
echo -e "#!/bin/bash\n\nexport DEBIAN_FRONTEND=noninteractive\n\nsudo apt-get update\n\nsudo apt-get upgrade -y\n\nsudo apt-get autoremove -y" >/home/"$linux_user"/update_system.sh
chmod +x /home/"$linux_user"/update_system.sh
fi
echo -e "#!/bin/bash\n\nexport DEBIAN_FRONTEND=noninteractive\n\nsudo apt-get update\n\nsudo apt-get upgrade -y\n\nsudo apt-get autoremove -y" >/root/update_system.sh
chmod +x /root/update_system.sh
crontab -l >/tmp/updatecron
if ! grep -q "update_system.sh" "/tmp/updatecron"; then
if [ "$linux_user" == "root" ]; then
crontab -l /tmp/updatecron
echo "0 4 * * * /bin/bash /root/update_system.sh" >>/tmp/updatecron
crontab /tmp/updatecron
rm /tmp/crontab
else
sudo crontab -l /tmp/updatecron
echo "0 4 * * * /bin/bash /home/$linux_user/update_system.sh" >>/tmp/updatecron
sudo crontab /tmp/updatecron
rm /tmp/updatecron
fi
echo "0 4 * * * /bin/bash /root/update_system.sh" >>/tmp/updatecron
crontab /tmp/updatecron
rm /tmp/updatecron
fi
if docker ps | grep "ebesucher\|traffmonetizer\|peer2profit\|IPRoyal\|packetstream\|honeygain" >/dev/null; then
if docker run -d --name watchtower --restart=always -v /var/run/docker.sock:/var/run/docker.sock -v /etc/localtime:/etc/localtime:ro containrrr/watchtower --cleanup --interval 86400; then
erfolg "Watchtower erfolgreich eingerichtet"

View File

@@ -1,331 +0,0 @@
#!/bin/bash
red='\033[0;31m' # ${red}
white='\033[0;37m' # ${white}
yellow='\033[0;33m' # ${yellow}
lblue='\033[1;34m' # ${lblue}
cyan='\033[0;36m' # ${cyan}
purple='\033[0;35m' # ${purple}
Help() {
# Display Help
echo
echo -e "${purple}Benachrichtigungs Skript für Passive-Income (pain).${white}"
echo
echo "Ausführung: ./notifier.sh"
echo
echo "Für erneute Configuration: ./notifier.sh -c"
echo
echo "Argumente:"
echo -e "${yellow} -c${white} ${lblue}Starte die Konfiguration erneut"
echo -e "${yellow} -h${white} ${lblue}Zeige diese Hilfe"
echo
}
fehler() {
echo -e "${red}$1${white}"
}
Hinweis() {
echo -e "${yellow}$1${white}"
}
URLlink() {
echo -e "${cyan}$1${white}"
}
config="/opt/Passive-Income/NotificationHandler/config"
setup_config() {
while true; do
messagehandler=$(
whiptail --title "Wähle den Notifier" --menu "Nehme hier die Art der Benachrichtung die du haben willst." 20 100 9 \
"SurfbarName" "" \
"Discord" "" \
"Telegram" "" \
"Apprise" "" \
"NextcloudTalk" "" \
"PushBullet" "" \
"Email" "" \
"Rocket.Chat" "" \
"CronErstellen" "" \
"Beenden" "" 3>&2 2>&1 1>&3
)
case "$messagehandler" in
SurfbarName)
surflink=$(whiptail --title "Surfbar Link" --inputbox "Gebe hier den Namen deiner Surfbar ein\nBeispiel:\nHttps://www.ebesucher.de/surfbar/MeinSurfLink\nName ist hierbei: MeinSurfLink\nEs können auch mehrere eingegeben werden." 16 100 3>&2 2>&1 1>&3)
if [ -n "$surflink" ]; then
sed -i "s/SurfbarName=.*/SurfbarName=\"$surflink\"/g" $config
fi
;;
Discord)
dishook=$(whiptail --title "Discord Webhook URL" --inputbox "Gebe hier deine Discord Webhook URL ein" 16 100 3>&2 2>&1 1>&3)
if [ -n "$dishook" ]; then
sed -i "s|Discord_WebHookLink=.*|Discord_WebHookLink=\"$dishook\"|g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"Discord\"/g" $config
fi
;;
Telegram)
T_UI=$(whiptail --title "Telegram USER ID" --inputbox "Gebe hier deine Telegram USERID ein" 16 100 3>&2 2>&1 1>&3)
T_BotToken=$(whiptail --title "Telegram Bot Token" --inputbox "Gebe hier deinen Telegram Bot Token ein" 16 100 3>&2 2>&1 1>&3)
if [ -n "$T_UI" ]; then
sed -i "s/Telegram_UID=.*/Telegram_UID=\"$T_UI\"/g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"Telegram\"/g" $config
fi
if [ -n "$T_BotToken" ]; then
sed -i "s/Telegram_BT=.*/Telegram_BT=\"$T_BotToken\"/g" $config
fi
;;
Apprise)
AppRise_URL=$(whiptail --title "AppRise URL" --inputbox "Gebe hier die AppRise URL ein\nNötig ist hier die IP:Port. Beispiel:\n192.168.5.21:8000" 16 100 3>&2 2>&1 1>&3)
AppRise_URL_TAG=$(whiptail --title "AppRise Tag" --inputbox "Gebe hier einen AppRise Tag ein (Optional! Achtung, ohne Tag\nwerden alle Konfigurierten Methoden in Apprise genutzt)" 16 100 3>&2 2>&1 1>&3)
if [ -n "$AppRise_URL" ]; then
sed -i "s|AppRiseURL=.*|AppRiseURL=\"$AppRise_URL/notify/apprise\"|g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"Apprise\"/g" $config
fi
if [ -n "$AppRise_URL_TAG" ]; then
sed -i "s/AppRiseTAG=.*/AppRiseTAG=\"$AppRise_URL_TAG\"/g" $config
fi
;;
NextcloudTalk)
NextcloudDomain=$(whiptail --title "Nextcloud Domain" --inputbox "Gebe hier deine Nextcloud Domain/IP:Port ein\nBeispiel: 10.0.0.4:85 oder\nhttps://cloud.zephyre.one" 16 100 3>&2 2>&1 1>&3)
NextcloudTalkToken=$(whiptail --title "Nextcloud Talk Token" --inputbox "Gebe hier deinen Nextcloud Talk Chatroom Token ein\nhttps://cloud.zephyre.one/call/9gp9y99i\n9gp9y99i ist der benötigte Token" 16 100 3>&2 2>&1 1>&3)
NextcloudUser=$(whiptail --title "Nextcloud User" --inputbox "Gebe hier deinen Nextcloud User ein der die Nachricht schreiben soll.\nDer User muss dem Chatroom hinzugefügt werden!" 16 100 3>&2 2>&1 1>&3)
NextcloudPassword=$(whiptail --title "Nextcloud Password" --passwordbox "Gebe hier das Passwort von dem Nextcloud User ein" 16 100 3>&2 2>&1 1>&3)
if [ -n "$NextcloudDomain" ]; then
sed -i "s|NextcloudDomain=.*|NextcloudDomain=\"$NextcloudDomain\"|g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"NextCloud\"/g" $config
fi
if [ -n "$NextcloudTalkToken" ]; then
sed -i "s/NextcloudTalkToken=.*/NextcloudTalkToken=\"$NextcloudTalkToken\"/g" $config
fi
if [ -n "$NextcloudUser" ]; then
sed -i "s/NextcloudUser=.*/NextcloudUser=\"$NextcloudUser\"/g" $config
fi
if [ -n "$NextcloudPassword" ]; then
sed -i "s/NextcloudPassword=.*/NextcloudPassword=\"$NextcloudPassword\"/g" $config
fi
;;
PushBullet)
PBToken=$(whiptail --title "Pushbullet Token" --inputbox "Gebe hier deinen Pushbullet Token ein" 16 100 3>&2 2>&1 1>&3)
if [ -n "$PBToken" ]; then
sed -i "s/PushBulletToken=.*/PushBulletToken=\"$PBToken\"/g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"PushBullet\"/g" $config
fi
;;
Email)
smtpURL=$(whiptail --title "Nextcloud Domain" --inputbox "Gebe hier die SMTP Domain ein" 16 100 3>&2 2>&1 1>&3)
smtpPORT=$(whiptail --title "Nextcloud Talk Token" --inputbox "Gebe hier den SMTP Port an" 16 100 3>&2 2>&1 1>&3)
mailfrom=$(whiptail --title "Nextcloud User" --inputbox "Gebe hier die E-Mail an, die die Nachricht verschicken soll" 16 100 3>&2 2>&1 1>&3)
mailrcpt=$(whiptail --title "Nextcloud Password" --inputbox "Gebe hier die E-Mail an, die die Nachricht erhalten soll" 16 100 3>&2 2>&1 1>&3)
mailuser=$(whiptail --title "Nextcloud User" --inputbox "Gebe hier den User für die E-Mail an" 16 100 3>&2 2>&1 1>&3)
mailpass=$(whiptail --title "Nextcloud Password" --passwordbox "Gebe das Passwort des Users ein" 16 100 3>&2 2>&1 1>&3)
if [ -n "$smtpURL" ]; then
sed -i "s/smtpURL=.*/smtpURL=\"$smtpURL\"/g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"Email\"/g" $config
fi
if [ -n "$smtpPORT" ]; then
sed -i "s/smtpPORT=.*/smtpPORT=\"$smtpPORT\"/g" $config
fi
if [ -n "$mailfrom" ]; then
sed -i "s/mailfrom=.*/mailfrom=\"$mailfrom\"/g" $config
fi
if [ -n "$mailrcpt" ]; then
sed -i "s/mailrcpt=.*/mailrcpt=\"$mailrcpt\"/g" $config
fi
if [ -n "$mailuser" ]; then
sed -i "s/mailuser=.*/mailuser=\"$mailuser\"/g" $config
fi
if [ -n "$mailpass" ]; then
sed -i "s/mailpass=.*/mailpass=\"$mailpass\"/g" $config
fi
;;
Rocket.Chat)
RCHOOK=$(whiptail --title "Rocket Chat Webhook" --inputbox "Gebe hier deine Rocket.Chat Webhook ein" 16 100 3>&2 2>&1 1>&3)
if [ -n "$RCHOOK" ]; then
sed -i "s/RocketChatHook=.*/RocketChatHook=\"$RCHOOK\"/g" $config
sed -i "s/NotificationHandler=.*/NotificationHandler=\"Rocket.Chat\"/g" $config
fi
;;
CronErstellen)
cronloc="/tmp/crontab"
curr_dir=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)
scriptname=$(echo "$0" | sed 's/\.\///g')
crontab -l "$cronloc"
if grep -q "notifier.sh" $cronloc; then
if whiptail --title "Eintrag bereits vorhanden" --yesno "Es ist bereits ein eintrag für den notifier vorhanden, möchtest du diesen überschreiben?" 20 100; then
sed -i "s|.*notifier.sh.*|10,20,30,40,50 * * * * /bin/bash $curr_dir/$scriptname|g" "$cronloc"
crontab "$cronloc"
fi
else
echo "10,20,30,40,50 * * * * /bin/bash $curr_dir/$scriptname|g" >>"$cronloc"
crontab "$cronloc"
fi
;;
Beenden)
break
exit 0
;;
esac
break
exit
done
}
while getopts ":hc" option; do
case $option in
h) # display Help
Help
exit
;;
c) # Starte eine erneute Konfiguration
if ! [ -f "$config" ]; then
mkdir -p /opt/Passive-Income/NotificationHandler 2>/dev/null
wget -qO "$config" https://raw.githubusercontent.com/Pakobbix/passive-income/NotificationHandler/NotificationHandler/config
fi
setup_config
exit
;;
\?) # Invalid option
echo "Fehler: Ungültige Eingabe"
Help
exit
;;
esac
done
if ! [ -d "/opt/Passive-Income/NotificationHandler" ] || ! [ -f "$config" ]; then
mkdir -p /opt/Passive-Income/NotificationHandler 2>/dev/null
wget -qO "$config" https://raw.githubusercontent.com/Pakobbix/passive-income/NotificationHandler/NotificationHandler/config
setup_config
fi
source "$config"
if [ -z "$NotificationHandler" ]; then
setup_config
fi
if [ -z "$SurfbarName" ]; then
fehler "SurfbarName ist nicht gesetzt!"
Hinweis "Wenn du weiter drückst, wird die Konfiguration nochmal aufgerufen. Wähle hier dann SurfbarName um diesen zu Konfigurieren"
read -rp "Drücke eine beliebige Taste zum fortfahren"
setup_config
fi
for SurfbarLinks in $SurfbarName; do
ProcessID=$(pgrep -f "surfbar/$SurfbarLinks")
case $NotificationHandler in
Discord)
if [ -z "$Discord_WebHookLink" ]; then
fehler "Fehler! Discord wurde ausgewählt, aber keine WebHook angegeben!"
echo
Hinweis "Eine Anleitung für die Webhook findet ihr hier:"
URLlink "https://hookdeck.com/webhooks/platforms/how-to-get-started-with-discord-webhooks#how-do-i-add-a-webhook-to-discord"
exit 1
else
if [ -z "$ProcessID" ]; then
curl -i -H "Accept: application/json" -H "Content-Type:application/json" -X POST --data "{\"content\": \"Ebesucher ist Abgestürzt.\n$SurfbarLinks läuft nicht mehr\"}" "$Discord_WebHookLink" &>/dev/null
else
exit 1
fi
fi
;;
Telegram)
if [ -z "$Telegram_UID" ] || [ -z "$Telegram_BT" ]; then
fehler "Fehler! Discord wurde ausgewählt, aber keine WebHook angegeben!"
echo
Hinweis "Eine Anleitung für die Webhook findet ihr hier:"
URLlink "https://hookdeck.com/webhooks/platforms/how-to-get-started-with-discord-webhooks#how-do-i-add-a-webhook-to-discord"
exit 1
else
if [ -z "$ProcessID" ]; then
curl -X POST -H 'Content-Type: application/json' -d '{"chat_id": "'"$Telegram_UID"'", "text": "This is a test from curl", "disable_notification": true}' https://api.telegram.org/bot$Telegram_BT/sendMessage
else
exit 1
fi
fi
;;
Apprise)
if [ -z "$AppRiseURL" ]; then
fehler "Fehler! AppRise wurde ausgewählt, aber keine URL angegeben!"
echo
Hinweis "Eine Anleitung für AppRise findet ihr hier"
URLlink "https://github.com/caronc/apprise/wiki/config"
exit 1
else
if [ -z "$ProcessID" ]; then
if [ -n "$AppRiseTAG" ]; then
curl -d '{"body":"'"Ebesucher Container $SurfbarLinks ist down"'", "title":"Passive-Income Notification: Ebesucher ist Abgestürzt","tag":"'"$AppRiseTAG"'"}' -H "Content-Type: application/json" "$AppRiseURL" &>/dev/null
else
curl -d '{"body":"'"Ebesucher Container $SurfbarLinks ist down"'", "title":"Passive-Income Notification: Ebesucher ist Abgestürzt","tag":"all"}' -H "Content-Type: application/json" "$AppRiseURL" &>/dev/null
fi
else
exit 1
fi
fi
;;
NextCloud)
if [ -z "$NextcloudUser" ] || [ -z "$NextcloudPassword" ] || [ -z "$NextcloudDomain" ] || [ -z "$NextcloudTalkToken" ]; then
echo "Eine oder mehrere Variablen (NextcloudUser, NextcloudPassword, NextcloudDomain, und/oder NextcloudTalkToken) wurden nicht angegeben. Beende NotificationHandler!."
exit 1
else
if [ -z "$ProcessID" ]; then
curl -d '{"token":"'"$NextcloudTalkToken"'", "message":"'"Passive-Income Notification: Ebesucher ist Abgestürzt\nEbesucher Container $SurfbarLinks ist down"'"}' -H "Content-Type: application/json" -H "Accept:application/json" -H "OCS-APIRequest:true" -u "$NextcloudUser:$NextcloudPassword" "$NextcloudDomain"/ocs/v1.php/apps/spreed/api/v1/chat/tokenid &>/dev/null
fi
fi
;;
PushBullet)
if [ -z "$PushBulletToken" ]; then
fehler "Fehler! PushBullet wurde ausgewählt, aber kein Token angegeben!"
echo
Hinweis "Eine Anleitung für PushBullet findet ihr hier"
URLlink "https://www.pushbullet.com/"
exit 1
else
if [ -z "$ProcessID" ]; then
curl -u "$PushBulletToken": -X POST https://api.pushbullet.com/v2/pushes --header 'Content-Type: application/json' --data-binary '{"type": "note", "title": "Passive-Income Notification: Ebesucher ist Abgestürzt", "body": "Ebesucher Container '"$SurfbarLinks"' ist down"}'
else
exit 1
fi
fi
;;
Email)
if [ -z "$smtpURL" ] || [ -z "$smtpPORT" ] || [ -z "$mailfrom" ] || [ -z "$mailrcpt" ] || [ -z "$mailuser" ] || [ -z "$mailpass" ]; then
echo "Fehler! Mail wurde ausgewählt, aber eines oder mehrere Variablen leer gelassen!"
exit 1
else
if [ -z "$ProcessID" ]; then
echo "From: Passive-Income $mailfrom
To: $mailrcpt $mailrcpt
Subject: Passive-Income Notification: Ebesucher ist Abgestürzt
Hi $mailrcpt,
Your Ebesucher Container $SurfbarLinks ist abgestürzt und läuft nicht mehr.
Bye!" >/root/pain_watchmail
curl "smtps://$smtpURL:$smtpPORT" --mail-from "$mailfrom" --mail-rcpt "$mailrcpt" -T /root/pain_watchmail -u "$mailuser:$mailpass" --ssl-reqd --insecure --show-error -s
else
exit 1
fi
fi
;;
Rocket.Chat)
if [ -z "$RocketChatHook" ]; then
fehler "Fehler! RocketChat wurde ausgewählt, aber keine WebHook angegeben!"
echo
Hinweis "Eine Anleitung für die Webhook findet ihr hier:"
URLlink "https://docs.rocket.chat/use-rocket.chat/rocket.chat-workspace-administration/integrations"
exit 1
else
if [ -z "$ProcessID" ]; then
curl -X POST -H 'Content-Type: application/json' --data '{"text":"Passive-Income Notification: Ebesucher ist Abgestürzt","attachments":[{"title":"Passive-Income Notification: Ebesucher ist Abgestürzt","text":"Ebesucher Container '"$SurfbarLinks"' ist down","color":"#764FA5"}]}' "$RocketChatHook"
else
exit 1
fi
fi
;;
esac
done

View File

@@ -3,6 +3,18 @@
# Variablen für Benennung und Ebesucher Nutzernamen
username=
containername=ebesucher
# Variable für die Maximale Nutzung von CPU Cores
CPUcores=
# Überprüfe ob bereits ein restart läuft
if [ -f /tmp/ebesucher_restart.lock ]; then
exit
fi
# Erstelle Lockfile
echo $$ >/tmp/ebesucher_restart.lock
# Ordner des Skripts
git_dir=$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)
# Wechsel in den Ordner
@@ -19,22 +31,16 @@ unzip -qqo config.zip
# Warte 60s um die 120s Wartezeit von Ebesucher zu umgehen
sleep 60s
# Starte Ebesucher Firefox
docker_run(){
if [ -z "$username" ]; then
# Funktion zum starten des Containers, falls username nicht gesetzt
docker run -d --name="$containername" -p 3000:5800 -v "$git_dir"/config:/config:rw -m "$1" --shm-size 2g jlesage/firefox
else
# Funktion zum starten von Firefox immer mit der Surfbar (Verhindert dass bei Updates Firefox ein "neue Features" Tab über der Surfbar öffnet)
docker run -d --name="$containername" -p 3000:5800 -e FF_OPEN_URL="https://ebesucher.com/surfbar/$username" -m "$1" -v "$git_dir"/config:/config:rw --shm-size 2g jlesage/firefox
fi
docker_run() {
docker run -d --name="$containername" -p 3000:5800 -v "$git_dir"/config:/config:rw -m "$1" --cpus "$CPUcores" --shm-size 2g jlesage/firefox
}
# Überprüfe wieviel Arbeitsspeicher vorhanden ist, um bei Geräten mit weniger als 4 GB 1 GB als Sicherungs zu haben.
ram_avail=$(bc <<<"scale=2;$(($(free | awk 'NR==2 {print $2}') / 1000000))")
if [[ $ram_avail -ge "2" ]]; then
docker_run "1g"
elif [[ $ram_avail -eq "4" ]]; then
docker_run "3g"
if ((ram_avail >= 3 && ram_avail <= 4)); then
docker_run "3g" "$CPUSet"
elif [[ $ram_avail -ge "5" ]]; then
docker_run "4g"
docker_run "4g" "$CPUSet"
fi
rm -f /tmp/ebesucher_restart.lock