Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
7242b1c2ab | ||
|
|
5152252653 | ||
|
|
50fc8a72b2 | ||
|
|
9183bbcef5 |
10
CHANGELOG.md
10
CHANGELOG.md
@@ -1,3 +1,13 @@
|
|||||||
|
# 0.6.3 - 10/08/2021
|
||||||
|
- Add command last_rain_sensor_timestamp, last_rain_online_timestamp, reset_last_rain_sensor_timestamp, reset_last_rain_online_timestamp
|
||||||
|
- Add socket server api for reset_last_rain_sensor_timestamp, reset_last_rain_online_timestamp
|
||||||
|
|
||||||
|
# 0.6.2 - 24/04/2021
|
||||||
|
- Update rainsensorqty driver to version 0.2.5c
|
||||||
|
|
||||||
|
# 0.6.1 - 06/09/2020
|
||||||
|
- Add support for send log to piGardenWeb
|
||||||
|
|
||||||
# 0.6.0 - 16/05/2020
|
# 0.6.0 - 16/05/2020
|
||||||
- Add support for enable all cron fron api
|
- Add support for enable all cron fron api
|
||||||
- Update rainsensorqty driver to version 0.2.5b
|
- Update rainsensorqty driver to version 0.2.5b
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
||||||
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
||||||
|
|
||||||
|
#
|
||||||
|
# Enable send log to piGardenWeb
|
||||||
|
#
|
||||||
|
|
||||||
|
#LOG_URL="http://url_of_your_pigardenweb/api/log"
|
||||||
|
#LOG_API_TOKEN="token_of_pigardenweb_user"
|
||||||
|
#LOG_CURL_PARAM="--data-urlencode -k"
|
||||||
|
|
||||||
# Log file for driver output
|
# Log file for driver output
|
||||||
LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
||||||
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
||||||
|
|
||||||
|
#
|
||||||
|
# Enable send log to piGardenWeb
|
||||||
|
#
|
||||||
|
|
||||||
|
#LOG_URL="http://url_of_your_pigardenweb/api/log"
|
||||||
|
#LOG_API_TOKEN="token_of_pigardenweb_user"
|
||||||
|
#LOG_CURL_PARAM="--data-urlencode -k"
|
||||||
|
|
||||||
# Log file for driver output
|
# Log file for driver output
|
||||||
LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
||||||
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
||||||
|
|
||||||
|
#
|
||||||
|
# Enable send log to piGardenWeb
|
||||||
|
#
|
||||||
|
|
||||||
|
#LOG_URL="http://url_of_your_pigardenweb/api/log"
|
||||||
|
#LOG_API_TOKEN="token_of_pigardenweb_user"
|
||||||
|
#LOG_CURL_PARAM="--data-urlencode -k"
|
||||||
|
|
||||||
# Log file for driver output
|
# Log file for driver output
|
||||||
#LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
#LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
||||||
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
||||||
|
|
||||||
|
#
|
||||||
|
# Enable send log to piGardenWeb
|
||||||
|
#
|
||||||
|
|
||||||
|
#LOG_URL="http://url_of_your_pigardenweb/api/log"
|
||||||
|
#LOG_API_TOKEN="token_of_pigardenweb_user"
|
||||||
|
#LOG_CURL_PARAM="--data-urlencode -k"
|
||||||
|
|
||||||
# Log file for driver output
|
# Log file for driver output
|
||||||
#LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
#LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,14 @@
|
|||||||
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
LOG_FILE="/home/pi/piGarden/log/piGarden.log"
|
||||||
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
LOG_FILE_MAX_SIZE=1048576 # 1MB
|
||||||
|
|
||||||
|
#
|
||||||
|
# Enable send log to piGardenWeb
|
||||||
|
#
|
||||||
|
|
||||||
|
#LOG_URL="http://url_of_your_pigardenweb/api/log"
|
||||||
|
#LOG_API_TOKEN="token_of_pigardenweb_user"
|
||||||
|
#LOG_CURL_PARAM="--data-urlencode -k"
|
||||||
|
|
||||||
# Log file for driver output
|
# Log file for driver output
|
||||||
#LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
#LOG_OUTPUT_DRV_FILE="/tmp/piGarden.drv.log"
|
||||||
|
|
||||||
|
|||||||
1
drv/rainsensorqty/commands/test_pulse
Executable file
1
drv/rainsensorqty/commands/test_pulse
Executable file
@@ -0,0 +1 @@
|
|||||||
|
echo 1 > /tmp/tick ; sleep 0.9 ; echo 0 > /tmp/tick
|
||||||
@@ -60,6 +60,46 @@ en_echo() # enhanched echo - check verbose variable
|
|||||||
[[ $RAINSENSORQTY_verbose = yes ]] && echo "$(d) $*"
|
[[ $RAINSENSORQTY_verbose = yes ]] && echo "$(d) $*"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
check_incomplete_loop()
|
||||||
|
{
|
||||||
|
[[ ! -f $RAINSENSORQTY_HISTORYRAW ]] && return 1
|
||||||
|
[[ ! -f $RAINSENSORQTY_HISTORY ]] && touch $RAINSENSORQTY_HISTORY
|
||||||
|
> $RAINSENSORQTY_HISTORYTMP
|
||||||
|
|
||||||
|
if lastrainevent=$( rainevents 1 ) ; then
|
||||||
|
: # done ok
|
||||||
|
else
|
||||||
|
echo "WARNING: rainevents function had errors"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
set -- ${lastrainevent//:/ }
|
||||||
|
local started=$1
|
||||||
|
local before=$2
|
||||||
|
local counter=$3
|
||||||
|
|
||||||
|
wrongevent=$(awk -F ":" '$1=="'$started'" && $2!="'$before'" {print $0}' $RAINSENSORQTY_HISTORY)
|
||||||
|
if [[ -n $wrongevent ]] ; then
|
||||||
|
echo "ERROR: wrong last rain event found: $wrongevent , right one should be: $lastrainevent"
|
||||||
|
return 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
if grep -q ^${lastrainevent}$ $RAINSENSORQTY_HISTORY ; then
|
||||||
|
: # already present
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
|
||||||
|
: # missing and fixed
|
||||||
|
if [[ $1 == tmp ]] ; then
|
||||||
|
echo $lastrainevent > $RAINSENSORQTY_HISTORYTMP
|
||||||
|
else
|
||||||
|
echo $lastrainevent >> $RAINSENSORQTY_HISTORY
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#next function is not used anymore
|
||||||
rain_history()
|
rain_history()
|
||||||
{
|
{
|
||||||
[[ ! -f $RAINSENSORQTY_HISTORYRAW ]] && return 1
|
[[ ! -f $RAINSENSORQTY_HISTORYRAW ]] && return 1
|
||||||
@@ -134,7 +174,7 @@ rainevents()
|
|||||||
newloop=no
|
newloop=no
|
||||||
fi
|
fi
|
||||||
if (( sequence == 1 )) ; then
|
if (( sequence == 1 )) ; then
|
||||||
# [[ $skiplast=true ]] && { skilast=false ; continue ; }
|
# [[ $skiplast=true ]] && { skiplast=false ; continue ; }
|
||||||
echo $time:$endtime:$endsequence
|
echo $time:$endtime:$endsequence
|
||||||
newloop=yes
|
newloop=yes
|
||||||
(( event +=1 ))
|
(( event +=1 ))
|
||||||
|
|||||||
@@ -4,8 +4,8 @@
|
|||||||
# Author: androtto
|
# Author: androtto
|
||||||
# file "drv_rainsensorqty_monitor.sh"
|
# file "drv_rainsensorqty_monitor.sh"
|
||||||
# monitor script
|
# monitor script
|
||||||
# Version: 0.2.5b
|
# Version: 0.2.5c
|
||||||
# Data: 12/May/2020
|
# Data: 08/Dec/2020
|
||||||
|
|
||||||
resetcounter()
|
resetcounter()
|
||||||
{
|
{
|
||||||
@@ -14,6 +14,19 @@ resetcounter()
|
|||||||
echo "SIGUSR1 received after last PULSE - counter resetted"
|
echo "SIGUSR1 received after last PULSE - counter resetted"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# DEBUG FUNCTION:
|
||||||
|
testloop()
|
||||||
|
{
|
||||||
|
touch /tmp/tick
|
||||||
|
while true
|
||||||
|
do
|
||||||
|
if [[ $( < /tmp/tick ) = "1" ]] ; then
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
###############
|
###############
|
||||||
# MAIN #
|
# MAIN #
|
||||||
###############
|
###############
|
||||||
@@ -51,30 +64,41 @@ fi
|
|||||||
echo $$ > $RAINSENSORQTY_MONPID
|
echo $$ > $RAINSENSORQTY_MONPID
|
||||||
drv_rainsensorqty_writelog $f "NORMAL - $$ pid monitor process started - see $RAINSENSORQTY_MONPID"
|
drv_rainsensorqty_writelog $f "NORMAL - $$ pid monitor process started - see $RAINSENSORQTY_MONPID"
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
en_echo "---- NEW RUN ----"
|
||||||
|
|
||||||
|
# check if monitor script was killed before writing a complete rain event
|
||||||
|
check_incomplete_loop
|
||||||
|
case $? in
|
||||||
|
2) echo "\$RAINSENSORQTY_HISTORY - wrong entry found - no fix possible" ;;
|
||||||
|
1) echo "\$RAINSENSORQTY_HISTORY - fixed incomplete loop" ;;
|
||||||
|
0) echo "\$RAINSENSORQTY_HISTORY - no incomplete loop needed to be fixed" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
# init variables
|
# init variables
|
||||||
MMEACH="$RAINSENSORQTY_MMEACH"
|
MMEACH="$RAINSENSORQTY_MMEACH"
|
||||||
(( counter=0 ))
|
(( counter=0 ))
|
||||||
rain_history
|
before="-1"
|
||||||
|
|
||||||
echo ""
|
|
||||||
en_echo "---- NEW RUN ----"
|
|
||||||
en_echo "WAITING FOR $RAINSENSORQTY_PULSE PULSE"
|
en_echo "WAITING FOR $RAINSENSORQTY_PULSE PULSE"
|
||||||
|
|
||||||
# loop forever
|
# loop forever
|
||||||
while true
|
while true
|
||||||
do
|
do
|
||||||
before=`date +%s`
|
|
||||||
sleep $RAINSENSOR_DEBOUNCE
|
sleep $RAINSENSOR_DEBOUNCE
|
||||||
|
#DEBUG: testloop #DEBUG
|
||||||
$GPIO -g wfi $gpio_port $RAINSENSORQTY_PULSE
|
$GPIO -g wfi $gpio_port $RAINSENSORQTY_PULSE
|
||||||
now=`date +%s`
|
now=`date +%s`
|
||||||
(( elapsed = now - before ))
|
(( elapsed = now - before ))
|
||||||
if (( elapsed >= RAINSENSORQTY_SECSBETWEENRAINEVENT )) ; then
|
if (( elapsed >= RAINSENSORQTY_SECSBETWEENRAINEVENT )) ; then
|
||||||
|
last_event="$started:$before:$counter"
|
||||||
(( counter=0 ))
|
(( counter=0 ))
|
||||||
drv_rainsensorqty_writelog $f "first drops after $elapsed seconds since last rain ( greater than $RAINSENSORQTY_SECSBETWEENRAINEVENT )- new cycle - waiting for $( $JQ -n "$RAINSENSORQTY_LOOPSFORSETRAINING * $MMEACH" ) mm of rain" &
|
drv_rainsensorqty_writelog $f "first drops after $elapsed seconds since last rain ( greater than $RAINSENSORQTY_SECSBETWEENRAINEVENT )- new cycle - waiting for $( $JQ -n "$RAINSENSORQTY_LOOPSFORSETRAINING * $MMEACH" ) mm of rain" &
|
||||||
|
(( before > 0 )) && echo $last_event >> $RAINSENSORQTY_HISTORY
|
||||||
en_echo "---- NEW CYCLE ----"
|
en_echo "---- NEW CYCLE ----"
|
||||||
rain_history &
|
|
||||||
fi
|
fi
|
||||||
(( counter+=1 ))
|
(( counter+=1 ))
|
||||||
|
(( counter == 1 )) && (( started = now ))
|
||||||
echo "$now:$counter" >> ${RAINSENSORQTY_HISTORYRAW} &
|
echo "$now:$counter" >> ${RAINSENSORQTY_HISTORYRAW} &
|
||||||
MMWATER=$( $JQ -n "$counter*$MMEACH" )
|
MMWATER=$( $JQ -n "$counter*$MMEACH" )
|
||||||
en_echo $( printf "%s PULSE #%d RECEIVED (%.2f mm)" $RAINSENSORQTY_PULSE $counter $MMWATER )
|
en_echo $( printf "%s PULSE #%d RECEIVED (%.2f mm)" $RAINSENSORQTY_PULSE $counter $MMWATER )
|
||||||
@@ -85,4 +109,5 @@ do
|
|||||||
else
|
else
|
||||||
drv_rainsensorqty_writelog $f "now is $text" &
|
drv_rainsensorqty_writelog $f "now is $text" &
|
||||||
fi
|
fi
|
||||||
|
(( before = now ))
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ function drv_remote_rele_open {
|
|||||||
error="${error%\"}"
|
error="${error%\"}"
|
||||||
error="${error#\"}"
|
error="${error#\"}"
|
||||||
echo "error=$error"
|
echo "error=$error"
|
||||||
log_write "Remote rele open error: $error"
|
log_write "drv_remote" "error" "Remote rele open error: $error"
|
||||||
message_write "warning" "Remote rele open error: $error"
|
message_write "warning" "Remote rele open error: $error"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -68,7 +68,7 @@ function drv_remote_rele_close {
|
|||||||
error="${error%\"}"
|
error="${error%\"}"
|
||||||
error="${error#\"}"
|
error="${error#\"}"
|
||||||
echo "error=$error"
|
echo "error=$error"
|
||||||
log_write "Remote rele close error: $error"
|
log_write "drv_remoter" "error" "Remote rele close error: $error"
|
||||||
message_write "warning" "Remote rele close error: $error"
|
message_write "warning" "Remote rele close error: $error"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ function drv_sonoff_tasmota_http_rele_open {
|
|||||||
error="${error%\"}"
|
error="${error%\"}"
|
||||||
error="${error#\"}"
|
error="${error#\"}"
|
||||||
echo "error=$error"
|
echo "error=$error"
|
||||||
log_write "Remote rele open error: $error"
|
log_write "drv_sonoff_tasmota_http" "error" "Remote rele open error: $error"
|
||||||
message_write "warning" "Remote rele open error: $error"
|
message_write "warning" "Remote rele open error: $error"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -69,7 +69,7 @@ function drv_sonoff_tasmota_http_rele_close {
|
|||||||
error="${error%\"}"
|
error="${error%\"}"
|
||||||
error="${error#\"}"
|
error="${error#\"}"
|
||||||
echo "error=$error"
|
echo "error=$error"
|
||||||
log_write "Remote rele close error: $error"
|
log_write "drv_sonoff_tasmota_http" "error" "Remote rele close error: $error"
|
||||||
message_write "warning" "Remote rele close error: $error"
|
message_write "warning" "Remote rele close error: $error"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ function drv_spb16ch_boards_id_load {
|
|||||||
SPB16CH_USED_ID+=("$board_id")
|
SPB16CH_USED_ID+=("$board_id")
|
||||||
done
|
done
|
||||||
else
|
else
|
||||||
log_write "spb16ch: file $SPB16CH_BOARD_ID_STORE_FILE not found: remember to run 'piGarden init' to generate the file"
|
log_write "drv_spb16ch" "error" "spb16ch: file $SPB16CH_BOARD_ID_STORE_FILE not found: remember to run 'piGarden init' to generate the file"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ function drv_spb16ch_rele_open {
|
|||||||
local rele_data=${SPB16CH_RELE_MAP[$rele_id]}
|
local rele_data=${SPB16CH_RELE_MAP[$rele_id]}
|
||||||
if [[ -z $rele_data ]]; then
|
if [[ -z $rele_data ]]; then
|
||||||
local message="Error - Rele map not defined - rele_id=$rele_id - ($1)"
|
local message="Error - Rele map not defined - rele_id=$rele_id - ($1)"
|
||||||
log_write "$message"
|
log_write "drv_spb16ch" "error" "$message"
|
||||||
message_write "warning" "$message"
|
message_write "warning" "$message"
|
||||||
fi
|
fi
|
||||||
local address_num=${rele_data:0:2}
|
local address_num=${rele_data:0:2}
|
||||||
@@ -52,7 +52,7 @@ function drv_spb16ch_rele_close {
|
|||||||
local rele_data=${SPB16CH_RELE_MAP[$rele_id]}
|
local rele_data=${SPB16CH_RELE_MAP[$rele_id]}
|
||||||
if [[ -z $rele_data ]]; then
|
if [[ -z $rele_data ]]; then
|
||||||
local message="Error - Rele map not defined - rele_id=$rele_id - ($1)"
|
local message="Error - Rele map not defined - rele_id=$rele_id - ($1)"
|
||||||
log_write "$message"
|
log_write "drv_spb16ch" "error" "$message"
|
||||||
message_write "warning" "$message"
|
message_write "warning" "$message"
|
||||||
fi
|
fi
|
||||||
local address_num=${rele_data:0:2}
|
local address_num=${rele_data:0:2}
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ function cron_del {
|
|||||||
|
|
||||||
if [ -z "$CRON_TYPE" ]; then
|
if [ -z "$CRON_TYPE" ]; then
|
||||||
echo "Cron type is empty" >&2
|
echo "Cron type is empty" >&2
|
||||||
log_write "Cron type is empty"
|
log_write "cron" "error" "Cron type is empty"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -25,17 +25,17 @@ function cron_del {
|
|||||||
fi
|
fi
|
||||||
if ! [[ $START =~ $re ]] ; then
|
if ! [[ $START =~ $re ]] ; then
|
||||||
echo "Cron start don't find" >&2
|
echo "Cron start don't find" >&2
|
||||||
log_write "Cron start don't find"
|
log_write "cron" "error" "Cron start don't find"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
if ! [[ $END =~ $re ]] ; then
|
if ! [[ $END =~ $re ]] ; then
|
||||||
echo "Cron end cron don't find" >&2
|
echo "Cron end cron don't find" >&2
|
||||||
log_write "Cron end cron don't find"
|
log_write "cron" "error" "Cron end cron don't find"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
if [ "$START" -gt "$END" ]; then
|
if [ "$START" -gt "$END" ]; then
|
||||||
echo "Wrong position for start and end in cron" >&2
|
echo "Wrong position for start and end in cron" >&2
|
||||||
log_write "Wrong position for start and end in cron"
|
log_write "cron" "error" "Wrong position for start and end in cron"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -74,7 +74,7 @@ function cron_add {
|
|||||||
|
|
||||||
if [ -z "$CRON_TYPE" ]; then
|
if [ -z "$CRON_TYPE" ]; then
|
||||||
echo "Cron type is empty" >&2
|
echo "Cron type is empty" >&2
|
||||||
log_write "Cron type is empty"
|
log_write "cron" "error" "Cron type is empty"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -91,12 +91,12 @@ function cron_add {
|
|||||||
else
|
else
|
||||||
if ! [[ $START =~ $re ]] ; then
|
if ! [[ $START =~ $re ]] ; then
|
||||||
echo "Cron start don't find" >&2
|
echo "Cron start don't find" >&2
|
||||||
log_write "Cron start don't find"
|
log_write "cron" "error" "Cron start don't find"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
if ! [[ $END =~ $re ]] ; then
|
if ! [[ $END =~ $re ]] ; then
|
||||||
echo "Cron end cron don't find" >&2
|
echo "Cron end cron don't find" >&2
|
||||||
log_write "Cron end cron don't find"
|
log_write "cron" "error" "Cron end cron don't find"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
START=$(($START + 1))
|
START=$(($START + 1))
|
||||||
@@ -104,7 +104,7 @@ function cron_add {
|
|||||||
|
|
||||||
if [ "$START" -gt "$END" ]; then
|
if [ "$START" -gt "$END" ]; then
|
||||||
echo "Wrong position for start and end in cron" >&2
|
echo "Wrong position for start and end in cron" >&2
|
||||||
log_write "Wrong position for start and end in cron"
|
log_write "cron" "error" "Wrong position for start and end in cron"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -183,7 +183,7 @@ function cron_add {
|
|||||||
|
|
||||||
*)
|
*)
|
||||||
echo "Wrong cron type: $CRON_TYPE"
|
echo "Wrong cron type: $CRON_TYPE"
|
||||||
log_write "Wrong cron type: $CRON_TYPE"
|
log_write "cron" "error" "Wrong cron type: $CRON_TYPE"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
esac
|
esac
|
||||||
@@ -225,7 +225,7 @@ function cron_get {
|
|||||||
|
|
||||||
if [ -z "$CRON_TYPE" ]; then
|
if [ -z "$CRON_TYPE" ]; then
|
||||||
echo "Cron type is empty" >&2
|
echo "Cron type is empty" >&2
|
||||||
log_write "Cron type is empty"
|
log_write "cron" "error" "Cron type is empty"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -241,12 +241,12 @@ function cron_get {
|
|||||||
else
|
else
|
||||||
if ! [[ $START =~ $re ]] ; then
|
if ! [[ $START =~ $re ]] ; then
|
||||||
echo "Cron start don't find" >&2
|
echo "Cron start don't find" >&2
|
||||||
log_write "Cron start don't find"
|
log_write "cron" "error" "Cron start don't find"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
if ! [[ $END =~ $re ]] ; then
|
if ! [[ $END =~ $re ]] ; then
|
||||||
echo "Cron end cron don't find" >&2
|
echo "Cron end cron don't find" >&2
|
||||||
log_write "Cron end cron don't find"
|
log_write "cron" "error" "Cron end cron don't find"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
START=$(($START + 1))
|
START=$(($START + 1))
|
||||||
@@ -254,7 +254,7 @@ function cron_get {
|
|||||||
|
|
||||||
if [ "$START" -gt "$END" ]; then
|
if [ "$START" -gt "$END" ]; then
|
||||||
echo "Wrong position for start and end in cron" >&2
|
echo "Wrong position for start and end in cron" >&2
|
||||||
log_write "Wrong position for start and end in cron"
|
log_write "cron" "error" "Wrong position for start and end in cron"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -370,7 +370,7 @@ function add_cron_open {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -387,7 +387,7 @@ function del_cron_open {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -404,7 +404,7 @@ function get_cron_open {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -421,7 +421,7 @@ function del_cron_open_in {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -439,7 +439,7 @@ function get_cron_close {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -462,7 +462,7 @@ function add_cron_close {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
@@ -479,7 +479,7 @@ function del_cron_close {
|
|||||||
|
|
||||||
local exists=`alias_exists $1`
|
local exists=`alias_exists $1`
|
||||||
if [ "check $exists" = "check FALSE" ]; then
|
if [ "check $exists" = "check FALSE" ]; then
|
||||||
log_write "Alias $1 not found"
|
log_write "cron" "error" "Alias $1 not found"
|
||||||
echo "Alias $1 not found"
|
echo "Alias $1 not found"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -94,7 +94,7 @@ function drv_rele_init {
|
|||||||
$GPIO -g mode $idx out # setta il gpio nella modalita di scrittura
|
$GPIO -g mode $idx out # setta il gpio nella modalita di scrittura
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc" == "drvnotfound" ]; then
|
elif [ "$fnc" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
@@ -116,7 +116,7 @@ function drv_rele_close {
|
|||||||
$GPIO -g write $idx $RELE_GPIO_CLOSE
|
$GPIO -g write $idx $RELE_GPIO_CLOSE
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc" == "drvnotfound" ]; then
|
elif [ "$fnc" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
return 1
|
return 1
|
||||||
else
|
else
|
||||||
@@ -142,7 +142,7 @@ function drv_rele_open {
|
|||||||
$GPIO -g write $idx $RELE_GPIO_OPEN
|
$GPIO -g write $idx $RELE_GPIO_OPEN
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc" == "drvnotfound" ]; then
|
elif [ "$fnc" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
return 1
|
return 1
|
||||||
else
|
else
|
||||||
@@ -172,7 +172,7 @@ function drv_supply_bistable_init {
|
|||||||
$GPIO -g mode $idx1 out
|
$GPIO -g mode $idx1 out
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc1" == "drvnotfound" ]; then
|
elif [ "$fnc1" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx1"
|
log_write "drv" "error" "Driver not found: $idx1"
|
||||||
message_write "warning" "Driver not found: $idx1"
|
message_write "warning" "Driver not found: $idx1"
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
@@ -186,7 +186,7 @@ function drv_supply_bistable_init {
|
|||||||
$GPIO -g mode $idx2 out
|
$GPIO -g mode $idx2 out
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc2" == "drvnotfound" ]; then
|
elif [ "$fnc2" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx2"
|
log_write "drv" "error" "Driver not found: $idx2"
|
||||||
message_write "warning" "Driver not found: $idx2"
|
message_write "warning" "Driver not found: $idx2"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc2 arg:$idx2" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc2 arg:$idx2" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
@@ -212,7 +212,7 @@ function drv_supply_positive {
|
|||||||
$GPIO -g write $idx1 $SUPPLY_GPIO_POS
|
$GPIO -g write $idx1 $SUPPLY_GPIO_POS
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc1" == "drvnotfound" ]; then
|
elif [ "$fnc1" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx1"
|
log_write "drv" "error" "Driver not found: $idx1"
|
||||||
message_write "warning" "Driver not found: $idx1"
|
message_write "warning" "Driver not found: $idx1"
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
@@ -225,7 +225,7 @@ function drv_supply_positive {
|
|||||||
$GPIO -g write $idx2 $SUPPLY_GPIO_POS
|
$GPIO -g write $idx2 $SUPPLY_GPIO_POS
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc2" == "drvnotfound" ]; then
|
elif [ "$fnc2" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx2"
|
log_write "drv" "error" "Driver not found: $idx2"
|
||||||
message_write "warning" "Driver not found: $idx2"
|
message_write "warning" "Driver not found: $idx2"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc2 arg:$idx2" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc2 arg:$idx2" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
@@ -251,7 +251,7 @@ function drv_supply_negative {
|
|||||||
$GPIO -g write $idx1 $SUPPLY_GPIO_NEG
|
$GPIO -g write $idx1 $SUPPLY_GPIO_NEG
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc1" == "drvnotfound" ]; then
|
elif [ "$fnc1" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx1"
|
log_write "drv" "error" "Driver not found: $idx1"
|
||||||
message_write "warning" "Driver not found: $idx1"
|
message_write "warning" "Driver not found: $idx1"
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
@@ -264,7 +264,7 @@ function drv_supply_negative {
|
|||||||
$GPIO -g write $idx2 $SUPPLY_GPIO_NEG
|
$GPIO -g write $idx2 $SUPPLY_GPIO_NEG
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc2" == "drvnotfound" ]; then
|
elif [ "$fnc2" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx2"
|
log_write "drv" "error" "Driver not found: $idx2"
|
||||||
message_write "warning" "Driver not found: $idx2"
|
message_write "warning" "Driver not found: $idx2"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc2 arg:$idx2" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc2 arg:$idx2" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
@@ -288,7 +288,7 @@ function drv_rain_sensor_init {
|
|||||||
$GPIO -g mode $idx in
|
$GPIO -g mode $idx in
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc" == "drvnotfound" ]; then
|
elif [ "$fnc" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
@@ -312,7 +312,7 @@ function drv_rain_sensor_get {
|
|||||||
vret=`$GPIO -g read $idx`
|
vret=`$GPIO -g read $idx`
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc" == "drvnotfound" ]; then
|
elif [ "$fnc" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
@@ -335,11 +335,11 @@ function drv_rain_online_get {
|
|||||||
|
|
||||||
# Nessun driver definito, esegue la lettura del sensore tramite gpio del raspberry
|
# Nessun driver definito, esegue la lettura del sensore tramite gpio del raspberry
|
||||||
if [ -z "$fnc" ]; then
|
if [ -z "$fnc" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
# Il driver definito non è stato trovato
|
# Il driver definito non è stato trovato
|
||||||
elif [ "$fnc" == "drvnotfound" ]; then
|
elif [ "$fnc" == "drvnotfound" ]; then
|
||||||
log_write "Driver not found: $idx"
|
log_write "drv" "error" "Driver not found: $idx"
|
||||||
message_write "warning" "Driver not found: $idx"
|
message_write "warning" "Driver not found: $idx"
|
||||||
else
|
else
|
||||||
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
echo "$(date) $fnc arg:$idx" >> "$LOG_OUTPUT_DRV_FILE"
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
function check_rain_online {
|
function check_rain_online {
|
||||||
|
|
||||||
if [ "$WEATHER_SERVICE" == "none" ]; then
|
if [ "$WEATHER_SERVICE" == "none" ]; then
|
||||||
log_write "check_rain_online - online service is disable"
|
log_write "rain" "warning" "check_rain_online - online service is disabled"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -17,7 +17,7 @@ function check_rain_online {
|
|||||||
|
|
||||||
if [[ $local_epoch =~ ^-?[0-9]+$ ]]; then
|
if [[ $local_epoch =~ ^-?[0-9]+$ ]]; then
|
||||||
if [ $local_epoch -eq 0 ]; then
|
if [ $local_epoch -eq 0 ]; then
|
||||||
log_write "check_rain_online - failed read online data"
|
log_write "rain" "error" "check_rain_online - failed read online data"
|
||||||
else
|
else
|
||||||
if [ $local_epoch -gt 0 ]; then
|
if [ $local_epoch -gt 0 ]; then
|
||||||
current_state_rain_online='rain'
|
current_state_rain_online='rain'
|
||||||
@@ -27,14 +27,14 @@ function check_rain_online {
|
|||||||
fi
|
fi
|
||||||
weather=$(cat "$STATUS_DIR/last_weather_online" | $JQ -M ".weather")
|
weather=$(cat "$STATUS_DIR/last_weather_online" | $JQ -M ".weather")
|
||||||
|
|
||||||
log_write "check_rain_online - weather=$weather, local_epoch=$local_epoch"
|
log_write "rain" "info" "check_rain_online - weather=$weather, local_epoch=$local_epoch"
|
||||||
if [ "$current_state_rain_online" != "$last_state_rain_online" ]; then
|
if [ "$current_state_rain_online" != "$last_state_rain_online" ]; then
|
||||||
echo "$current_state_rain_online" > "$STATUS_DIR/last_state_rain_online"
|
echo "$current_state_rain_online" > "$STATUS_DIR/last_state_rain_online"
|
||||||
trigger_event "check_rain_online_change" "$current_state_rain_online" "$weather"
|
trigger_event "check_rain_online_change" "$current_state_rain_online" "$weather"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
log_write "check_rain_online - failed read online data"
|
log_write "rain" "error" "check_rain_online - failed read online data"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
trigger_event "check_rain_online_after" "$current_state_rain_online" "$weather"
|
trigger_event "check_rain_online_after" "$current_state_rain_online" "$weather"
|
||||||
@@ -57,11 +57,11 @@ function check_rain_sensor {
|
|||||||
current_state_rain_sensor='rain'
|
current_state_rain_sensor='rain'
|
||||||
local local_epoch=`date +%s`
|
local local_epoch=`date +%s`
|
||||||
echo $local_epoch > "$STATUS_DIR/last_rain_sensor"
|
echo $local_epoch > "$STATUS_DIR/last_rain_sensor"
|
||||||
log_write "check_rain_sensor - now it's raining ($local_epoch)"
|
log_write "rain" "info" "check_rain_sensor - now it's raining ($local_epoch)"
|
||||||
#return $local_epoch
|
#return $local_epoch
|
||||||
else
|
else
|
||||||
current_state_rain_sensor='norain'
|
current_state_rain_sensor='norain'
|
||||||
log_write "check_rain_sensor - now is not raining"
|
log_write "rain" "info" "check_rain_sensor - now is not raining"
|
||||||
fi
|
fi
|
||||||
if [ "$current_state_rain_sensor" != "$last_state_rain_sensor" ]; then
|
if [ "$current_state_rain_sensor" != "$last_state_rain_sensor" ]; then
|
||||||
echo "$current_state_rain_sensor" > "$STATUS_DIR/last_state_rain_sensor"
|
echo "$current_state_rain_sensor" > "$STATUS_DIR/last_state_rain_sensor"
|
||||||
@@ -69,7 +69,7 @@ function check_rain_sensor {
|
|||||||
fi
|
fi
|
||||||
trigger_event "check_rain_sensor_after" "$current_state_rain_sensor"
|
trigger_event "check_rain_sensor_after" "$current_state_rain_sensor"
|
||||||
else
|
else
|
||||||
log_write "Rain sensor not present"
|
log_write "rain" "warning" "Rain sensor not present"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -113,11 +113,45 @@ function close_all_for_rain {
|
|||||||
#echo "$al = $state"
|
#echo "$al = $state"
|
||||||
if [ "$state" = "1" ] && [ "$evnorain" != "1" ]; then
|
if [ "$state" = "1" ] && [ "$evnorain" != "1" ]; then
|
||||||
ev_close $al
|
ev_close $al
|
||||||
log_write "close_all_for_rain - Close solenoid '$al' for rain"
|
log_write "irrigate" "warning" "close_all_for_rain - Close solenoid '$al' for rain"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Mostra il timestamp dell'ultima pioggia rilevato dal sensore
|
||||||
|
#
|
||||||
|
function last_rain_sensor_timestamp {
|
||||||
|
cat "$STATUS_DIR/last_rain_sensor" 2> /dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Mostra il timestamp dell'ultima pioggia rilevato dal servizio online
|
||||||
|
#
|
||||||
|
function last_rain_online_timestamp {
|
||||||
|
cat "$STATUS_DIR/last_rain_online" 2> /dev/null
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Resetta il timestamp dell'ultima pioggia rilevato dal sensore
|
||||||
|
#
|
||||||
|
function reset_last_rain_sensor_timestamp {
|
||||||
|
trigger_event "reset_last_rain_sensor_timestamp_before" ""
|
||||||
|
rm "$STATUS_DIR/last_rain_sensor" 2> /dev/null
|
||||||
|
trigger_event "reset_last_rain_sensor_timestamp_after" ""
|
||||||
|
log_write "rain" "info" "reset_last_rain_sensor_timestamp"
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Resetta mostra il timestamp dell'ultima pioggia rilevato dal servizio online
|
||||||
|
#
|
||||||
|
function reset_last_rain_online_timestamp {
|
||||||
|
trigger_event "reset_last_rain_online_timestamp_before" ""
|
||||||
|
rm "$STATUS_DIR/last_rain_online" 2> /dev/null
|
||||||
|
trigger_event "reset_last_rain_online_timestamp_before" ""
|
||||||
|
log_write "rain" "info" "reset_last_rain_online_timestamp"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -19,7 +19,7 @@ function stop_socket_server {
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log_write "stop socket server"
|
log_write "socket_server" "info" "stop socket server"
|
||||||
|
|
||||||
kill -9 $(list_descendants `cat "$TCPSERVER_PID_FILE"`) 2> /dev/null
|
kill -9 $(list_descendants `cat "$TCPSERVER_PID_FILE"`) 2> /dev/null
|
||||||
kill -9 `cat "$TCPSERVER_PID_FILE"` 2> /dev/null
|
kill -9 `cat "$TCPSERVER_PID_FILE"` 2> /dev/null
|
||||||
@@ -44,7 +44,7 @@ function socket_server_command {
|
|||||||
user=$(echo "$user" | $TR -d '[\r\n]')
|
user=$(echo "$user" | $TR -d '[\r\n]')
|
||||||
password=$(echo "$password" | $TR -d '[\r\n]')
|
password=$(echo "$password" | $TR -d '[\r\n]')
|
||||||
if [ "$user" != "$TCPSERVER_USER" ] || [ "$password" != "$TCPSERVER_PWD" ]; then
|
if [ "$user" != "$TCPSERVER_USER" ] || [ "$password" != "$TCPSERVER_PWD" ]; then
|
||||||
log_write "socket connection from: $TCPREMOTEIP - Bad socket server credentials - user:$user"
|
log_write "socket_server" "warning" "socket connection from: $TCPREMOTEIP - Bad socket server credentials - user:$user"
|
||||||
json_error 0 "Bad socket server credentials"
|
json_error 0 "Bad socket server credentials"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
@@ -61,7 +61,7 @@ function socket_server_command {
|
|||||||
arg7=$(echo "$line " | $CUT -d ' ' -f7)
|
arg7=$(echo "$line " | $CUT -d ' ' -f7)
|
||||||
arg8=$(echo "$line " | $CUT -d ' ' -f8)
|
arg8=$(echo "$line " | $CUT -d ' ' -f8)
|
||||||
|
|
||||||
log_write "socket connection from: $TCPREMOTEIP - command: $arg1 $arg2 $arg3 $arg4 $arg5 $arg6 $arg7 $arg8"
|
log_write "socket_server" "info" "socket connection from: $TCPREMOTEIP - command: $arg1 $arg2 $arg3 $arg4 $arg5 $arg6 $arg7 $arg8"
|
||||||
|
|
||||||
#reset_messages &> /dev/null
|
#reset_messages &> /dev/null
|
||||||
|
|
||||||
@@ -127,7 +127,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "Cron set failed"
|
json_error 0 "Cron set failed"
|
||||||
log_write "Cron set failed: $vret"
|
log_write "socket_server" "error" "Cron set failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Cron set successfull"
|
message_write "success" "Cron set successfull"
|
||||||
json_status
|
json_status
|
||||||
@@ -142,7 +142,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "Cron set failed"
|
json_error 0 "Cron set failed"
|
||||||
log_write "Cron del failed: $vret"
|
log_write "socket_server" "error" "Cron del failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Cron set successfull"
|
message_write "success" "Cron set successfull"
|
||||||
json_status
|
json_status
|
||||||
@@ -157,7 +157,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "Cron del failed"
|
json_error 0 "Cron del failed"
|
||||||
log_write "Cron del failed: $vret"
|
log_write "socket_server" "error" "Cron del failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Scheduled start successfully deleted"
|
message_write "success" "Scheduled start successfully deleted"
|
||||||
json_status "get_cron_open_in:$arg2"
|
json_status "get_cron_open_in:$arg2"
|
||||||
@@ -173,7 +173,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "Cron set failed"
|
json_error 0 "Cron set failed"
|
||||||
log_write "Cron set failed: $vret"
|
log_write "socket_server" "error" "Cron set failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Cron set successfull"
|
message_write "success" "Cron set successfull"
|
||||||
json_status
|
json_status
|
||||||
@@ -188,7 +188,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "Cron set failed"
|
json_error 0 "Cron set failed"
|
||||||
log_write "Cron set failed: $vret"
|
log_write "socket_server" "error" "Cron set failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Cron set successfull"
|
message_write "success" "Cron set successfull"
|
||||||
json_status
|
json_status
|
||||||
@@ -203,7 +203,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "Cron set failed"
|
json_error 0 "Cron set failed"
|
||||||
log_write "Cron set failed: $vret"
|
log_write "socket_server" "error" "Cron set failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Cron set successfull"
|
message_write "success" "Cron set successfull"
|
||||||
json_status
|
json_status
|
||||||
@@ -218,7 +218,7 @@ function socket_server_command {
|
|||||||
|
|
||||||
if [[ ! -z $vret ]]; then
|
if [[ ! -z $vret ]]; then
|
||||||
json_error 0 "piGardenSched command failed"
|
json_error 0 "piGardenSched command failed"
|
||||||
log_write "piGardenSched command failed: $vret"
|
log_write "socket_server" "error" "piGardenSched command failed: $vret"
|
||||||
else
|
else
|
||||||
message_write "success" "Schedule set successfull"
|
message_write "success" "Schedule set successfull"
|
||||||
json_status
|
json_status
|
||||||
@@ -240,6 +240,19 @@ function socket_server_command {
|
|||||||
nohup $PATH_SCRIPT poweroff > /dev/null 2>&1 &
|
nohup $PATH_SCRIPT poweroff > /dev/null 2>&1 &
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
reset_last_rain_sensor_timestamp)
|
||||||
|
reset_last_rain_sensor_timestamp
|
||||||
|
message_write "success" "Timestamp of last sensor rain successfull reset"
|
||||||
|
json_status
|
||||||
|
;;
|
||||||
|
|
||||||
|
reset_last_rain_online_timestamp)
|
||||||
|
reset_last_rain_online_timestamp
|
||||||
|
message_write "success" "Timestamp of last online rain successfull reset"
|
||||||
|
json_status
|
||||||
|
;;
|
||||||
|
|
||||||
|
|
||||||
*)
|
*)
|
||||||
json_error 0 "invalid command"
|
json_error 0 "invalid command"
|
||||||
;;
|
;;
|
||||||
|
|||||||
80
piGarden.sh
80
piGarden.sh
@@ -10,7 +10,7 @@
|
|||||||
#
|
#
|
||||||
function initialize {
|
function initialize {
|
||||||
|
|
||||||
log_write "Run initialize"
|
log_write "general" "info" "Run initialize"
|
||||||
|
|
||||||
unlock
|
unlock
|
||||||
|
|
||||||
@@ -50,13 +50,13 @@ function initialize {
|
|||||||
# Inizializza il sensore di rilevamento pioggia
|
# Inizializza il sensore di rilevamento pioggia
|
||||||
if [ -n "$RAIN_GPIO" ]; then
|
if [ -n "$RAIN_GPIO" ]; then
|
||||||
drv_rain_sensor_init "$RAIN_GPIO"
|
drv_rain_sensor_init "$RAIN_GPIO"
|
||||||
log_write "Rain sensor initialized"
|
log_write "rain" "info" "Rain sensor initialized"
|
||||||
else
|
else
|
||||||
log_write "Rain sensor not present"
|
log_write "rain" "info" "Rain sensor not present"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
trigger_event "init_after" ""
|
trigger_event "init_after" ""
|
||||||
log_write "End initialize"
|
log_write "general" "info" "End initialize"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -98,7 +98,7 @@ function ev_open {
|
|||||||
message_write "warning" "Solenoid not open for rain"
|
message_write "warning" "Solenoid not open for rain"
|
||||||
trigger_event "ev_not_open_for_rain_online" "$1"
|
trigger_event "ev_not_open_for_rain_online" "$1"
|
||||||
trigger_event "ev_not_open_for_rain" "$1"
|
trigger_event "ev_not_open_for_rain" "$1"
|
||||||
log_write "Solenoid '$1' not open for rain (online check)"
|
log_write "irrigate" "warning" "Solenoid '$1' not open for rain (online check)"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -113,7 +113,7 @@ function ev_open {
|
|||||||
message_write "warning" "Solenoid not open for rain"
|
message_write "warning" "Solenoid not open for rain"
|
||||||
trigger_event "ev_not_open_for_rain_sensor" "$1"
|
trigger_event "ev_not_open_for_rain_sensor" "$1"
|
||||||
trigger_event "ev_not_open_for_rain" "$1"
|
trigger_event "ev_not_open_for_rain" "$1"
|
||||||
log_write "Solenoid '$1' not open for rain (sensor check)"
|
log_write "irrigate" "warning" "Solenoid '$1' not open for rain (sensor check)"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@@ -126,7 +126,7 @@ function ev_open {
|
|||||||
|
|
||||||
trigger_event "ev_open_before" "$1" "$2"
|
trigger_event "ev_open_before" "$1" "$2"
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
log_write "Solenoid '$1' not open due to external event"
|
log_write "irrigate" "warning" "Solenoid '$1' not open due to external event"
|
||||||
message_write 'warning' "Solenoid not open due to external event"
|
message_write 'warning' "Solenoid not open due to external event"
|
||||||
mqtt_status
|
mqtt_status
|
||||||
return
|
return
|
||||||
@@ -150,7 +150,7 @@ function ev_open {
|
|||||||
|
|
||||||
ev_set_state $EVNUM $state
|
ev_set_state $EVNUM $state
|
||||||
|
|
||||||
log_write "Solenoid '$1' open"
|
log_write "irrigate" "info" "Solenoid '$1' open"
|
||||||
message_write "success" "Solenoid open"
|
message_write "success" "Solenoid open"
|
||||||
|
|
||||||
trigger_event "ev_open_after" "$1" "$2"
|
trigger_event "ev_open_after" "$1" "$2"
|
||||||
@@ -259,7 +259,7 @@ function ev_close {
|
|||||||
|
|
||||||
ev_set_state $EVNUM 0
|
ev_set_state $EVNUM 0
|
||||||
|
|
||||||
log_write "Solenoid '$1' close"
|
log_write "irrigate" "info" "Solenoid '$1' close"
|
||||||
message_write "success" "Solenoid close"
|
message_write "success" "Solenoid close"
|
||||||
|
|
||||||
trigger_event "ev_close_after" "$1"
|
trigger_event "ev_close_after" "$1"
|
||||||
@@ -285,7 +285,9 @@ function supply_negative {
|
|||||||
|
|
||||||
#
|
#
|
||||||
# Scrive un messaggio nel file di log
|
# Scrive un messaggio nel file di log
|
||||||
# $1 log da scrivere
|
# $1 type
|
||||||
|
# $2 level
|
||||||
|
# $3 log da scrivere
|
||||||
#
|
#
|
||||||
function log_write {
|
function log_write {
|
||||||
if [ -e "$LOG_FILE" ]; then
|
if [ -e "$LOG_FILE" ]; then
|
||||||
@@ -304,7 +306,25 @@ function log_write {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "`date`\t\t$1" >> $LOG_FILE
|
echo -e "`date`\t\t$1\t$2\t$3" >> $LOG_FILE
|
||||||
|
|
||||||
|
log_send "$1" "$2" "`date '+%Y-%m-%d %H:%M:%S'`" "$3"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# Invia un log verso piGardenWeb
|
||||||
|
# $1 type
|
||||||
|
# $2 level
|
||||||
|
# $3 date time
|
||||||
|
# $4 messaggio
|
||||||
|
#
|
||||||
|
function log_send {
|
||||||
|
|
||||||
|
if [[ ! -z "$LOG_URL" ]]; then
|
||||||
|
$CURL $LOG_CURL_PARAM "$LOG_URL" -d "api_token=$LOG_API_TOKEN&type=$1&level=$2&datetime_log=$3&message=$4" &> /dev/null &
|
||||||
|
fi
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
@@ -373,7 +393,7 @@ function gpio_alias2number {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
log_write "ERROR solenoid alias not found: $1"
|
log_write "general" "error" "ERROR solenoid alias not found: $1"
|
||||||
message_write "warning" "Solenoid alias not found"
|
message_write "warning" "Solenoid alias not found"
|
||||||
mqtt_status
|
mqtt_status
|
||||||
exit 1
|
exit 1
|
||||||
@@ -393,7 +413,7 @@ function ev_alias2number {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
log_write "ERROR solenoid alias not found: $1"
|
log_write "general" "error" "ERROR solenoid alias not found: $1"
|
||||||
message_write "warning" "Solenoid alias not found"
|
message_write "warning" "Solenoid alias not found"
|
||||||
mqtt_status
|
mqtt_status
|
||||||
exit 1
|
exit 1
|
||||||
@@ -480,7 +500,7 @@ function close_all {
|
|||||||
#echo "$al = $state"
|
#echo "$al = $state"
|
||||||
if [[ "$state" -gt "0" || "$1" = "force" ]]; then
|
if [[ "$state" -gt "0" || "$1" = "force" ]]; then
|
||||||
ev_close $al
|
ev_close $al
|
||||||
log_write "close_all - Close solenoid '$al' for rain"
|
log_write "irrigate" "info" "close_all - Close solenoid '$al' for rain"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -707,6 +727,10 @@ function show_usage {
|
|||||||
echo -e "\t$NAME_SCRIPT list_alias view list of aliases solenoid"
|
echo -e "\t$NAME_SCRIPT list_alias view list of aliases solenoid"
|
||||||
echo -e "\t$NAME_SCRIPT ev_status alias show status solenoid"
|
echo -e "\t$NAME_SCRIPT ev_status alias show status solenoid"
|
||||||
echo -e "\t$NAME_SCRIPT ev_status_all show status solenoids"
|
echo -e "\t$NAME_SCRIPT ev_status_all show status solenoids"
|
||||||
|
echo -e "\t$NAME_SCRIPT last_rain_sensor_timestamp show timestamp of last rain sensor"
|
||||||
|
echo -e "\t$NAME_SCRIPT last_rain_online_timestamp show timestamp of last rain online"
|
||||||
|
echo -e "\t$NAME_SCRIPT reset_last_rain_sensor_timestamp show timestamp of last rain sensor"
|
||||||
|
echo -e "\t$NAME_SCRIPT reset_last_rain_online_timestamp show timestamp of last rain online"
|
||||||
echo -e "\t$NAME_SCRIPT json_status [get_cron|get_cron_open_in|get_schedule] show status in json format"
|
echo -e "\t$NAME_SCRIPT json_status [get_cron|get_cron_open_in|get_schedule] show status in json format"
|
||||||
echo -e "\t$NAME_SCRIPT mqtt_status send status in json format to mqtt broker"
|
echo -e "\t$NAME_SCRIPT mqtt_status send status in json format to mqtt broker"
|
||||||
echo -e "\t$NAME_SCRIPT check_rain_online check rain from http://api.wunderground.com/"
|
echo -e "\t$NAME_SCRIPT check_rain_online check rain from http://api.wunderground.com/"
|
||||||
@@ -779,12 +803,12 @@ function lock {
|
|||||||
local foo=bar
|
local foo=bar
|
||||||
else
|
else
|
||||||
if [ "$current_time" -gt "$max_time" ]; then
|
if [ "$current_time" -gt "$max_time" ]; then
|
||||||
log_write "Maximum locked time reached"
|
log_write "general" "error" "Maximum locked time reached"
|
||||||
sleep $max_time
|
sleep $max_time
|
||||||
unlock
|
unlock
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
log_write "Sleep 1 second for locked state"
|
log_write "general" "info" "Sleep 1 second for locked state"
|
||||||
sleep 1
|
sleep 1
|
||||||
lock $current_time
|
lock $current_time
|
||||||
return
|
return
|
||||||
@@ -833,7 +857,7 @@ function send_identifier {
|
|||||||
fi
|
fi
|
||||||
echo "$ID" > "$FILE_ID"
|
echo "$ID" > "$FILE_ID"
|
||||||
|
|
||||||
log_write "Send installation identifier to collect usage"
|
log_write "general" "info" "Send installation identifier to collect usage"
|
||||||
|
|
||||||
$CURL https://www.lejubila.net/statistic/collect_usage/piGarden/$ID/$VERSION/$SUB_VERSION/$RELEASE_VERSION > /dev/null 2>&1
|
$CURL https://www.lejubila.net/statistic/collect_usage/piGarden/$ID/$VERSION/$SUB_VERSION/$RELEASE_VERSION > /dev/null 2>&1
|
||||||
|
|
||||||
@@ -875,7 +899,7 @@ function cmd_pigardensched {
|
|||||||
|
|
||||||
if [ $PIGARDENSCHED == 0 ]; then
|
if [ $PIGARDENSCHED == 0 ]; then
|
||||||
echo "piGardenSched not configured in piGarden" >&2
|
echo "piGardenSched not configured in piGarden" >&2
|
||||||
log_write "piGardenSched not configured in piGarden"
|
log_write "piGardenSched" "error" "piGardenSched not configured in piGarden"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -984,7 +1008,7 @@ function debug2 {
|
|||||||
|
|
||||||
VERSION=0
|
VERSION=0
|
||||||
SUB_VERSION=6
|
SUB_VERSION=6
|
||||||
RELEASE_VERSION=0
|
RELEASE_VERSION=3
|
||||||
|
|
||||||
DIR_SCRIPT=`dirname $0`
|
DIR_SCRIPT=`dirname $0`
|
||||||
NAME_SCRIPT=${0##*/}
|
NAME_SCRIPT=${0##*/}
|
||||||
@@ -1099,6 +1123,22 @@ case "$1" in
|
|||||||
mqtt_status $2
|
mqtt_status $2
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
last_rain_sensor_timestamp)
|
||||||
|
last_rain_sensor_timestamp
|
||||||
|
;;
|
||||||
|
|
||||||
|
last_rain_online_timestamp)
|
||||||
|
last_rain_online_timestamp
|
||||||
|
;;
|
||||||
|
|
||||||
|
reset_last_rain_sensor_timestamp)
|
||||||
|
reset_last_rain_sensor_timestamp
|
||||||
|
;;
|
||||||
|
|
||||||
|
reset_last_rain_online_timestamp)
|
||||||
|
reset_last_rain_online_timestamp
|
||||||
|
;;
|
||||||
|
|
||||||
check_rain_online)
|
check_rain_online)
|
||||||
check_rain_online
|
check_rain_online
|
||||||
;;
|
;;
|
||||||
@@ -1130,7 +1170,7 @@ case "$1" in
|
|||||||
nohup $0 start_socket_server_daemon > /dev/null 2>&1 &
|
nohup $0 start_socket_server_daemon > /dev/null 2>&1 &
|
||||||
|
|
||||||
echo "Daemon is started widh pid $!"
|
echo "Daemon is started widh pid $!"
|
||||||
log_write "start socket server with pid $!"
|
log_write "socket_server" "info" "start socket server with pid $!"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
start_socket_server_daemon)
|
start_socket_server_daemon)
|
||||||
|
|||||||
Reference in New Issue
Block a user