Compare commits

..

No commits in common. "aa04b75e4161f3e4db87ca537e4e1756b686318f" and "8c3bfed83f313243bab0bbb7d6c014d5d4b59323" have entirely different histories.

3 changed files with 78 additions and 50 deletions

View File

@ -26,43 +26,45 @@ delete_expired_at_jobs() {
echo "Keine überholten 'at'-Jobs gefunden." echo "Keine überholten 'at'-Jobs gefunden."
fi fi
## Behalte nur den nächsten 'at'-Job und lösche alle zukünftigen Jobs # Behalte nur den nächsten 'at'-Job und lösche alle zukünftigen Jobs
#next_job_id=$(/usr/bin/atq | awk '{print $1}' | sort -n | head -n 1) next_job_id=$(/usr/bin/atq | awk '{print $1}' | sort -n | head -n 1)
#if [ -n "$next_job_id" ]; then if [ -n "$next_job_id" ]; then
#/usr/bin/atrm $(/usr/bin/atq | awk -v next_job_id="$next_job_id" '$1 > next_job_id {print $1}') /usr/bin/atrm $(/usr/bin/atq | awk -v next_job_id="$next_job_id" '$1 > next_job_id {print $1}')
#echo "Nur der nächste 'at'-Job bleibt erhalten: $next_job_id" echo "Nur der nächste 'at'-Job bleibt erhalten: $next_job_id"
#else else
#echo "Keine 'at'-Jobs gefunden." echo "Keine 'at'-Jobs gefunden."
#fi fi
} }
# Verwende die Funktion, um überholte Jobs zu löschen # Verwende die Funktion, um überholte Jobs zu löschen
delete_expired_at_jobs delete_expired_at_jobs
# Die IP-Adresse von Lisas-IPhone holen (ohne Ping-Test) # Die IP-Adresse von Lisas-IPhone holen und Ping-Test durchführen
check_ip() { check_ip() {
mac_address="e4:cd:d1" # Ersetze dies durch die MAC-Adresse mac_address="e4:cd:d1" # Ersetze dies durch die MAC-Adresse
attempts=10
interval=5
for ((i = 1; i <= $attempts; i++)); do
A72_ip=$(arp-scan -r 5 -v --localnet | grep "$mac_address" | awk '{print $1}') A72_ip=$(arp-scan -r 5 -v --localnet | grep "$mac_address" | awk '{print $1}')
if [ -n "$A72_ip" ]; then if [ -z "$A72_ip" ]; then
echo "IP nicht gefunden. Ziel ist nicht erreichbar."
return 1
fi
echo "Gefundene IP: $A72_ip" echo "Gefundene IP: $A72_ip"
return 0 # Erfolg: IP-Adresse gefunden
fi
if [ $i -lt $attempts ]; then # Ping-Test durchführen
echo "Warte $interval Sekunden, bevor der nächste Versuch gestartet wird." echo "teste ping $A72_ip"
sleep $interval local ping_output=$(/bin/ping -q -w 3 -c 3 $A72_ip 2>&1)
fi local ping_exit_code=$?
done
# Alle Versuche erfolglos echo "$ping_output" # Ausgabe des Ping-Befehls anzeigen
echo "Das Ziel konnte nach $attempts Versuchen nicht erreicht werden."
iobroker state set zigbee.0.04cd15fffee03198.state false if [ $ping_exit_code -eq 0 ] && [[ "$ping_output" == *"3 received"* ]]; then
return 1 # Fehler: IP-Adresse nicht gefunden echo "Das Ziel ist erreichbar."
return 0 # Erfolg: Das Ziel ist erreichbar
else
echo "Das Ziel ist nicht erreichbar. Exit Code: $ping_exit_code"
return 1 # Fehler: Das Ziel ist nicht erreichbar
fi
} }
# check_ip -Funktion ausführen. # check_ip -Funktion ausführen.

View File

@ -6,8 +6,6 @@
# Es schaltet Bluetooth aus, erhöht die Lautstärke und überprüft, ob der Wecker beendet wurde. # Es schaltet Bluetooth aus, erhöht die Lautstärke und überprüft, ob der Wecker beendet wurde.
# Nach dem Beenden des Weckers wird der Weckersound abgespielt. # Nach dem Beenden des Weckers wird der Weckersound abgespielt.
echo "Script ausgeführt um: $(date)" > /data/scripts/morning-alarm.log
# Funktion zum Ausschalten von Bluetooth # Funktion zum Ausschalten von Bluetooth
turn_off_bluetooth() { turn_off_bluetooth() {
svc bluetooth disable svc bluetooth disable

View File

@ -17,9 +17,9 @@ rot="ff0000"
gruen="00ff00" gruen="00ff00"
blau="0000ff" blau="0000ff"
iobroker state set zigbee.0.04cd15fffee03198.colortemp 1600
iobroker state set zigbee.0.04cd15fffee03198.state false iobroker state set zigbee.0.04cd15fffee03198.state false
iobroker state set zigbee.0.04cd15fffee03198.brightness 0 iobroker state set zigbee.0.04cd15fffee03198.brightness 0
iobroker state set zigbee.0.04cd15fffee03198.colortemp 1600
set_brightness() { set_brightness() {
local brightness_value=$1 local brightness_value=$1
@ -27,6 +27,7 @@ set_brightness() {
iobroker state set zigbee.0.04cd15fffee03198.brightness "$brightness_value" iobroker state set zigbee.0.04cd15fffee03198.brightness "$brightness_value"
} }
set_colortemp() { set_colortemp() {
local colortemp_value=$1 local colortemp_value=$1
# Ersetze 'zigbee.0.04cd15fffee03198.colortemp' durch die tatsächliche ioBroker-Adresse für die Farbtemperatur # Ersetze 'zigbee.0.04cd15fffee03198.colortemp' durch die tatsächliche ioBroker-Adresse für die Farbtemperatur
@ -39,7 +40,7 @@ set_color() {
iobroker state set zigbee.0.04cd15fffee03198.color "$color_value" iobroker state set zigbee.0.04cd15fffee03198.color "$color_value"
} }
# Die IP-Adresse von Lisas-IPhone holen (ohne Ping-Test) # Die IP-Adresse von Lisas-IPhone holen und Ping-Test durchführen
check_ip() { check_ip() {
mac_address="e4:cd:d1" # Ersetze dies durch die MAC-Adresse mac_address="e4:cd:d1" # Ersetze dies durch die MAC-Adresse
attempts=10 attempts=10
@ -50,7 +51,20 @@ check_ip() {
if [ -n "$A72_ip" ]; then if [ -n "$A72_ip" ]; then
echo "Gefundene IP: $A72_ip" echo "Gefundene IP: $A72_ip"
return 0 # Erfolg: IP-Adresse gefunden
# Ping-Test durchführen
echo "teste ping $A72_ip"
local ping_output=$(/bin/ping -q -w 3 -c 3 $A72_ip 2>&1)
local ping_exit_code=$?
echo "$ping_output" # Ausgabe des Ping-Befehls anzeigen
if [ $ping_exit_code -eq 0 ] && [[ "$ping_output" == *"3 received"* ]]; then
echo "Das Ziel ist erreichbar."
return 0 # Erfolg: Das Ziel ist erreichbar
else
echo "Das Ziel ist nicht erreichbar. Exit Code: $ping_exit_code"
fi
fi fi
if [ $i -lt $attempts ]; then if [ $i -lt $attempts ]; then
@ -62,7 +76,8 @@ check_ip() {
# Alle Versuche erfolglos # Alle Versuche erfolglos
echo "Das Ziel konnte nach $attempts Versuchen nicht erreicht werden." echo "Das Ziel konnte nach $attempts Versuchen nicht erreicht werden."
iobroker state set zigbee.0.04cd15fffee03198.state false iobroker state set zigbee.0.04cd15fffee03198.state false
return 1 # Fehler: IP-Adresse nicht gefunden return 1 # Fehler: Das Ziel konnte nicht erreicht werden
exit
} }
# check_ip -Funktion ausführen. # check_ip -Funktion ausführen.
@ -85,19 +100,19 @@ check_external_light_status() {
# Checkt, ob der Wecker am Handy ausgeschaltet wurde. # Checkt, ob der Wecker am Handy ausgeschaltet wurde.
check_notification() { check_notification() {
max_attempts=10 max_attempts=10
wait_time=5 wait_time=10
for ((i = 1; i <= $max_attempts; i++)); do for ((i = 1; i <= $max_attempts; i++)); do
# Führe den SSH-Befehl innerhalb eines Timeout aus # Führe den SSH-Befehl innerhalb eines Timeout aus
check_ip # IP holen check_ip # IP holen
output=$(ssh -i /root/.ssh/A72 root@$A72_ip 'dumpsys activity processes | grep com.urbandroid.sleep') output=$(ssh -i /root/.ssh/A72 root@$A72_ip 'dumpsys activity processes | grep com.urbandroid.sleep')
#echo $output echo $output
# Überprüfen, ob das Ergebnis den Wecker enthält # Überprüfen, ob das Ergebnis den Wecker enthält
if [[ $output == *"com.urbandroid.sleep"* && $output == *"AlarmKlaxon"* ]]; then if [[ $output == *"com.urbandroid.sleep"* && $output == *"AlarmKlaxon"* ]]; then
# Wecker noch nicht beendet. # Wecker noch nicht beendet.
date && echo "Wecker noch nicht beendet." date && echo "Wecker noch nicht beendet."
#echo $output echo $output
sleep $wait_time # Wartezeit von 10 Sekunden sleep $wait_time # Wartezeit von 10 Sekunden
elif [[ $output == *"com.urbandroid.sleep"* && $output != *"AlarmKlaxon"* ]]; then elif [[ $output == *"com.urbandroid.sleep"* && $output != *"AlarmKlaxon"* ]]; then
# Wecker beendet. # Wecker beendet.
@ -116,6 +131,7 @@ check_notification() {
# Handy konnte nicht erreicht werden. # Handy konnte nicht erreicht werden.
echo "Handy konnte nach $max_attempts Versuchen nicht erreicht werden." echo "Handy konnte nach $max_attempts Versuchen nicht erreicht werden."
date && echo "Wecker beendet." date && echo "Wecker beendet."
echo $output
iobroker state set zigbee.0.04cd15fffee03198.state false iobroker state set zigbee.0.04cd15fffee03198.state false
exit exit
} }
@ -128,10 +144,11 @@ start_colortemp=1600 # Warmweiß (1600)
end_brightness=100 # Höchste Helligkeit (100) end_brightness=100 # Höchste Helligkeit (100)
end_colortemp=0 # Kaltweiß (0) end_colortemp=0 # Kaltweiß (0)
# Dauer der Anpassung in Sekunden (15 Minuten) # Dauer der Anpassung in Sekunden (15 Minuten)
duration_seconds=900 duration_seconds=900
# Alle 30 Sekunden Änderung # Alle 30 Sekinden Änderung
steps=30 # Alle 30 Sekunden einen Schritt steps=30 # Alle 30 Sekunden einen Schritt
# Berechne die Schritte für Helligkeit und Farbtemperatur pro Schritt # Berechne die Schritte für Helligkeit und Farbtemperatur pro Schritt
@ -157,7 +174,7 @@ colortemp_step=$(bc <<< "$start_colortemp / $steps")
set_brightness "$current_brightness" set_brightness "$current_brightness"
set_colortemp "$current_colortemp" set_colortemp "$current_colortemp"
sleep 27 # Änderungen alle 30 (27) Sekunden sleep 30 # Änderungen alle 30 Sekunden
done done
# check_ip -Funktion ausführen. # check_ip -Funktion ausführen.
@ -165,8 +182,7 @@ check_ip
echo "$A72_ip" echo "$A72_ip"
# Starten des Alarm-Scripts auf dem Handy. # Starten des Alarm-Scripts auf dem Handy.
echo "Starten des morning-alarm.sh Scripts am Ziel: $A72_ip" ssh -i /root/.ssh/A72 root@$A72_ip "/data/scripts/morning-alarm.sh" &
nohup ssh -i /root/.ssh/A72 root@$A72_ip "/data/scripts/morning-alarm.sh > /dev/null" &
# Farben ändern für mehr konzentration # Farben ändern für mehr konzentration
while :; do while :; do
@ -174,14 +190,26 @@ while :; do
check_external_light_status check_external_light_status
else else
first_brightness_change=false first_brightness_change=false
fi
set_color "$gruen" set_color "$gruen"
sleep 5 sleep 2
set_color "$rot"
sleep 5
set_color "$blau" set_color "$blau"
sleep 2
set_color "$rot"
check_notification check_notification
fi
done done
# Füge hier den Rest deines Skripts ein, das den Weckvorgang durchführt
# ...
# Hier kannst du den Weckprozess starten
# ...
# Lösche temporäre Dateien, falls erforderlich
# ...
# Hinweis: Dieses Skript konzentriert sich auf die Anpassung von Helligkeit und Farbtemperatur
# über ioBroker und sollte in Kombination mit anderen Aktionen verwendet werden, um den Weckvorgang zu vervollständigen.