2005-02-11 00:06:43 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
|
|
|
|
# Beginn des Scripts
|
2005-02-11 00:42:02 +00:00
|
|
|
HOMEDIR=/home/WGDialer/
|
2005-02-11 00:06:43 +00:00
|
|
|
PIDDatei=${HOMEDIR}data/WGDialer.pid
|
|
|
|
WarteSekunden=2
|
|
|
|
WarteSchleifen=10
|
|
|
|
OUTDEV="ippp0"
|
|
|
|
ScriptLog=${HOMEDIR}data/WGDialer.log
|
2005-02-11 00:42:02 +00:00
|
|
|
WGET="/usr/bin/wget --spider http://www.freenet.de &>${HOMEDIR}data/wget.log"
|
|
|
|
IPTABLES="sudo /sbin/iptables"
|
2005-02-11 00:06:43 +00:00
|
|
|
DialerModem="/usr/bin/wvdial"
|
|
|
|
DialerISDN="/usr/sbin/isdnctrl"
|
|
|
|
DialPIDDatei=${HOMEDIR}data/dialer.pid
|
|
|
|
SitzungsPrefix=${HOMEDIR}data/sitzung/
|
|
|
|
NutzerLogPrefix=${HOMEDIR}data/nutzer/
|
|
|
|
AdminFehlerLog=${HOMEDIR}data/fehler.log
|
|
|
|
AdminLog=${HOMEDIR}data/meldungen.log
|
|
|
|
DialerStatus=${HOMEDIR}data/dialer.info
|
|
|
|
# enthaelt Namen des Verbindungsaufbauenden / Einwahltarif
|
|
|
|
DialerLog=${HOMEDIR}data/dialer.log
|
|
|
|
NutzerListenDatei=${HOMEDIR}data/nutzer.liste
|
|
|
|
VerbindungsWunschDatei=${HOMEDIR}data/verbindungs.anforderung
|
|
|
|
|
|
|
|
# Format der Nutzerdateien:
|
|
|
|
# "Datum (lesbar)" "Datum (auswertbar)" "Kostensatz" "Anzahl der Teilnehmer" "Kosten der Teilverbindung" "Dauer"
|
|
|
|
# Format der Sitzungsdateien:
|
|
|
|
# "Beginn der/s Verbindung(-sabschnitts) in Sek. seit 1970" /
|
|
|
|
# "lesbares Datum"
|
|
|
|
|
|
|
|
|
|
|
|
# Format der Nutzerlistendatei:
|
|
|
|
# "Nutzername" "IP"
|
|
|
|
|
|
|
|
# Format der Dialer-Status-Datei:
|
|
|
|
# "Kosten" folgende Zeilen: "Name der/s Einwaehlenden"
|
|
|
|
|
|
|
|
################## der Dialer ############################
|
|
|
|
|
|
|
|
function istDialerGestartet()
|
|
|
|
{
|
|
|
|
local istGestartet
|
|
|
|
istGestartet="falsch"
|
|
|
|
if test $OUTDEV = "ppp0"; then
|
|
|
|
if test -e "$DialPIDDatei"; then
|
|
|
|
local dialPID=`cat $DialPIDDatei`
|
2005-02-11 00:42:02 +00:00
|
|
|
local t=`ps -p $dialPID -o cmd|tail -1 | cut -f 1 -d " "`
|
2005-02-11 00:06:43 +00:00
|
|
|
if test "$DialerModem" != "$t"; then
|
|
|
|
AdminFehler "Dial-PID-Datei enthaelt fehlerhaften Verweis"
|
|
|
|
rm $DialPIDDatei
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
test -e "$DialPIDDatei" && istGestartet="wahr"
|
|
|
|
else
|
2005-02-11 00:42:02 +00:00
|
|
|
local ctlStatus=`${DialerISDN} status $OUTDEV | grep "not connected"`
|
|
|
|
test -z "$ctlStatus" && istGestartet="wahr"
|
2005-02-11 00:06:43 +00:00
|
|
|
fi
|
|
|
|
test $istGestartet = "wahr"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function beendeDialer()
|
|
|
|
{
|
|
|
|
if istDialerGestartet; then
|
|
|
|
AdminNachricht "Der Dialer wird beendet ..."
|
|
|
|
if test "$OUTDEV" = "ppp0"; then
|
|
|
|
kill `cat $DialPIDDatei`
|
|
|
|
else
|
|
|
|
$DialerISDN hangup $OUTDEV
|
|
|
|
fi
|
|
|
|
# jetzt sollte die Aufraeumaktion gestartet werden
|
|
|
|
test -e $DialPIDDatei && rm $DialerStatus
|
|
|
|
DialerIstBeendet
|
|
|
|
test -n "X"
|
|
|
|
else
|
|
|
|
AdminFehler "beendeDialer: nicht gestartet"
|
|
|
|
test -z "X"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function starteDialer()
|
|
|
|
{
|
|
|
|
if istDialerGestartet; then
|
|
|
|
AdminFehler "Dialer lief bereits ohne aktive Nutzer!"
|
|
|
|
test -n "X"
|
|
|
|
fi
|
|
|
|
holeProviderInfo Preis
|
|
|
|
local preis=$ERG
|
|
|
|
test 0 -gt $preis && AdminFehler "sD: Kostenlose Verbindung?"
|
|
|
|
holeProviderInfo Name
|
|
|
|
local name=$ERG
|
|
|
|
AdminNachricht "Aufbau der Verbindung"
|
|
|
|
echo -e "$preis\t$name" >$DialerStatus
|
|
|
|
if test -e $VerbindungsWunschDatei; then
|
|
|
|
cat $VerbindungsWunschDatei >>$DialerStatus
|
|
|
|
test -n "X"
|
|
|
|
else
|
|
|
|
AdminFehler "sD: keine Verb.-Anforderungen!"
|
|
|
|
test -z "X"
|
|
|
|
fi
|
|
|
|
echo -e "\n`date` - ######## Start des Waehlprogramms #########" >>$DialerLog
|
|
|
|
if test $OUTDEV = "ppp0"; then
|
|
|
|
$DialerModem $name >>$DialerLog 2>>$DialerLog &
|
|
|
|
local pid=$!
|
|
|
|
echo $pid >$DialPIDDatei
|
|
|
|
else
|
|
|
|
# die Auswahl des Tarifs erfolgt extern per cron
|
|
|
|
$DialerISDN dial $OUTDEV
|
|
|
|
fi
|
|
|
|
istDialerGestartet
|
|
|
|
# damit der Rueckgabestatus stimmt
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Aufraeumarbeiten
|
|
|
|
function DialerIstBeendet()
|
|
|
|
{
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local anz=$ERG
|
|
|
|
test $anz -gt 0 && AdminFehler "Dialer beendet trotz aktiver Nutzer"
|
|
|
|
trenneAlleVerbindungen
|
|
|
|
test $OUTDEV = "ppp0" -a -e "$DialPIDDatei" && rm $DialPIDDatei
|
|
|
|
test -e "$DialerStatus" && rm $DialerStatus
|
|
|
|
test -e "$VerbindungsWunschDatei" && rm $VerbindungsWunschDatei
|
|
|
|
test $anz -eq 0
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
############ Protokollierung ##################
|
|
|
|
|
|
|
|
function aktiviereSkriptLog()
|
|
|
|
{
|
|
|
|
exec 2>>$ScriptLog
|
|
|
|
echo -e "\n\nSitzungsbeginn:" `date` >> ${HOMEDIR}data/WGDialer.log
|
|
|
|
|
2005-02-11 00:42:02 +00:00
|
|
|
#set -xu
|
|
|
|
# jede Zeile ausgeben
|
|
|
|
set -u
|
|
|
|
# Fehler nr bei undeklarierten Variablen melden
|
2005-02-11 00:06:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function AdminNachricht() # Para: Text
|
|
|
|
{
|
|
|
|
echo -e "`date` - $1" >>$AdminLog
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function AdminFehler() # Para: Text
|
|
|
|
{
|
|
|
|
AdminNachricht "Fehler: $1"
|
|
|
|
echo -e "`date` - $1" >>$AdminFehlerLog
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
################ Konsistenz ################
|
|
|
|
|
|
|
|
function pruefeStatus()
|
|
|
|
{
|
|
|
|
holeAktiveNutzer
|
|
|
|
local nutzer=$ERG
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local AnzahlNutzer=$ERG
|
|
|
|
local t=
|
|
|
|
test -e $VerbindungsWunschDatei && (istDialerGestartet || (t="? Verbindungswuensche ohne gestarteten Dialer" && rm $VerbindungsWunschDatei))
|
|
|
|
if test 0 -lt $AnzahlNutzer; then
|
|
|
|
istDialerGestartet || (t="? Nutzer ($nutzer) ohne Verbindung -> Trennung" && trenneAlleVerbindungen)
|
|
|
|
fi
|
|
|
|
test 0 -eq $AnzahlNutzer -a ! -e $VerbindungsWunschDatei && istDialerGestartet && (beendeDialer; t="? Verbindung ohne Nutzer")
|
|
|
|
test -e $NutzerListenDatei || t="? keine Nutzerlistendatei vorhanden!"
|
|
|
|
test -n "$t" && AdminFehler "$t"
|
|
|
|
test -z "$t"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# pruefe, ob Skript bereits aktiv, falls ja, dann bis zu sechs Sekunden auf
|
|
|
|
# Ende des Parallelprozesses warten, sonst Abbruch
|
|
|
|
function pruefeWeitereInstanz()
|
|
|
|
{
|
|
|
|
local count=0
|
|
|
|
local PID
|
|
|
|
local COMMAND
|
|
|
|
while test "$1" != "reset" -a -e $PIDDatei -a $WarteSchleifen -gt $count; do
|
|
|
|
PID=`cat $PIDDatei`
|
|
|
|
if test -z "$PID"; then
|
|
|
|
rm $PIDDatei
|
|
|
|
else
|
|
|
|
COMMAND=`ps -p $PID -o comm |tail -1`
|
|
|
|
if test `echo $0 | grep $COMMAND | wc -l` -eq 0; then
|
|
|
|
test -e $PIDDatei && rm $PIDDatei
|
|
|
|
else
|
|
|
|
let count=count+1
|
|
|
|
sleep $WarteSekunden
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
test -e $PIDDatei && AdminFehler "p-w-I: Wartezeit ueberschritten" && exit 1
|
|
|
|
trap "rm $PIDDatei" 0
|
|
|
|
echo $$ > $PIDDatei
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
################### Sitzungsverwaltung ####################
|
|
|
|
|
|
|
|
# sollte nur von "aktualisiereAlleSitzungen" aufgerufen werden
|
|
|
|
function verarbeiteSitzungsDatei() # Para: Nutzername
|
|
|
|
{
|
|
|
|
function holeSitzungsDauer() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local jetzt=`date +%s`
|
|
|
|
local beginn=`tail -1 $SitzungsPrefix$1 | cut -f 1`
|
|
|
|
let ERG=jetzt-beginn
|
|
|
|
}
|
|
|
|
# liefert die Pro-Minute-Kosten der atuell gewaehlten Verbindung
|
|
|
|
function holeAktuellenKostenSatz()
|
|
|
|
{
|
|
|
|
ERG="`head -1 $DialerStatus|cut -f 1`"
|
|
|
|
test -n "X"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeSitzungsKosten() # Para: Nutzername
|
|
|
|
{
|
|
|
|
holeAktuellenKostenSatz
|
|
|
|
local pro=$ERG
|
|
|
|
holeSitzungsDauer $1
|
|
|
|
local dauer
|
|
|
|
local gesamtKosten
|
|
|
|
let dauer=ERG+45
|
|
|
|
# "45" als Korrektur wegen der Minutenabrechnung
|
|
|
|
let gesamtKosten=pro*dauer/60
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local anz=$ERG
|
|
|
|
let ERG=gesamtKosten/anz
|
|
|
|
#test 0 -eq $ERG && AdminFehler "hSK: kostenfrei ($pro/$dauer/$anz)?"
|
|
|
|
test -n "X"
|
|
|
|
}
|
|
|
|
|
|
|
|
holeSitzungsKosten $1
|
|
|
|
local kosten=$ERG
|
|
|
|
holeSitzungsDauer $1
|
|
|
|
local dauer=$ERG
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local anz=$ERG
|
|
|
|
holeAktuellenKostenSatz
|
|
|
|
local kostenSatz
|
|
|
|
let kostenSatz=ERG/anz
|
|
|
|
echo -e "`date`\t`date +%Y%m%d`\t$kostenSatz\t$anz\t$kosten\t$dauer" >>$NutzerLogPrefix$1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# liefert "Preis" oder "Name (Dialer-Parameter)"
|
|
|
|
function holeProviderInfo() # gewuenschte Information
|
|
|
|
# WICHTIG: Aenderung, damit angewaehlter Tarif bezahlt wird
|
|
|
|
{
|
|
|
|
# Provider: 0 - Freenet-Super (Nebenzeit)
|
|
|
|
# 1 - Freenet-Super (Hauptzeit)
|
|
|
|
# 2 - Freenet-XXL (Sonntags)
|
|
|
|
local prov
|
|
|
|
local jetzt="`date +%H%M`" # liefert die aktuelle Stunde
|
|
|
|
if test $jetzt -lt 730; then
|
|
|
|
prov=0
|
|
|
|
elif test $jetzt -lt 1730; then
|
|
|
|
prov=1
|
|
|
|
elif test $jetzt -lt 2130; then
|
|
|
|
prov=0
|
|
|
|
else
|
|
|
|
prov=0
|
|
|
|
fi
|
|
|
|
local tag="`date +%w`"
|
|
|
|
test $tag -eq 0 -o $tag -eq 6 && prov=0
|
|
|
|
test $tag -eq 0 && prov=2
|
|
|
|
local preis
|
|
|
|
local name
|
|
|
|
case $prov in
|
|
|
|
0 ) preis=99; name="FreeNet-Super";;
|
2005-02-11 00:42:02 +00:00
|
|
|
# 1 ) preis=145; name="FreeNet-Super";;
|
|
|
|
1 ) preis=99; name="FreeNet-Super";;
|
2005-02-11 00:06:43 +00:00
|
|
|
2 ) preis=0; name="FreeNet-XXL";;
|
|
|
|
esac
|
|
|
|
if test "$1" = "Preis"; then ERG=$preis
|
|
|
|
elif test "$1" = "Name"; then ERG="$name"
|
|
|
|
else AdminFehler "ProviderInfo: fehlerhafte Anfrage"
|
|
|
|
fi
|
|
|
|
test -n "X"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function aktualisiereAlleSitzungen()
|
|
|
|
{
|
|
|
|
local SITZUNG
|
|
|
|
holeAktiveNutzer
|
|
|
|
local aktiveNutzer="$ERG"
|
|
|
|
if test -n "$aktiveNutzer"; then
|
|
|
|
for SITZUNG in $aktiveNutzer; do
|
|
|
|
verarbeiteSitzungsDatei $SITZUNG
|
|
|
|
erstelleSitzungsDatei $SITZUNG
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
test -n "X"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function loescheSitzungsDatei() # Para: Nutzername
|
|
|
|
{
|
|
|
|
rm $SitzungsPrefix$1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function erstelleSitzungsDatei() # Para: Nutzername
|
|
|
|
{
|
|
|
|
echo -e "`date +%s`" >$SitzungsPrefix$1
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
################# Nutzerverwaltung ####################
|
|
|
|
|
|
|
|
function holeAktiveNutzer()
|
|
|
|
{
|
|
|
|
ERG=`ls $SitzungsPrefix`
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeAnzahlNutzer()
|
|
|
|
{
|
|
|
|
ERG=`ls $SitzungsPrefix|wc -l`
|
|
|
|
local aN=`ls $SitzungsPrefix`
|
|
|
|
test -z "$aN" && ERG=0
|
|
|
|
test -n "X"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function verbindeNutzer() # Parameter: Nutzername
|
|
|
|
{
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local anz=$ERG
|
|
|
|
if test 0 -eq $anz; then
|
|
|
|
meldeVerbindungsWunschAn $1
|
|
|
|
istDialerGestartet || starteDialer
|
|
|
|
elif istNutzerAktiv $1; then
|
|
|
|
AdminFehler "$1 versucht sich mehrfach anzumelden"
|
|
|
|
else
|
|
|
|
test 0 -lt $anz && NutzerVerbindungenHergestellt $1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function NutzerVerbindungenHergestellt() # Para: Nutzernamen
|
|
|
|
{
|
|
|
|
holeAnzahlNutzer
|
|
|
|
test 0 -lt $ERG && aktualisiereAlleSitzungen
|
|
|
|
local nutzer
|
|
|
|
for nutzer in $1; do
|
|
|
|
if istNutzerOK "$nutzer"; then
|
|
|
|
AdminNachricht "$nutzer oeffnet die Verbindung"
|
|
|
|
erstelleSitzungsDatei $nutzer
|
|
|
|
else
|
|
|
|
AdminFehler "ungueltiger Nutzer: $nutzer"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
aktualisiereWeiterleitungen
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeVerbindungsStatus()
|
|
|
|
{
|
|
|
|
local zustand="unzulaessiger Status"
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local anz=$ERG
|
|
|
|
test 0 -lt $anz && zustand="verbunden"
|
|
|
|
istDialerGestartet || zustand="getrennt"
|
|
|
|
test -e $VerbindungsWunschDatei && zustand="Waehlvorgang"
|
|
|
|
ERG=$zustand
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeNutzerStatus() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local status="unbekannter Nutzer"
|
|
|
|
istNutzerOK $1 && status="getrennt"
|
|
|
|
istNutzerAktiv $1 && status="verbunden"
|
|
|
|
istNutzerBeiEinwahl $1 && status="bei der Einwahl"
|
|
|
|
ERG=$status
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeIPdesNutzers() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local aNutzer="`cat $NutzerListenDatei`"
|
|
|
|
local ip="unbekannt"
|
|
|
|
local nutzer
|
|
|
|
local tName
|
|
|
|
local tIP
|
|
|
|
for nutzer in $aNutzer; do
|
|
|
|
if test -z "$tName"; then
|
|
|
|
tName="`echo $nutzer|cut -f 1`"
|
|
|
|
else
|
|
|
|
tIP="`echo $nutzer|cut -f 1`"
|
|
|
|
test "$1" = "$tName" && ip=$tIP
|
|
|
|
tName=
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
ERG=$ip
|
|
|
|
test "$ip" != "unbekannt"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeNutzerDerIP() # Para: IP
|
|
|
|
{
|
|
|
|
local a5Nutzer="`cat $NutzerListenDatei`"
|
|
|
|
local name="unbekannt"
|
|
|
|
local nutzer
|
|
|
|
local tName
|
|
|
|
local tIP
|
|
|
|
for nutzer in $a5Nutzer; do
|
|
|
|
if test -z "$tName"; then
|
2005-02-11 00:42:02 +00:00
|
|
|
tName="`echo \"$nutzer\"|cut -f 1`"
|
2005-02-11 00:06:43 +00:00
|
|
|
else
|
2005-02-11 00:42:02 +00:00
|
|
|
tIP="`echo \"$nutzer\"|cut -f 1`"
|
2005-02-11 00:06:43 +00:00
|
|
|
test "$1" = "$tIP" && name=$tName
|
|
|
|
tName=
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
ERG=$name
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function istNutzerAktiv() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local gefunden=nein
|
|
|
|
holeAktiveNutzer
|
|
|
|
local a2Nutzer="$ERG"
|
|
|
|
local nutzer
|
|
|
|
for nutzer in $a2Nutzer; do
|
|
|
|
test "$nutzer" = "$1" && gefunden=ja
|
|
|
|
done
|
|
|
|
test "$gefunden" = "ja"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function istNutzerOK() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local a3Nutzer="`cat $NutzerListenDatei|cut -f 1`"
|
|
|
|
local gefunden="nein"
|
|
|
|
local name
|
|
|
|
for name in $a3Nutzer; do
|
|
|
|
test "$name" = "$1" && gefunden="ja"
|
|
|
|
done
|
|
|
|
test "$gefunden" = "ja"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function istNutzerBeiEinwahl() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local gefunden=nein
|
|
|
|
if test -e "$VerbindungsWunschDatei"; then
|
|
|
|
local nutzer
|
|
|
|
for nutzer in `cat $VerbindungsWunschDatei`; do
|
|
|
|
test "$nutzer" = "$1" && gefunden=ja
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
test "$gefunden" = "ja"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function meldeVerbindungsWunschAn() # Para: Nutzername
|
|
|
|
{
|
|
|
|
echo $1 >>$VerbindungsWunschDatei
|
|
|
|
AdminNachricht "$1 meldet Verbindungswunsch an"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function holeAnzahlVerbindungsWuensche()
|
|
|
|
{
|
|
|
|
local anz=0
|
|
|
|
test -s "$VerbindungsWunschDatei" && anz=`cat $VerbindungsWunschDatei|wc -l`
|
|
|
|
# "test -s" -> pruefe ob Datei groesser Null ist
|
|
|
|
test $anz -le 0 && AdminFehler "hAVW: ungueltige Anzahl von Verbindungswuenschen ($anz)!"
|
|
|
|
test -s "$VerbindungsWunschDatei" || AdminFehler "hAVW: fehlende (oder leere) Verbindungswunschdatei!"
|
|
|
|
ERG=$anz
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function erfuelleVerbindungsWuensche()
|
|
|
|
{
|
|
|
|
if test -f "$VerbindungsWunschDatei"; then
|
|
|
|
local wuensche="`cat $VerbindungsWunschDatei`"
|
|
|
|
NutzerVerbindungenHergestellt "$wuensche"
|
|
|
|
rm "$VerbindungsWunschDatei"
|
|
|
|
else
|
|
|
|
AdminFehler "keine Verbindungswuensche vorhanden!"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function entferneNutzerAusWunschDatei() # Para: Nutzername
|
|
|
|
{
|
|
|
|
local alle="`cat $VerbindungsWunschDatei`"
|
|
|
|
rm $VerbindungsWunschDatei
|
|
|
|
local einer
|
|
|
|
for einer in $alle; do
|
|
|
|
test "$einer" != "$1" && echo $einer >>$VerbindungsWunschDatei
|
|
|
|
done
|
|
|
|
test -e "$VerbindungsWunschDatei" || beendeDialer && AdminNachricht "Nutzer $1 trennt vor Verbindungsaufbau"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function trenneNutzer() # Para: Nutzername
|
|
|
|
{
|
|
|
|
if istNutzerBeiEinwahl $1; then
|
|
|
|
entferneNutzerAusWunschDatei $1
|
|
|
|
if istNutzerBeiEinwahl $1; then
|
|
|
|
AdminFehler "Nutzer konnte nicht aus Wunschdatei entfernt werden: $1"
|
|
|
|
test -z "X"
|
|
|
|
else AdminNachricht "Nutzer widerruft Verbindungswunsch: $1"
|
|
|
|
test -n "X"
|
|
|
|
fi
|
|
|
|
elif istNutzerAktiv $1; then
|
|
|
|
aktualisiereAlleSitzungen
|
|
|
|
loescheSitzungsDatei $1
|
|
|
|
aktualisiereWeiterleitungen
|
|
|
|
istNutzerAktiv $1 || AdminNachricht "$1 trennt die Verbindung"
|
|
|
|
holeAnzahlNutzer
|
|
|
|
test $ERG -eq 0 && beendeDialer && AdminNachricht "keine weiteren Nutzer nach $1 - Trennung"
|
|
|
|
if istNutzerAktiv $1; then
|
|
|
|
test -z "X"
|
|
|
|
else test -n "X"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
AdminFehler "trenneNutzer: Nutzer $1 nicht verbunden"
|
|
|
|
test -z "X"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function trenneAlleVerbindungen()
|
|
|
|
{
|
|
|
|
local nutzer
|
|
|
|
holeAktiveNutzer
|
|
|
|
local a4Nutzer=$ERG
|
|
|
|
if test -n "$a4Nutzer"; then
|
|
|
|
aktualisiereAlleSitzungen
|
|
|
|
for nutzer in "$a4Nutzer"; do
|
|
|
|
loescheSitzungsDatei $nutzer
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
verbieteAlleWeiterleitungen
|
|
|
|
holeAnzahlNutzer
|
|
|
|
local anz=$ERG
|
|
|
|
holeAktiveNutzer
|
|
|
|
local namen=$ERG
|
|
|
|
test $anz -gt 0 && AdminFehler "Verbindungstrennung: offene Verbindungen entdeckt ($namen)"
|
|
|
|
holeAnzahlNutzer
|
|
|
|
test $ERG -eq 0
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
############### Kostenermittlung ######################
|
|
|
|
|
|
|
|
function ermittleKosten() # Para: Nutzer, von, bis (jeweils in Form von "20041231")
|
|
|
|
{
|
|
|
|
local datumKosten
|
|
|
|
test -e $NutzerLogPrefix$1 && datumKosten=`cat $NutzerLogPrefix$1 | cut -f 2,5`
|
|
|
|
if test -n "$datumKosten"; then
|
|
|
|
local t
|
|
|
|
local was="datum"
|
|
|
|
local gesamt=0
|
|
|
|
local neuGesamt
|
|
|
|
local datum
|
|
|
|
local preis
|
|
|
|
for t in $datumKosten; do
|
|
|
|
if test "$was" = "datum"; then
|
|
|
|
datum=$t
|
|
|
|
was="preis"
|
|
|
|
else
|
|
|
|
preis=$t
|
|
|
|
test "$datum" -ge "$2" -a "$datum" -le "$3" && let neuGesamt=gesamt+preis
|
|
|
|
gesamt=$neuGesamt
|
|
|
|
was="datum"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
let ERG=gesamt/100
|
|
|
|
# Ergebnis in Cent
|
|
|
|
else
|
|
|
|
ERG=0;
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
############### Weiterleitungskontrolle ###############
|
|
|
|
|
|
|
|
function aktualisiereWeiterleitungen()
|
|
|
|
{
|
|
|
|
holeAktiveNutzer
|
|
|
|
local alle=$ERG
|
|
|
|
local n
|
|
|
|
$IPTABLES -F FORWARD # die Forward-Regeln loeschen
|
2005-02-11 00:42:02 +00:00
|
|
|
$IPTABLES -F JAP
|
|
|
|
#iptables -A FORWARD -o eth0 --protocol udp --dport 2074 -j ACCEPT
|
|
|
|
# gspeakfreely fuer staub
|
2005-02-11 00:06:43 +00:00
|
|
|
if test -n "$alle"; then
|
|
|
|
for n in $alle; do
|
2005-02-11 00:42:02 +00:00
|
|
|
holeIPdesNutzers $n && \
|
|
|
|
$IPTABLES -A FORWARD -i $OUTDEV -o eth0 -d $ERG -m state --state ESTABLISHED,RELATED -j ACCEPT && \
|
|
|
|
$IPTABLES -A FORWARD -i eth0 -o $OUTDEV -s $ERG -j ACCEPT
|
|
|
|
$IPTABLES -A JAP -i eth0 -s $ERG --protocol tcp --dport 4001 -j ACCEPT
|
2005-02-11 00:06:43 +00:00
|
|
|
done
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function erlaubeAlleWeiterleitungen()
|
|
|
|
{
|
|
|
|
$IPTABLES -A FORWARD -i $OUTDEV -o eth0 -m state --state ESTABLISHED,RELATED -j ACCEPT
|
|
|
|
$IPTABLES -A FORWARD -i eth0 -o $OUTDEV -j ACCEPT
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function verbieteAlleWeiterleitungen()
|
|
|
|
{
|
|
|
|
$IPTABLES -F FORWARD
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function entschaerfeProvider()
|
|
|
|
{
|
|
|
|
$IPTABLES -A OUTPUT -o $OUTDEV --protocol tcp --dport 80 -j ACCEPT
|
|
|
|
$IPTABLES -A INPUT -i $OUTDEV --protocol tcp --sport 80 -m state --state ESTABLISHED,RELATED -j ACCEPT
|
2005-02-11 00:42:02 +00:00
|
|
|
$WGET &
|
2005-02-11 00:06:43 +00:00
|
|
|
sleep 3
|
|
|
|
kill $!
|
|
|
|
# beende WGET, damit keine Firewall-Logs auftauchen
|
|
|
|
$IPTABLES -D INPUT -i $OUTDEV --protocol tcp --sport 80 -m state --state ESTABLISHED,RELATED -j ACCEPT
|
|
|
|
$IPTABLES -D OUTPUT -o $OUTDEV --protocol tcp --dport 80 -j ACCEPT
|
|
|
|
}
|
|
|
|
|
|
|
|
################## main ############################
|
|
|
|
|
|
|
|
|
|
|
|
pruefeWeitereInstanz # sorgt dafuer, dass nur eine Instanz laeuft
|
|
|
|
|
|
|
|
aktiviereSkriptLog # aktiviert die Log-Datei
|
|
|
|
|
|
|
|
|
|
|
|
set +u # wegen "unbound"-Warnungen notwendig
|
|
|
|
|
|
|
|
case "$1" in
|
|
|
|
verbinde ) # ein Nutzer moechte die Verbindung nutzen
|
|
|
|
pruefeStatus
|
|
|
|
if istNutzerOK $2; then
|
|
|
|
if verbindeNutzer $2; then
|
|
|
|
echo "Verbindungsaufbau gestartet"
|
|
|
|
else echo "Verbindungsaufbau fehlgeschlagen"
|
|
|
|
fi
|
|
|
|
else AdminFehler "$2 - versuchte Anmeldung"
|
|
|
|
echo "unzulaessiger Nutzer"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
ip-up ) # der Dialer hat die Verbindung hergestellt
|
|
|
|
# wird von "if-up" aufgerufen
|
|
|
|
pruefeStatus
|
|
|
|
erfuelleVerbindungsWuensche
|
|
|
|
entschaerfeProvider
|
|
|
|
;;
|
|
|
|
ip-down ) # Verbindung beendet (regulaer? / Wuensche zurueckziehen?)
|
|
|
|
pruefeStatus
|
|
|
|
holeAktiveNutzer
|
|
|
|
dieANutzer=$ERG
|
|
|
|
if test -n "$dieANutzer"; then
|
|
|
|
AdminNachricht "Zeitueberschreitung der Verbindung fuer: $dieANutzer"
|
|
|
|
trenneAlleVerbindungen
|
|
|
|
fi
|
|
|
|
# der Dialer sollte sich gerade selbst beenden
|
|
|
|
DialerIstBeendet
|
|
|
|
;;
|
|
|
|
trenne ) # Nutzer moechte Verbindung fuer sich beenden
|
|
|
|
pruefeStatus
|
|
|
|
if istNutzerOK $2;then
|
|
|
|
if trenneNutzer $2; then echo "Nutzer getrennt"
|
|
|
|
else echo "Trennung fehlerhaft"
|
|
|
|
fi
|
|
|
|
else echo "unzulaessiger Nutzer"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
status-verbindung ) # offen/waehlen/getrennt
|
|
|
|
pruefeStatus
|
|
|
|
holeVerbindungsStatus
|
|
|
|
echo -e "$ERG"
|
|
|
|
;;
|
|
|
|
status-nutzer ) # Verbindungsstatus fuer einen Nutzer
|
|
|
|
pruefeStatus
|
|
|
|
istNutzerOK $2 || AdminFehler "s-n: unbekannter Nutzer: $2"
|
|
|
|
holeNutzerStatus $2
|
|
|
|
echo -e "$ERG"
|
|
|
|
;;
|
|
|
|
alle-nutzer ) # Namen der Nutzer
|
|
|
|
pruefeStatus
|
|
|
|
cat $NutzerListenDatei | cut -f 1
|
|
|
|
;;
|
|
|
|
alle-aktiven-nutzer ) # Namen aller aktiven Nutzer
|
|
|
|
holeAktiveNutzer
|
|
|
|
if test -z "$ERG";
|
|
|
|
then echo "kein aktiver Nutzer"
|
|
|
|
else echo $ERG
|
|
|
|
fi
|
|
|
|
;;
|
2005-02-11 00:42:02 +00:00
|
|
|
anzahl-aktiver-nutzer ) # Anzahl der verbundenen Nutzer
|
|
|
|
holeAnzahlNutzer
|
|
|
|
echo "$ERG";
|
|
|
|
;;
|
2005-02-11 00:06:43 +00:00
|
|
|
status ) # Gesamtuebersicht
|
|
|
|
pruefeStatus
|
|
|
|
holeVerbindungsStatus
|
|
|
|
echo -e "Verbindungsstatus:\t$ERG"
|
|
|
|
for n in `cat $NutzerListenDatei | cut -f 1`; do
|
|
|
|
holeIPdesNutzers $n
|
|
|
|
echo -en "$ERG\t\t"
|
|
|
|
holeNutzerStatus $n
|
|
|
|
echo -e "$ERG\t$n"
|
|
|
|
done
|
|
|
|
;;
|
|
|
|
kosten ) # Kosten fuer einen Nutzer in bestimmtem Zeitraum
|
|
|
|
t=""
|
|
|
|
istNutzerOK $2 || t1="kosten: ungueltiger Nutzer ($2)"
|
|
|
|
test -n "$3" -a -n "$4" -a $3 -le $4 || t2="ungueltiger Datumsbereich ($3/$4)"
|
|
|
|
test -z "$t1" && t=$t2;
|
|
|
|
test -z "$t2" && t=$t1;
|
|
|
|
test -n "$t1" -a -n "$t2" && t="$t1 / $t2";
|
|
|
|
if test -z "$t"; then
|
|
|
|
ermittleKosten $2 $3 $4
|
|
|
|
echo $ERG
|
|
|
|
else
|
|
|
|
AdminFehler $t
|
|
|
|
echo $t
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
nutzer2ip ) #
|
|
|
|
if istNutzerOK $2; then
|
|
|
|
holeIPdesNutzers $2
|
|
|
|
echo $ERG
|
|
|
|
else
|
|
|
|
AdminFehler "n2i: unbekannter Nutzer: $2"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
ip2nutzer ) # ermittle Nutzernamen fuer IP
|
|
|
|
holeNutzerDerIP $2
|
|
|
|
echo $ERG
|
|
|
|
;;
|
|
|
|
nutzer-log ) # zeigt das Verbindungsprotokoll des Nutzers
|
|
|
|
if istNutzerOK $2; then
|
|
|
|
if test -s $NutzerLogPrefix$2; then
|
|
|
|
echo -e "Datum\tDatum (Comp)\tPreis je min\tAnzahl der Nutzer\tVerbindungskosten\tDauer (in Sek.)"
|
|
|
|
cat $NutzerLogPrefix$2
|
|
|
|
else
|
|
|
|
echo "keine Eintraege"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
AdminFehler "n-l: unbekannter Nutzer: $2"
|
|
|
|
echo "ungueltiger Nutzername"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
protokoll ) # zeigt eine Log-Datei an
|
|
|
|
datei=
|
|
|
|
case $2 in
|
|
|
|
fehler )
|
|
|
|
datei=$AdminFehlerLog
|
|
|
|
prog="cat"
|
|
|
|
;;
|
|
|
|
meldungen )
|
|
|
|
datei=$AdminLog
|
|
|
|
prog="tail -200"
|
|
|
|
;;
|
|
|
|
script )
|
|
|
|
datei=$ScriptLog
|
|
|
|
prog="tail -300"
|
|
|
|
;;
|
|
|
|
dialer )
|
|
|
|
datei=$DialerLog
|
|
|
|
prog="tail -70"
|
|
|
|
;;
|
|
|
|
* )
|
|
|
|
echo "ungueltige Auswahl der Protokoll-Datei"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
if test -n "$datei"; then
|
|
|
|
if test -s $datei; then
|
|
|
|
$prog $datei
|
|
|
|
else
|
|
|
|
echo "keine Eintraege"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
reset )
|
|
|
|
trenneAlleVerbindungen
|
|
|
|
# beenden geht leider nicht, wegen PID
|
|
|
|
if test -e $DialPIDDatei; then
|
|
|
|
ERG1=`cat $DialPIDDatei`
|
|
|
|
ERG2=`ps --pid $ERG1 -o comm | tail -1`
|
|
|
|
ERG3=`echo $0 | grep $ERG2`
|
|
|
|
test -n "$ERG3" && kill $ERG1
|
|
|
|
# beim Beenden sollte die PID-Datei geloescht werden, aber:
|
|
|
|
test -e "$DialPIDDatei" && rm $DialPIDDatei
|
|
|
|
fi
|
|
|
|
test -n "`ls $SitzungsPrefix`" && rm $SitzungsPrefix*
|
|
|
|
test -e $DialerStatus && rm $DialerStatus
|
|
|
|
test -e $VerbindungsWunschDatei && rm $VerbindungsWunschDatei
|
|
|
|
# unnoetig die PIDDatei zu loeschen, da trap dies tut
|
|
|
|
verbieteAlleWeiterleitungen
|
|
|
|
AdminNachricht "Reset ausgeloest"
|
|
|
|
;;
|
|
|
|
* ) # Hilfe
|
|
|
|
echo -e "Parameter:"
|
|
|
|
echo -e "\t verbinde X\t\t- oeffne Verbindung fuer X"
|
|
|
|
echo -e "\t trenne X\t\t- trenne die Verbindung fuer X"
|
|
|
|
echo -e "\t status\t\t\t- allgemeine Informationen"
|
|
|
|
echo -e "\t status-verbindung\t- Ausgabe der Info"
|
|
|
|
echo -e "\t status-nutzer X\t- Ausgabe der Info"
|
|
|
|
echo -e "\t alle-nutzer\t\t- Ausgabe aller Nutzernamen"
|
|
|
|
echo -e "\t alle-aktiven-nutzer\t- Ausgabe der derzeit verbundenen Nutzer"
|
2005-02-11 00:42:02 +00:00
|
|
|
echo -e "\t anzahl-aktiver-nutzer\t- Ausgabe der Anzahl der derzeit verbundenen Nutzer"
|
2005-02-11 00:06:43 +00:00
|
|
|
echo -e "\t ip2nutzer X\t\t- liefert den Nutzernamen fuer eine IP"
|
|
|
|
echo -e "\t nutzer2ip X\t\t- liefert die IP des Nutzers"
|
|
|
|
echo -e "\t kosten X Y Z\t\t- Kosten fuer X von Y bis Z (z.B.: 20041231)"
|
|
|
|
echo -e "\t nutzer-log X\t\t- Verbindungsprotokoll des Nutzers X"
|
|
|
|
echo -e "\t protokoll X\t\t- Log-Datei (fehler,meldungen,script,dialer)"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
|
|
|
|
|