Dateien nach "/" hochladen
This commit is contained in:
parent
a233e51d67
commit
3f1330f850
55
installer1.0.5
Normal file
55
installer1.0.5
Normal file
@ -0,0 +1,55 @@
|
||||
#!/bin/bash
|
||||
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
|
||||
# Angemeldeten Benutzer ermitteln
|
||||
a_user=$(whoami)
|
||||
|
||||
mkdir -p /home/"$a_user"/.icons ; cp icons/* /home/"$a_user"/.icons/ ; mkdir -p /home/"$a_user"/.config/wg_nmcli
|
||||
|
||||
wait;
|
||||
echo "Icons erfolgreich installiert"
|
||||
wait;
|
||||
# abfrage ob yad installiert ist, wenn nicht dann installiere automatisch yad. Nur Debian basierende Systeme!
|
||||
|
||||
|
||||
if ! which yad >/dev/null
|
||||
then
|
||||
if grep -i 'mint\|debian\|ubuntu\|pop|' /etc/os-release > /dev/null 2>&1
|
||||
then
|
||||
sudo apt install yad
|
||||
|
||||
elif grep -i 'arch\|manjaro\|garuda\|endeavour|' /etc/os-release > /dev/null 2>&1
|
||||
then
|
||||
sudo pacman -S yad
|
||||
|
||||
elif grep -i 'fedora' /etc/os-release > /dev/null 2>&1
|
||||
then
|
||||
sudo dnf install yad
|
||||
|
||||
elif grep -i 'suse' /etc/os-release > /dev/null 2>&1
|
||||
then
|
||||
clear
|
||||
echo Achtung OpenSuse wird nicht offiziell unterstützt!
|
||||
echo Sie können yad nachinstallieren und Wire-G dann verwenden,
|
||||
echo oder den uninstaller ausführen um Wire-G zu entfernen
|
||||
|
||||
else
|
||||
echo Ihr system konnte nicht ermittelt werden.
|
||||
echo Bitte installieren sie yad noch auf iher Distro nach.
|
||||
echo Wire-G ist dann auch für ihr System bereit.
|
||||
fi
|
||||
fi
|
||||
|
||||
wait;
|
||||
sudo mkdir -p /usr/share/icons/Arch-Symbole ; sudo cp icons/wg-vpn.png /usr/share/icons/Arch-Symbole/
|
||||
wait;
|
||||
sudo cp wire_g wg_stop /sbin/ ; sudo chmod +x /sbin/wire_g ; sudo chmod +x /sbin/wg_stop
|
||||
wait; sudo cp Wire-G.desktop /usr/share/applications/
|
||||
echo
|
||||
echo "Installation erfolgreich!"
|
||||
read -n 1 -s -r -p "Zum Fenster schließen eine Taste drücken"
|
||||
clear
|
||||
|
||||
############################################ ENDE #########################################################
|
18
uninstaller1.0.0
Normal file
18
uninstaller1.0.0
Normal file
@ -0,0 +1,18 @@
|
||||
#!/bin/bash
|
||||
|
||||
a_user=$(whoami)
|
||||
cd
|
||||
rm -f /home/$a_user/.icons/wireguard-active.png wireguard-stop.png wireguard-vpn.png wg-import.png wg-trash.png wg-info.png
|
||||
wait;
|
||||
rm -r /home/$a_user/.config/wg_nmcli
|
||||
wait;
|
||||
sudo rm /usr/share/icons/Arch-Symbole/wireguard-vpn.png
|
||||
wait;
|
||||
sudo rm /sbin/wire_g ; sudo rm /sbin/wg_stop
|
||||
wait;
|
||||
sudo rm /usr/share/applications/Wire-G.desktop
|
||||
echo
|
||||
echo "deinstallation erfolgreich!"
|
||||
read -n 1 -s -r -p "Zum Fenster schließen eine Taste drücken"
|
||||
clear
|
||||
|
29
wg_stop
Normal file
29
wg_stop
Normal file
@ -0,0 +1,29 @@
|
||||
#!/bin/bash
|
||||
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
|
||||
a_user=$(whoami)
|
||||
wg_wdir="/home/$a_user/.config/wg_nmcli/"
|
||||
wg_pic="/home/$a_user/.icons/"
|
||||
#Damit wird der inhalt von /home/$a_user/.config/wg_nmcli/.tunnel.txt in ein Array gespeichert
|
||||
IFS=$'\n' lines=( $(cat ${wg_wdir}.tunnel.txt) )
|
||||
#echo ${lines[0]} #Damit wird der Inhalt ausgelesen. (Index angeben)
|
||||
wert=$"*_*"
|
||||
for wert in "${lines[@]}"
|
||||
do
|
||||
# rm /home/$a_user/.config/wg_nmcli/.tunnel.txt # falls Wireguard nicht richtig funktioniert hier die # wegnehmen
|
||||
# hier wird die Ausgabe von nmcli für die auswertung in die .stop.txt gespeichert
|
||||
nmcli connection down $wert &> ${wg_wdir}.stop.txt
|
||||
disable=$(grep -i "deaktiviert" ${wg_wdir}.stop.txt)
|
||||
if [ "$?" = "0" ]
|
||||
then
|
||||
notify-send --icon=${wg_pic}wg-stop.png "$wert Verbindung wurde getrennt."
|
||||
pkill yad
|
||||
fi
|
||||
done
|
||||
|
||||
|
||||
################################# ENDE #################################################################
|
||||
############################################################################################################
|
||||
|
159
wire_g
Normal file
159
wire_g
Normal file
@ -0,0 +1,159 @@
|
||||
#!/bin/bash
|
||||
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
|
||||
# Angemeldeten Benutzer ermitteln
|
||||
a_user=$(whoami)
|
||||
# wg_workdir Arbeitsverzeichnis wg
|
||||
wg_wdir="/home/$a_user/.config/wg_nmcli/"
|
||||
# Pfad wg Icons
|
||||
wg_pic="/home/$a_user/.icons/"
|
||||
# Wireguard tunnel auslesen mit grep nur Wireguard zeigen
|
||||
# mit sed alles nach dem ersten Leerzeichen bis Zeilenende weggeschneiden und .tunnel.txt schreiben
|
||||
nmcli connection show | grep -iPo "(.*)(wireguard)" | sed 's/ .*//' > ${wg_wdir}.tunnel.txt
|
||||
# Variable der verfügbaren Tunnelanzeige für Yad
|
||||
tunnel=$(nmcli connection show | grep -iPo "(.*)(wireguard)" | sed 's/ .*//')
|
||||
# Variable der aktiven Tunnelanzeige für Yad
|
||||
active=$(nmcli connection show --active | grep -iPo "(.*)(wireguard)" | sed 's/ .*//')
|
||||
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
# funktion wg_notify
|
||||
|
||||
wg_notify(){
|
||||
|
||||
a_user=$(whoami)
|
||||
active=$(nmcli connection show --active | grep -iPo "(.*)(wireguard)" | sed 's/ .*//')
|
||||
wg_pic="/home/$a_user/.icons/"
|
||||
notify-send --icon=${wg_pic}wg-vpn.png "$active eingeschaltet"
|
||||
# autoconnect wird hier abgeschalten damit auch neu importierte nach einem Systemneustart nicht aktiv sind
|
||||
nmcli con mod $active connection.autoconnect no
|
||||
# ab hier beginnt yad notify
|
||||
#Pipe erstellen
|
||||
PIPE="$HOME/.pipe.tmp"
|
||||
rm $PIPE
|
||||
mkfifo $PIPE
|
||||
exec 3<> $PIPE
|
||||
#Yad Dialog erstellen
|
||||
yad --notification --listen --command=wire_g --icon-size=32 --no-middle <&3 &
|
||||
#Menüeinträge definieren
|
||||
echo "menu:\
|
||||
$active stop!/sbin/wg_stop| " >&3
|
||||
#Icon des Menübuttons definieren
|
||||
echo "icon:${wg_pic}wg-vpn.png" >&3
|
||||
#Name des Menüs definieren
|
||||
echo "tooltip:$active aktiv" >&3
|
||||
|
||||
}
|
||||
export -f wg_notify
|
||||
|
||||
# function end
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
# funktion wireguard import
|
||||
|
||||
import_wg(){
|
||||
a_user=$(whoami)
|
||||
wg_pic="/home/$a_user/.icons/"
|
||||
wg_wdir="/home/$a_user/.config/wg_nmcli/"
|
||||
wgconf=$(yad --file --separator=" \n" \
|
||||
--button="OK" --button="Abbrechen" \
|
||||
--width=1200 --height=800 \
|
||||
--window-icon=${wg_pic}wg-import.png \
|
||||
--title="Wireguard .conf Datei auswählen")
|
||||
if [ "$?" = "0" ]
|
||||
then
|
||||
wg_stop
|
||||
nmcli connection import type wireguard file $wgconf > ${wg_wdir}.tmp.txt
|
||||
wg_notify
|
||||
fi }
|
||||
export -f import_wg
|
||||
|
||||
# function end
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
# funktion wireguard remove
|
||||
|
||||
remove(){
|
||||
a_user=$(whoami)
|
||||
wg_pic="/home/$a_user/.icons/"
|
||||
wg_wdir="/home/$a_user/.config/wg_nmcli/"
|
||||
tunnel=$(nmcli connection show | grep -iPo "(.*)(wireguard)" | sed 's/ .*//')
|
||||
nmcli connection show --active | grep -iPo "(.*)(wireguard)" | sed 's/ .*//' &> ${wg_wdir}.wg_noactive.txt
|
||||
active=$(cat ${wg_wdir}.wg_noactive.txt)
|
||||
|
||||
selection=$(yad --no-click --list --height=300 --width=60 \
|
||||
--title="Wire-G Trash" \
|
||||
--fixed --buttons-layout=center \
|
||||
--button="OK" --button="Abbrechen" \
|
||||
--separator="" --window-icon=${wg_pic}wg-trash.png \
|
||||
--borders=8 --column 'Löschen' $tunnel)
|
||||
if [ "$?" = "0" ]
|
||||
then
|
||||
nmcli connection delete $selection &> ${wg_wdir}.tmp.txt
|
||||
erfolg=$(grep -i "Verbindung erfolgreich gelöscht" ${wg_wdir}.tmp.txt)
|
||||
if [ "$?" = "0" ]
|
||||
then
|
||||
yad --window-icon=${wg_pic}wg-trash.png \
|
||||
--image-on-top --image=${wg_pic}wg-info.png \
|
||||
--text="Oh etwas ging schief.\nBitte Tunnel im Networkmanager löschen." \
|
||||
--text-align=center --button="OK" --title "Wire-G Trash" \
|
||||
--fixed --center --buttons-layout=center --borders=8 --center
|
||||
else
|
||||
yad --window-icon=${wg_pic}wg-trash.png \
|
||||
--image-on-top --image=${wg_pic}wg-info.png \
|
||||
--text="Ihr Tunnel $selection wurde erfolgreich gelöscht.\n" \
|
||||
--text-align=center --button="OK" --title "Wire-G Trash" \
|
||||
--fixed --center --buttons-layout=center --borders=8 --center
|
||||
fi
|
||||
if [ $selection = $active ]
|
||||
then
|
||||
pkill wire_g
|
||||
pkill yad
|
||||
fi
|
||||
fi }
|
||||
export -f remove
|
||||
|
||||
# function end
|
||||
############################################################################################################
|
||||
############################################################################################################
|
||||
# funktion wireguard enable select Tunnel
|
||||
|
||||
connect(){
|
||||
|
||||
erfolg=$(grep -i "Verbindung wurde erfolgreich aktiviert" ${wg_wdir}.tmp.txt)
|
||||
if [ "$?" = "0" ]
|
||||
then
|
||||
nmcli con mod $selection connection.autoconnect no
|
||||
wg_notify
|
||||
fi }
|
||||
|
||||
# function end
|
||||
############################################################################################################
|
||||
############################################################################################################ # --text "<b>Aktiver Tunnel:</b> <span color='#0fad0a'><b>$active</b></span> # mit <b>gewünschtes wort</b> wird fett geschrieben.
|
||||
# hiermit wird die Farbe für Variable $active festgelegt mit fetter Schrift.
|
||||
|
||||
selection=$(yad --no-click --list \
|
||||
--close-on-unfocus --tab=Löschen \
|
||||
--height=300 --width=60 --title="Wire-G" \
|
||||
--fixed --buttons-layout=center \
|
||||
--button="OK" --button="Abbrechen" \
|
||||
--button=Importieren:"bash -c import_wg" \
|
||||
--button=Entfernen:"bash -c remove" --separator="" \
|
||||
--window-icon=${wg_pic}wg-vpn.png \
|
||||
--borders=8 --image-on-top --image=${wg_pic}wg-active.png \
|
||||
--text "<b>Aktiver Tunnel: </b> <span color='#0fad0a'><b>$active</b></span>
|
||||
<b>----------------------------------------------------------------------------------</b>
|
||||
<b>Sollten keine Tunnel aufgelistet sein,</b>
|
||||
<b>so müssen sie ihren Tunnel zuvor importieren.</b>" \
|
||||
--column 'Auswahl' $tunnel)
|
||||
if [ "$?" = "0" ]
|
||||
then
|
||||
wg_stop
|
||||
nmcli connection up $selection &> ${wg_wdir}.tmp.txt
|
||||
connect
|
||||
fi
|
||||
|
||||
############################################ ENDE #########################################################
|
||||
|
7
wireguard.desktop
Normal file
7
wireguard.desktop
Normal file
@ -0,0 +1,7 @@
|
||||
[Desktop Entry]
|
||||
Type=Application
|
||||
Name=Wire-G
|
||||
Exec=/sbin/wire_g
|
||||
Terminal=false
|
||||
Categories=Internet;Browser;
|
||||
Icon=/usr/share/icons/Arch-Symbole/wg-vpn.png
|
Loading…
x
Reference in New Issue
Block a user