Refactor generate_text.sh script:
- Replace HTML file creation with Markdown content generation for improved simplicity and readability. - Construct Markdown content with a header, table, and row entries based on the generated text components. - Introduce a curl_command variable to construct and echo the curl command for sending a notification to A72. - Display the constructed Markdown content for debugging purposes. - Transfer text files to A72's sdcard instead of the scripts directory. - Start generate_mp3.sh on A72 using nohup and ssh. - Adjust comments and remove unnecessary HTML file display section. - Overall, enhance the script structure, content creation, and notification handling in generate_text.sh.
This commit is contained in:
parent
a5076ae046
commit
4fe4ef7de7
86
wecker.sh
86
wecker.sh
@ -13,6 +13,9 @@
|
|||||||
#set -e # Stop the script on errors
|
#set -e # Stop the script on errors
|
||||||
#set -x # Enable debugging # Uncomment for a more detailed log
|
#set -x # Enable debugging # Uncomment for a more detailed log
|
||||||
|
|
||||||
|
# Variables
|
||||||
|
alarm_dismissed=false # Variable to track alarm status
|
||||||
|
|
||||||
# Debug
|
# Debug
|
||||||
debug=false
|
debug=false
|
||||||
ssh_executed=false # Variable to track SSH command status
|
ssh_executed=false # Variable to track SSH command status
|
||||||
@ -107,12 +110,12 @@ check_external_light_status() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# Check if the alarm on the phone has been turned off
|
# Function to check the alarm notification
|
||||||
check_notification() {
|
check_notification() {
|
||||||
max_attempts=10
|
max_attempts=10
|
||||||
wait_time=5
|
wait_time=5
|
||||||
|
|
||||||
for ((i = 1; i <= $max_attempts; i++)); do
|
for ((i = 1; i <= $max_attempts;)); do
|
||||||
# Execute the SSH command within a timeout
|
# Execute the SSH command within a timeout
|
||||||
check_ip # Get IP
|
check_ip # Get IP
|
||||||
|
|
||||||
@ -121,26 +124,25 @@ check_notification() {
|
|||||||
output="com.urbandroid.sleep AlarmKlaxon"
|
output="com.urbandroid.sleep AlarmKlaxon"
|
||||||
else
|
else
|
||||||
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
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Check if the result contains the alarm
|
# Check if the result contains the alarm
|
||||||
if [[ $output == *"com.urbandroid.sleep"* && $output == *"AlarmKlaxon"* ]]; then
|
if [[ $output == *"com.urbandroid.sleep"* && $output == *"AlarmKlaxon"* ]]; then
|
||||||
# Alarm not turned off yet
|
# Alarm not turned off yet
|
||||||
date && echo "Alarm not turned off yet."
|
date && echo "Alarm not turned off yet."
|
||||||
echo $output
|
#echo $output
|
||||||
return
|
|
||||||
elif [[ $output == *"com.urbandroid.sleep"* && $output != *"AlarmKlaxon"* ]]; then
|
elif [[ $output == *"com.urbandroid.sleep"* && $output != *"AlarmKlaxon"* ]]; then
|
||||||
# Alarm turned off
|
# Alarm turned off
|
||||||
date && echo "Alarm turned off."
|
date && echo "Alarm turned off."
|
||||||
echo $output
|
ssh -i /root/.ssh/A72 root@$A72_ip 'killall mpv'
|
||||||
iobroker state set zigbee.0.04cd15fffee03198.state false
|
iobroker state set zigbee.0.04cd15fffee03198.state false
|
||||||
/root/iobroker_scripts/general/generate_text.sh > /dev/null
|
exit # Exit the script when the alarm is turned off
|
||||||
exit # Beende das Skript, wenn der Alarm ausgeschaltet wurde
|
|
||||||
else
|
else
|
||||||
# Phone unreachable
|
# Phone unreachable
|
||||||
echo "Phone unreachable. Waiting $wait_time seconds before the next attempt."
|
echo "Phone unreachable. Waiting $wait_time seconds before the next attempt."
|
||||||
check_ip # Get IP
|
check_ip # Get IP
|
||||||
|
i++
|
||||||
sleep $wait_time
|
sleep $wait_time
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
@ -148,8 +150,9 @@ check_notification() {
|
|||||||
# Phone could not be reached.
|
# Phone could not be reached.
|
||||||
echo "Phone could not be reached after $max_attempts attempts."
|
echo "Phone could not be reached after $max_attempts attempts."
|
||||||
date && echo "Alarm turned off."
|
date && echo "Alarm turned off."
|
||||||
|
ssh -i /root/.ssh/A72 root@$A72_ip 'killall mpv'
|
||||||
iobroker state set zigbee.0.04cd15fffee03198.state false
|
iobroker state set zigbee.0.04cd15fffee03198.state false
|
||||||
exit # Beende das Skript, wenn das Telefon nicht erreicht werden konnte
|
exit # Exit the script when the phone is unreachable
|
||||||
}
|
}
|
||||||
|
|
||||||
# Define starting values for brightness and color temperature
|
# Define starting values for brightness and color temperature
|
||||||
@ -184,7 +187,7 @@ echo "Reached final colortemp: $((start_colortemp - colortemp_step * steps)) fro
|
|||||||
sleep_duration=$((duration_seconds / steps - 3))
|
sleep_duration=$((duration_seconds / steps - 3))
|
||||||
|
|
||||||
# Gradual adjustment of brightness and color temperature
|
# Gradual adjustment of brightness and color temperature
|
||||||
for ((i = 1; i <= $steps; i++)); do
|
for ((i = 1; i < $steps; i++)); do
|
||||||
current_brightness=$(printf "%.0f" $(bc <<< "$start_brightness + ($brightness_step * $i)"))
|
current_brightness=$(printf "%.0f" $(bc <<< "$start_brightness + ($brightness_step * $i)"))
|
||||||
current_colortemp=$(printf "%.0f" $(bc <<< "$start_colortemp - ($colortemp_step * $i)"))
|
current_colortemp=$(printf "%.0f" $(bc <<< "$start_colortemp - ($colortemp_step * $i)"))
|
||||||
|
|
||||||
@ -193,6 +196,7 @@ for ((i = 1; i <= $steps; i++)); do
|
|||||||
echo "current brightness= $current_brightness"
|
echo "current brightness= $current_brightness"
|
||||||
echo "current colortemp= $current_colortemp"
|
echo "current colortemp= $current_colortemp"
|
||||||
|
|
||||||
|
# Check if it's the first brightness change
|
||||||
if [ "$first_brightness_change" = true ]; then
|
if [ "$first_brightness_change" = true ]; then
|
||||||
echo "Variable first_brightness_change = true"
|
echo "Variable first_brightness_change = true"
|
||||||
check_external_light_status
|
check_external_light_status
|
||||||
@ -210,6 +214,11 @@ for ((i = 1; i <= $steps; i++)); do
|
|||||||
else
|
else
|
||||||
sleep $sleep_duration # Changes every 30 seconds
|
sleep $sleep_duration # Changes every 30 seconds
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Check if the alarm is dismissed
|
||||||
|
if [ "$alarm_dismissed" = true ]; then
|
||||||
|
exit # Exit the script when the alarm is dismissed
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
# Set to end values.
|
# Set to end values.
|
||||||
@ -226,32 +235,53 @@ echo "$A72_ip"
|
|||||||
echo "current_brightness: $current_brightness end_brightness: $end_brightness"
|
echo "current_brightness: $current_brightness end_brightness: $end_brightness"
|
||||||
echo "current_colortemp: $current_colortemp end_colortemp: $end_colortemp"
|
echo "current_colortemp: $current_colortemp end_colortemp: $end_colortemp"
|
||||||
|
|
||||||
|
# Check if the alarm is dismissed
|
||||||
|
if [ "$alarm_dismissed" = true ]; then
|
||||||
|
exit # Exit the script when the alarm is dismissed
|
||||||
|
fi
|
||||||
|
|
||||||
ssh_command() { # Function to send a command to A72.
|
ssh_command() { # Function to send a command to A72.
|
||||||
local command=$1
|
local command=$1
|
||||||
nohup ssh -i /root/.ssh/A72 -f root@$A72_ip "$command" </dev/null &
|
|
||||||
ssh_executed=true # Mark that the SSH command has been executed.
|
ssh_executed=true # Mark that the SSH command has been executed.
|
||||||
|
|
||||||
|
# Start the SSH command in the background and store the PID.
|
||||||
|
nohup ssh -i /root/.ssh/A72 root@$A72_ip "$command" > /dev/null 2>&1 &
|
||||||
|
echo "$ssh_executed"
|
||||||
|
ssh_pid=$! # Store the PID of the SSH process.
|
||||||
|
echo "ssh_pid: $ssh_pid"+
|
||||||
|
|
||||||
|
# Wait briefly to ensure that the process has started.
|
||||||
|
sleep 1
|
||||||
}
|
}
|
||||||
|
|
||||||
if [ $current_brightness -eq $end_brightness ] && [ $current_colortemp -eq $end_colortemp ]; then
|
if [ $current_brightness -eq $end_brightness ] && [ $current_colortemp -eq $end_colortemp ]; then
|
||||||
# Change colors for more concentration
|
|
||||||
while :; do
|
# Continue with the color-changing loop
|
||||||
# Start the alarm script on the phone if the SSH command has not been executed yet.
|
while :; do
|
||||||
if [ "$ssh_executed" = false ]; then
|
# Start the alarm script on the phone if the SSH command has not been executed yet.
|
||||||
if [ "$debug" = true ]; then
|
if [ "$ssh_executed" = false ]; then
|
||||||
echo "DEBUG: Alternative ssh command."
|
if [ "$debug" = true ]; then
|
||||||
ssh_command "cmd media_session volume scripts/--set 5 --stream 9 && /data/data/com.termux/files/usr/bin/mpv /data/scripts/your-new-morning-alarm.ogg"
|
echo "DEBUG: Alternative ssh command."
|
||||||
else
|
ssh_command "cmd media_session volume --set 5 --stream 9 && /data/data/com.termux/files/usr/bin/mpv /data/scripts/your-new-morning-alarm.ogg"
|
||||||
nohup ssh a72 '/data/scripts/morning-alarm.sh 2>&1 | /data/data/com.termux/files/usr/bin/tee /data/scripts/morning-alarm.log'
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
check_external_light_status
|
sleep 1
|
||||||
set_color "$green"
|
ssh_command "/data/scripts/morning-alarm.sh >> /data/scripts/morning-alarm.log" &
|
||||||
sleep 5
|
ssh_executed=true
|
||||||
set_color "$red"
|
|
||||||
sleep 5
|
|
||||||
set_color "$blue"
|
|
||||||
check_notification
|
|
||||||
fi
|
fi
|
||||||
|
else
|
||||||
|
check_external_light_status
|
||||||
|
set_color "$green"
|
||||||
|
sleep 5
|
||||||
|
set_color "$red"
|
||||||
|
sleep 5
|
||||||
|
set_color "$blue"
|
||||||
|
check_notification #&
|
||||||
|
fi
|
||||||
|
if [ "$alarm_dismissed" = true ]; then
|
||||||
|
echo "Alarm dismissed"
|
||||||
|
/root/iobroker_scripts/general/generate_text.sh # Call generate_text.sh script
|
||||||
|
exit # Exit the script when the alarm is dismissed
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user