Powering off system when closing the last remaining zone and it being the constant zone now works correctly.
This commit is contained in:
parent
ac9addde30
commit
ee7751ffd5
33
aircon.sh
33
aircon.sh
|
@ -497,14 +497,17 @@ function generate_actions() { # populates global: nairconcommands & airconcmd
|
||||||
# pass xx - if we're closing the constant zone, and it's NOT the myzone,
|
# pass xx - if we're closing the constant zone, and it's NOT the myzone,
|
||||||
# just turn the whole system off (since it will probably be opened.
|
# just turn the whole system off (since it will probably be opened.
|
||||||
# again anyway).
|
# again anyway).
|
||||||
|
#
|
||||||
if [[ -z $powerchange && $airconmode != "off" ]]; then
|
if [[ -z $powerchange && $airconmode != "off" ]]; then
|
||||||
for x in ${!zname[@]}; do
|
for x in ${!zname[@]}; do
|
||||||
if [[ ${zaction[$x]} == *close_vent* && $constant == ${zname[$x]} ]]; then
|
if [[ ${zaction[$x]} == *close_vent* ]]; then
|
||||||
|
if [[ $constant == ${zname[$x]} ]]; then
|
||||||
if [[ $airconmyzoneid != ${zid[$x]} ]]; then
|
if [[ $airconmyzoneid != ${zid[$x]} ]]; then
|
||||||
zaction[$x]="power_off"
|
zaction[$x]="power_off"
|
||||||
[[ -z $powerchange ]] && powerchange="power_off"
|
[[ -z $powerchange ]] && powerchange="power_off"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -619,9 +622,22 @@ function generate_actions() { # populates global: nairconcommands & airconcmd
|
||||||
gen_aircon_command ${x} ${zaction[$x]}
|
gen_aircon_command ${x} ${zaction[$x]}
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# if we are closing the constant zone and taking no other action,
|
||||||
|
# just turn the system off.
|
||||||
|
if [[ $nairconcommands -eq 1 ]]; then
|
||||||
|
if [[ ${airconjcmd[0]} == *lose* ]]; then
|
||||||
|
if [[ ${airconcmdzone[0]} == $constant ]]; then
|
||||||
|
globprob="constant_close"
|
||||||
|
globaction="power_off"
|
||||||
|
[[ -z $powerchange ]] && powerchange="power_off"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
if [[ -n $globaction ]]; then
|
if [[ -n $globaction ]]; then
|
||||||
gen_aircon_command -1 ${globaction}
|
gen_aircon_command -1 ${globaction}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[[ $cronmode -eq 0 && $logmode -eq 0 ]] && echo -e "${GREEN}${BOLD}ok${PLAIN}"
|
[[ $cronmode -eq 0 && $logmode -eq 0 ]] && echo -e "${GREEN}${BOLD}ok${PLAIN}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1542,6 +1558,15 @@ function get_aircon_info() {
|
||||||
[[ $cronmode -eq 0 && $logmode -eq 0 ]] && echo -en "${GREEN}${BOLD}>> ${PLAIN}${GREEN}Querying aircon... ${PLAIN}"
|
[[ $cronmode -eq 0 && $logmode -eq 0 ]] && echo -en "${GREEN}${BOLD}>> ${PLAIN}${GREEN}Querying aircon... ${PLAIN}"
|
||||||
url="${AIRCON_URL}/getSystemData"
|
url="${AIRCON_URL}/getSystemData"
|
||||||
jsoninfo=$(curl -s "$url" 2>/dev/null)
|
jsoninfo=$(curl -s "$url" 2>/dev/null)
|
||||||
|
if [[ $? -ne 0 ]]; then
|
||||||
|
error "get_aircon_info() failed to reach ${AIRCON_URL}/getSystemData endpoint"
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
|
echo "$jsoninfo" | jq . &>/dev/null
|
||||||
|
if [[ $? -ne 0 ]]; then
|
||||||
|
error "${AIRCON_URL}/getSystemData returned bad json: $jsoninfo"
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
zones=$(echo "$jsoninfo" | $JQ -r '.aircons.ac1.zones[] | [ .name, .state, .setTemp, .measuredTemp, .number ] | @csv' | tr -d '" ')
|
zones=$(echo "$jsoninfo" | $JQ -r '.aircons.ac1.zones[] | [ .name, .state, .setTemp, .measuredTemp, .number ] | @csv' | tr -d '" ')
|
||||||
state=$(echo "$jsoninfo" | $JQ -r '.aircons.ac1.info.state' | tr -d '" ')
|
state=$(echo "$jsoninfo" | $JQ -r '.aircons.ac1.info.state' | tr -d '" ')
|
||||||
if [[ $state == "off" ]]; then
|
if [[ $state == "off" ]]; then
|
||||||
|
@ -1555,6 +1580,10 @@ url="${AIRCON_URL}/getSystemData"
|
||||||
IFS=',' read -ra tok <<< "$line"
|
IFS=',' read -ra tok <<< "$line"
|
||||||
addzone "${tok[0]}" "${tok[1]}" "${tok[2]}" "${tok[3]}" "${tok[4]}"
|
addzone "${tok[0]}" "${tok[1]}" "${tok[2]}" "${tok[3]}" "${tok[4]}"
|
||||||
done
|
done
|
||||||
|
if [[ $nzones -eq 0 ]]; then
|
||||||
|
error "get_aircon_info() found no zones"
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
airconmyzone=$(getnamefromid $airconmyzoneid)
|
airconmyzone=$(getnamefromid $airconmyzoneid)
|
||||||
[[ $cronmode -eq 0 && $logmode -eq 0 ]] && echo -e "${GREEN}${BOLD}ok${PLAIN}"
|
[[ $cronmode -eq 0 && $logmode -eq 0 ]] && echo -e "${GREEN}${BOLD}ok${PLAIN}"
|
||||||
profile "query aircon"
|
profile "query aircon"
|
||||||
|
@ -1674,6 +1703,8 @@ function describe_globprob() {
|
||||||
echo "$limit or more zones are ${globprob/_/ }"
|
echo "$limit or more zones are ${globprob/_/ }"
|
||||||
elif [[ $globprob == "not_needed" ]]; then
|
elif [[ $globprob == "not_needed" ]]; then
|
||||||
echo "The system is on but all zones at optimal temperature"
|
echo "The system is on but all zones at optimal temperature"
|
||||||
|
elif [[ $globprob == "constant_close" ]]; then
|
||||||
|
echo "All other zones are already closed"
|
||||||
else
|
else
|
||||||
echo "_unknown_globprob_:$globprob"
|
echo "_unknown_globprob_:$globprob"
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Reference in New Issue