from overrides import overrides
import base_presence
-from type.locations import Location
import site_config
import state_tracker
+from type.locations import Location
logger = logging.getLogger(__name__)
-class WaitablePresenceDetectorWithMemory(
- state_tracker.WaitableAutomaticStateTracker
-):
+class WaitablePresenceDetectorWithMemory(state_tracker.WaitableAutomaticStateTracker):
"""
This is a waitable class that keeps a PresenceDetector internally
and periodically polls it to detect changes in presence in a
self,
override_update_interval_sec: float = 60.0,
override_location: Location = site_config.get_location(),
+ injected_presence_detector: Optional[base_presence.PresenceDetection] = None,
) -> None:
self.last_someone_is_home: Optional[bool] = None
self.someone_is_home: Optional[bool] = None
self.everyone_gone_since: Optional[datetime.datetime] = None
self.someone_home_since: Optional[datetime.datetime] = None
self.location = override_location
- self.detector: base_presence.PresenceDetection = (
- base_presence.PresenceDetection()
- )
+ if injected_presence_detector is not None:
+ self.detector: base_presence.PresenceDetection = injected_presence_detector
+ else:
+ self.detector = base_presence.PresenceDetection()
super().__init__(
{
'poll_presence': override_update_interval_sec,
def check_detector(self) -> None:
if len(self.detector.dark_locations) > 0:
- logger.debug(
- 'PresenceDetector is incomplete; trying to reinitialize...'
- )
+ logger.debug('PresenceDetector is incomplete; trying to reinitialize...')
self.detector = base_presence.PresenceDetection()
- def is_someone_home(self) -> Tuple[bool, datetime.datetime]:
+ def is_someone_home(self) -> Optional[Tuple[bool, datetime.datetime]]:
"""Returns a tuple of a bool that indicates whether someone is home
and a datetime that indicates how long either someone has been
home or no one has been home.
"""
if self.someone_is_home is None:
- raise Exception("Too Soon!")
+ return None # checked too soon, wait a bit.
if self.someone_is_home:
+ assert self.someone_home_since is not None
return (True, self.someone_home_since)
else:
+ assert self.everyone_gone_since is not None
return (False, self.everyone_gone_since)