domo.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. # -*- coding: utf-8 -*-
  2. from __future__ import print_function, absolute_import, division, unicode_literals
  3. import os
  4. import logging
  5. from timeit import default_timer
  6. from random import choice
  7. import time
  8. import requests
  9. from ameise import app, ask, log
  10. from utils import write_text_matrix
  11. from flask_ask import Ask, statement, question, session, context
  12. ALEXA_DEVICE2ROOM = {
  13. 'amzn1.ask.device.AGUM4ZB75QPFGNC5X2TYPIACRGBGQJUG7W3EJYVOG7W46XYQLQJNH3OJAUYPRZKMWDDE2UJGFJWSWCM27F4D22LD2PC6T3CAZEJB5ZQPIBY6NA32MIITTNUCTUL5SOIV5RDC2HWHI6UJRN77G7CFT2TPZB6A':
  14. 'arbeitszimmer',
  15. 'amzn1.ask.device.AGUM4ZB75QPFGNC5X2TYPIACRGBPSS5LVRD657YFVYBPGW2VGO2TZTHMZVAUBLBDSBKCTZ5P5MOXX5S5DLDEKPQAIOSQLQOI2SXIF2X6HT5GMJELOUNWZEXNM44SCT4CQBNTC73WDCW3KNX75PFXNFR7GRVA':
  16. 'wohnzimmer',
  17. }
  18. # room powerswitch ids
  19. ROOM2POWER_DOMO_IDX = {
  20. 'arbeitszimmer': 2839,
  21. 'wohnzimmer': 2840,
  22. }
  23. class RoomState(object):
  24. def __init__(self):
  25. self.last_switches = {}
  26. for room in ROOM2POWER_DOMO_IDX:
  27. self.last_switches[room] = time.time()
  28. STATE = RoomState()
  29. # map alexa slot to domoticz switch value
  30. ON_OFF_SLOT = {'an': 'On', 'aus': 'Off'}
  31. DOMO_ALEXA_AUTH = ('alexa', os.environ['DOMO_ALEXA_PW'])
  32. DOMO_BASE = 'https://domo.cere.duckdns.org/json.htm'
  33. def domo_command(**kwargs):
  34. t = default_timer()
  35. try:
  36. kwargs['type'] = 'command'
  37. resp = requests.get(DOMO_BASE, params=kwargs, auth=DOMO_ALEXA_AUTH)
  38. if resp.status_code == 200:
  39. return resp.json()
  40. else:
  41. raise ValueError('code: %s' % resp.status_code)
  42. finally:
  43. log.info('domo call in %.3f sec' % (default_timer()-t))
  44. @ask.intent("LightIntent")
  45. def toggle_switch(OnOff):
  46. did = context.System.device.get('deviceId')
  47. room = ALEXA_DEVICE2ROOM.get(did)
  48. if room is None:
  49. return statement('Sorry, Ich weiss nicht wo du bist')
  50. log.info('alexa: room %s switch: %s' % (room, OnOff))
  51. assert OnOff in ON_OFF_SLOT, OnOff
  52. switchcmd = ON_OFF_SLOT[OnOff]
  53. domo_idx = ROOM2POWER_DOMO_IDX[room]
  54. log.info('domoticz: device %s switch: %s' % (domo_idx, switchcmd))
  55. domo_command(param='switchlight', idx=domo_idx, switchcmd=switchcmd)
  56. delta_last = time.time() - STATE.last_switches[room]
  57. STATE.last_switches[room] = time.time()
  58. if delta_last < 30:
  59. return statement('')
  60. else:
  61. if choice(range(10)) == 0:
  62. return statement('Ich habe das Licht im %s %sgeschaltet.' % (room, OnOff))
  63. else:
  64. return statement('OK')