150 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python3 
 | |
| 
 | |
| from __future__ import absolute_import, print_function
 | |
| 
 | |
| import sys
 | |
| import argparse
 | |
| import socket
 | |
| from datetime import datetime
 | |
| 
 | |
| import can
 | |
| from can import Bus, BusState, Logger
 | |
| 
 | |
| import paho.mqtt.client as mqtt
 | |
| 
 | |
| sub_topic = "shutter"
 | |
| aliases = { 
 | |
|   'Esszimmer_Garten': 'EZ_G',
 | |
|   'Esszimmer_Nachbar': 'EZ_N',
 | |
|   'Wohnzimmer1': 'WZ1',
 | |
|   'Wohnzimmer2': 'WZ2',
 | |
|   'Wohnzimmer3': 'WZ3',
 | |
|   'Wohnzimmer4': 'WZ4',
 | |
| }
 | |
| event_map = {
 | |
|   'stop': 0,
 | |
|   'off': 0,
 | |
|   'up': 1,
 | |
|   'down': 2
 | |
| }
 | |
| coil_map = {
 | |
|   # up , down
 | |
|   'EZ_G':  [ 0x03, 0x04 , 0x03, 0x05 ],
 | |
|   'EZ_N':  [ 0x03, 0x08 , 0x03, 0x06 ],
 | |
|   'WZ1': [ 0x00, 0x01 , 0x00, 0x01 ],
 | |
|   'WZ2': [ 0x00, 0x01 , 0x00, 0x01 ],
 | |
|   'WZ3': [ 0x00, 0x01 , 0x00, 0x01 ],
 | |
|   'WZ4': [ 0x00, 0x01 , 0x00, 0x01 ]
 | |
| }
 | |
| cmd_map = {
 | |
|   'off': 0,
 | |
|   'on': 1,
 | |
|   'value': 2,
 | |
|   'toggle': 3
 | |
| }
 | |
|   
 | |
| 
 | |
| def decon(msg_id):
 | |
|    msg_prio=msg_id>>26
 | |
|    msg_type=(msg_id>>24) & 0x03
 | |
|    msg_dst=(msg_id>>16) & 0xFF
 | |
|    msg_src=(msg_id>>8) & 0xFF
 | |
|    msg_cmd=msg_id & 0xFF
 | |
|    print("msg_id: ", hex(msg_id), "prio: ", hex(msg_prio),"type: ", hex(msg_type)," dst: ", hex(msg_dst)," src: ", hex(msg_src)," cmd: ",hex(msg_cmd))
 | |
|    return [msg_prio, msg_type, msg_dst, msg_src, msg_cmd]
 | |
| 
 | |
| def con(msg_dst,msg_cmd,msg_prio=3,msg_type=0,msg_src=11, ):
 | |
|    msg_id=(msg_prio<<26) + \
 | |
|    ((msg_type&0x03)<<24) +\
 | |
|    ((msg_dst&0xFF)<<16) +\
 | |
|    ((msg_src&0xFF)<<8) +\
 | |
|    (msg_cmd&0xFF)
 | |
|    print("Constructed ID: "+hex(msg_id))
 | |
|    return msg_id
 | |
| 
 | |
| def on_connect(mcp_mqtt, userdata, flags, rc):
 | |
|     print("Connected with result code "+str(rc))
 | |
| 
 | |
|     # Subscribing in on_connect() means that if we lose the connection and
 | |
|     # reconnect then subscriptions will be renewed.
 | |
|     mcp_mqtt.subscribe(sub_topic+"/+")
 | |
|     print("Subscribed to:"+sub_topic+"/+")
 | |
| 
 | |
| def on_message(mcp_mqtt, userdata, msg):
 | |
|     local_bus=userdata
 | |
|     print("data Received topic: ", msg.topic)
 | |
|     m_decode=str(msg.payload.decode("utf-8","ignore"))
 | |
|     print("data Received",m_decode)
 | |
|     data=m_decode
 | |
|     sub=msg.topic[len(sub_topic)+1:]
 | |
|     event=event_map[data]
 | |
|     coils={
 | |
|       'up': [ coil_map[sub][0], coil_map[sub][1] ],
 | |
|       'down': [ coil_map[sub][2], coil_map[sub][3] ]
 | |
|     }
 | |
|     if event is not None: # it's 0,1,2
 | |
|       for key, value in coils.items():
 | |
|         msg_id=con(msg_dst=value[0],msg_cmd=0)
 | |
|         msg_data=[value[1]]
 | |
|         print("turning off: ",sub,value[0],value[1])
 | |
|         m = can.Message(arbitration_id=msg_id,
 | |
|             data=msg_data,
 | |
|             extended_id=True)
 | |
|         print("going to sent to CAN",m)
 | |
|         try:
 | |
|           local_bus.send(m)
 | |
|         except BaseException as e:
 | |
|           logging.error("Error sending can message {%s}: %s" % (m, e))
 | |
|         print("data sent to CAN",m)
 | |
|       if event is not 0:
 | |
|         addr = coils[data]
 | |
|         print("turning on: ",addr[0],addr[1])
 | |
|         msg_id=con(msg_dst=addr[0],msg_cmd=1)
 | |
|         msg_data=[addr[1]]
 | |
|         print(msg_data)
 | |
|         m = can.Message(arbitration_id=msg_id,
 | |
|             data=msg_data,
 | |
|             extended_id=True)
 | |
|         print("going to sent to CAN",m)
 | |
|   
 | |
|         try:
 | |
|             local_bus.send(m)
 | |
|         except BaseException as e:
 | |
|             logging.error("Error sending can message {%s}: %s" % (m, e))
 | |
|         print("data sent to CAN",m)
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| def main():
 | |
|     verbosity = 2
 | |
| 
 | |
|     logging_level_name = ['critical', 'error', 'warning', 'info', 'debug', 'subdebug'][min(5, verbosity)]
 | |
|     can.set_logging_level(logging_level_name)
 | |
| 
 | |
|     can_filters = []
 | |
|     config = {"can_filters": can_filters, "single_handle": True}
 | |
|     config["interface"] = "socketcan"
 | |
|     config["bitrate"] = 125000
 | |
|     bus = Bus("can1", **config)
 | |
| 
 | |
|     print('Connected to {}: {}'.format(bus.__class__.__name__, bus.channel_info))
 | |
|     print('Can Logger (Started on {})\n'.format(datetime.now()))
 | |
| 
 | |
|     mcp_mqtt = mqtt.Client()
 | |
|     mcp_mqtt.on_connect = on_connect
 | |
|     mcp_mqtt.on_message = on_message
 | |
|     mcp_mqtt.user_data_set(bus)
 | |
|     mcp_mqtt.connect("mcp", 1883, 60)
 | |
| 
 | |
|     try:
 | |
|       while True:
 | |
|         mcp_mqtt.loop()
 | |
|     except KeyboardInterrupt:
 | |
|         pass
 | |
|     finally:
 | |
|         bus.shutdown()
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     main()
 |