forked from dpoulson/ginlong-mqtt
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathginlong-listen.py
executable file
·173 lines (145 loc) · 6.73 KB
/
ginlong-listen.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
#!/usr/bin/env python
#===============================================================================
# Copyright (C) 2017 Darren Poulson
#
# This file is part of ginlong-mqtt.
#
# R2_Control is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# R2_Control is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with ginlong-mqtt. If not, see <http://www.gnu.org/licenses/>.
#===============================================================================
import paho.mqtt.publish as publish
import socket
import binascii
import time
import sys
import string
import ConfigParser
import io
with open("config.ini") as f:
sample_config = f.read()
config = ConfigParser.RawConfigParser(allow_no_value=True)
config.readfp(io.BytesIO(sample_config))
###########################
# Variables
listen_address = config.get('DEFAULT', 'listen_address') # What address to listen to (0.0.0.0 means it will listen on all addresses)
listen_port = int(config.get('DEFAULT', 'listen_port')) # Port to listen on
client_id = config.get('MQTT', 'client_id') # MQTT Client ID
mqtt_server = config.get('MQTT', 'mqtt_server') # MQTT Address
mqtt_port = int(config.get('MQTT', 'mqtt_port')) # MQTT Port
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
sock.bind((listen_address, listen_port))
sock.listen(1)
while True:
# Wait for a connection
if __debug__:
print 'waiting for a connection'
conn,addr = sock.accept()
try:
#print >>sys.stderr, 'connection from', addr
# while True:
rawdata = conn.recv(1000) # Read in a chunk of data
hexdata = binascii.hexlify(rawdata) # Convert to hex for easier processing
if(len(hexdata) == 270):
timestamp = (time.strftime("%F %H:%M")) # get date time
msgs = []
serial = binascii.unhexlify(str(hexdata[70:102])) # Serial number is used for MQTT path, allowing multiple inverters to connect to a single instance
if __debug__:
print 'Hex data: %s' % hexdata
print "Serial %s" % serial
print "Length %s" % len(hexdata)
mqtt_topic = ''.join([client_id, "/", serial, "/"]) # Create the topic base using the client_id and serial number
if __debug__:
print >>sys.stderr, 'MQTT Topic: ', mqtt_topic
##### Vpv1
vpv1 = float(int(hexdata[108:112],16))/10
if __debug__:
print >>sys.stderr, 'vpv1: ', vpv1
msgs.append((mqtt_topic + "Vpv1", vpv1, 0, False))
##### Vpv2
#vpv2 = float(int(hexdata[108:112],16))/10
#if __debug__:
# print >>sys.stderr, 'vpv2: ', vpv2
#msgs.append((mqtt_topic + "Vpv2", vpv2, 0, False))
##### Ipv1
ipv1 = float(int(hexdata[112:116],16))/10
if __debug__:
print >>sys.stderr, 'ipv1: ', ipv1
msgs.append((mqtt_topic + "Ipv1", ipv1, 0, False))
##### Ipv2
#ipv2 = float(int(hexdata[116:120],16))/10
#if __debug__:
# print >>sys.stderr, 'ipv2: ', ipv2
#msgs.append((mqtt_topic + "Ipv2", ipv2, 0, False))
##### Vac1
vac1 = float(int(hexdata[144:148],16))/10
if __debug__:
print >>sys.stderr, 'vac1: ', vac1
msgs.append((mqtt_topic + "Vac1", vac1, 0, False))
##### Vac2
#vac2 = float(int(hexdata[106:109],16))/10
#if __debug__:
# print >>sys.stderr, 'vac2: ', vac2
#msgs.append((mqtt_topic + "Vac2", vac2, 0, False))
##### Vac3
#vac3 = float(int(hexdata[110:113],16))/10
#if __debug__:
# print >>sys.stderr, 'vac3: ', vac3
#msgs.append((mqtt_topic + "Vac3", vac3, 0, False))
##### Iac1
iac1 = float(int(hexdata[120:124],16))/10
if __debug__:
print >>sys.stderr, 'iac1: ', iac1
msgs.append((mqtt_topic + "Iac1", iac1, 0, False))
##### Iac2
#iac2 = float(int(hexdata[124:128],16))/10
#if __debug__:
# print >>sys.stderr, 'iac2: ', iac2
#msgs.append((mqtt_topic + "Iac2", iac2, 0, False))
##### Iac3
#iac3 = float(int(hexdata[128:132],16))/10
#if __debug__:
# print >>sys.stderr, 'iac3: ', iac3
#msgs.append((mqtt_topic + "Iac3", iac3, 0, False))
##### Pac
pac = float(int(hexdata[140:144],16))/10
if __debug__:
print >>sys.stderr, 'pac: ', pac
msgs.append((mqtt_topic + "Pac", pac, 0, False))
##### Fac
fac = float(int(hexdata[148:152],16))/100
if __debug__:
print >>sys.stderr, 'fac: ', fac
msgs.append((mqtt_topic + "Fac", fac, 0, False))
##### Temp
temp = float(int(hexdata[102:104],16))/10
if __debug__:
print >>sys.stderr, 'temp: ', temp
msgs.append((mqtt_topic + "Temp", temp, 0, False))
##### kWh today
kwhtoday = float(int(hexdata[156:160],16))/100
if __debug__:
print >>sys.stderr, 'kwhtoday: ', kwhtoday
msgs.append((mqtt_topic + "kwhtoday", kwhtoday, 0, False))
##### kWh total
kwhtotal = float(int(hexdata[164:168],16))/10
if __debug__:
print >>sys.stderr, 'kwhtotal: ', kwhtotal
msgs.append((mqtt_topic + "kwhtotal", kwhtotal, 0, False))
publish.multiple(msgs, hostname=mqtt_server)
file = open("rawlog",'a')
file.write(timestamp + ' ' + hexdata + '\n')
file.close()
finally:
if __debug__:
print "Finally"