I have 2 parameters in DB: start and stop. value for them can be eg 07:00-23:00 or 23:00-07:00 (start after 07, stop after 23 or start after 23, stop after 07)
In that time, a status must be 0 or 1, let's say it's LED
How to create unified logic controller that won't mess up after/before midnight?
My poor implementation (wont work) is below. Actually, I've tried many-many variations and still ended up where I currently am..
if curtime >= vv_time_trig1 and curtime <= vv_time_trig2:
logger.info("turning socket on")
logger.debug("#1")
#check current status
#if current is 0
#turn socket on
if vvstatus == 0:
logger.debug("current status off, turning socket on")
GPIO.output(25, GPIO.HIGH)
#check current status
#if current is already 1
#do nothing
elif vvstatus == 1:
logger.info("skiping. already on")
#unhandeled current status
else:
logger.critical("unhandeled vvstatus!")
logger.critical("turning socket off")
GPIO.output(25, GPIO.LOW)
#if current time is before start
#turn off
elif curtime <= vv_time_trig1 and curtime >= vv_time_trig2:
logger.info("turning socket off")
logger.debug("#2")
#check current status
#if current is 1
#turn socket off
if vvstatus == 1:
logger.debug("current status on, turning socket off")
GPIO.output(25, GPIO.LOW)
#check current status
#if current is already 0
#do nothing
elif vvstatus == 0:
logger.info("skiping. already off")
#unhandeled current status
else:
logger.critical("unhandeled vvstatus!")
logger.critical("turning socket off")
GPIO.output(25, GPIO.LOW)
#if current time is after stop
#turn off
elif curtime >= vv_time_trig2:
logger.info("turning socket off")
logger.debug("#3")
#check current status
#if current is 1
#turn socket off
if vvstatus == 1:
logger.debug("current status: %s, turning socket off", vvstatus)
GPIO.output(25, GPIO.LOW)
#check current status
#if current is already 0
#do nothing
elif vvstatus == 0:
logger.info("skiping. already on")
#unhandeled current status
else:
logger.critical("unhandeled vvstatus!")
logger.critical("turning socket off")
GPIO.output(25, GPIO.LOW)
#if current time is before stop
#turn off
elif curtime <= vv_time_trig2 and curtime <= vv_time_trig1:
logger.info("turning socket on")
logger.debug("#4")
#check current status
#if current is 0
#turn socket on
if vvstatus == 0:
logger.debug("current status off, turning socket on")
GPIO.output(25, GPIO.HIGH)
#check current status
#if current is already 1
#do nothing
elif vvstatus == 1:
logger.info("skiping. already on")
#unhandeled current status
else:
logger.critical("unhandeled vvstatus!")
logger.critical("turning socket off")
GPIO.output(25, GPIO.LOW)
Updated version. Determine current position in time relative to the end. end is set to tomorrow if midnight passes
n1 = datetime.now()
startTrig = datetime(n1.year, n1.month, n1.day, 23, 00, 0)
logger.debug("start: %s",startTrig)
n = datetime.now()
endTrig = datetime(n.year, n.month, n.day, 07, 00, 0)
logger.debug("end: %s",endTrig)
if startTrig > endTrig:
logger.debug("start > stop")
endTrig += timedelta(days=1)
logger.debug("new stop trig: %s",endTrig)
if datetime.now() < endTrig:
if curStatus == 1:
logger.debug("socket %s already on. doing nothing.")
elif curStatus == 0:
logger.debug("socket %s sould be on. flipping switch")
flipSocketStatus(bcmNo,bcmDir)
else:
logger.critical("unhandeled socket %s current status %s",socName,curStatus)
if curStatus == 1:
logger.critical("shutting socket %s down",socName)
GPIO.output(bcmNo, GPIO.LOW)
elif curStatus == 0:
logger.warn("socket %s already off",socName)
else:
logger.critical("unhandeled current status for pin: %s",bcmNo)
logger.critical("forcing socket %s down",socName)
GPIO.output(bcmNo, GPIO.LOW)
else:
logger.critical("unhandeled start-stop rules")
There are two cases: the current time is between given times (clock-wise) or outside (imagine the clock circle):
Output
UPDATE: Based on your update
This looks better, the only thing I'm confused about is your
if datetime.now() < endTrig
conditional.Correct me if I'm still misunderstanding you, but your current conditional looks like it reads:
You mentioned status must be 0 or 1. Based on that I would expect your conditional to look something like: