pymscada 0.2.6b1__tar.gz → 0.2.6b2__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {pymscada-0.2.6b1/src/pymscada.egg-info → pymscada-0.2.6b2}/PKG-INFO +1 -1
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/pyproject.toml +1 -1
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/bus_client.py +11 -2
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/bus_server.py +2 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/opnotes.py +1 -1
- {pymscada-0.2.6b1 → pymscada-0.2.6b2/src/pymscada.egg-info}/PKG-INFO +1 -1
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/LICENSE +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/MANIFEST.in +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/README.md +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/setup.cfg +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/__init__.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/__main__.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/alarms.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/callout.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/checkout.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/config.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/console.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/README.md +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/__init__.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/__pycache__/__init__.cpython-311.pyc +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/accuweather.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/alarms.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/bus.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/callout.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/files.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/history.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/logixclient.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/modbus_plc.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/modbusclient.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/modbusserver.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/openweather.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/opnotes.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/piapi.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/ping.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-alarms.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-bus.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-callout.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-demo-modbus_plc.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-files.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-history.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-logixclient.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-modbusclient.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-modbusserver.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-openweather.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-piapi.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-ping.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-sms.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-snmpclient.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-io-witsapi.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-opnotes.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/pymscada-wwwserver.service +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/sms.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/snmpclient.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/tags.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/witsapi.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/wwwserver.yaml +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/files.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/history.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/__init__.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/accuweather.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/logix_client.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/logix_map.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/modbus_client.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/modbus_map.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/modbus_server.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/openweather.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/piapi.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/ping_client.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/ping_map.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/sms.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/snmp_client.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/snmp_map.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/witsapi.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/iodrivers/witsapi_POC.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/main.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/misc.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/module_config.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/pdf/__init__.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/pdf/__pycache__/__init__.cpython-311.pyc +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/pdf/one.pdf +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/pdf/two.pdf +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/periodic.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/protocol_constants.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/samplers.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/tag.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/tools/get_history.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/tools/snmp_client2.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/tools/walk.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/www_server.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada.egg-info/SOURCES.txt +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada.egg-info/dependency_links.txt +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada.egg-info/entry_points.txt +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada.egg-info/requires.txt +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada.egg-info/top_level.txt +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_alarms.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_bus_server.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_callout.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_config.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_history.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_misc.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_opnotes.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_periodic.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_samplers.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_sms.py +0 -0
- {pymscada-0.2.6b1 → pymscada-0.2.6b2}/tests/test_tag.py +0 -0
|
@@ -79,7 +79,8 @@ class BusClient:
|
|
|
79
79
|
data = struct.pack(f'>B{size}s', pc.TYPE.JSON, jsonstr)
|
|
80
80
|
action = request.get("action", "unknown")
|
|
81
81
|
tag_id = self.tag_by_name[tagname].id
|
|
82
|
-
logging.info(f'{self.module}: RTA sending {tagname} {action} to
|
|
82
|
+
logging.info(f'{self.module}: RTA sending {tagname} {action} to'
|
|
83
|
+
f' tag_id {tag_id}')
|
|
83
84
|
self.write(pc.COMMAND.RTA, self.tag_by_name[tagname].id, time_us, data)
|
|
84
85
|
|
|
85
86
|
def write(self, command: pc.COMMAND, tag_id: int, time_us: int,
|
|
@@ -87,6 +88,12 @@ class BusClient:
|
|
|
87
88
|
"""Write a message."""
|
|
88
89
|
if data is None:
|
|
89
90
|
data = b''
|
|
91
|
+
try:
|
|
92
|
+
size_total = len(data)
|
|
93
|
+
except Exception:
|
|
94
|
+
size_total = 0
|
|
95
|
+
logging.info(f'{self.module}: write cmd={command} tag_id={tag_id} '
|
|
96
|
+
f'size_total={size_total}')
|
|
90
97
|
for i in range(0, len(data) + 1, pc.MAX_LEN):
|
|
91
98
|
snip = data[i:i+pc.MAX_LEN]
|
|
92
99
|
size = len(snip)
|
|
@@ -97,7 +104,9 @@ class BusClient:
|
|
|
97
104
|
except (asyncio.IncompleteReadError, ConnectionResetError):
|
|
98
105
|
self.read_task.cancel()
|
|
99
106
|
except AttributeError:
|
|
100
|
-
logging.warning('
|
|
107
|
+
logging.warning(f'{self.module}: write AttributeError '
|
|
108
|
+
f'cmd={command} '
|
|
109
|
+
f'tag_id={tag_id} size={size}')
|
|
101
110
|
|
|
102
111
|
def add_tag(self, tag: Tag):
|
|
103
112
|
"""Add the new tag and get the tag's bus ID."""
|
|
@@ -294,6 +294,8 @@ class BusServer:
|
|
|
294
294
|
def read_callback(self, command):
|
|
295
295
|
"""Process read messages, delete broken connections."""
|
|
296
296
|
bus_id, cmd, tag_id, time_us, data = command
|
|
297
|
+
logging.info(f'recv cmd={cmd} tag_id={tag_id} bus_id={bus_id} '
|
|
298
|
+
f'size={(0 if data is None else len(data))}')
|
|
297
299
|
if cmd is None:
|
|
298
300
|
# Clean up tag subscriptions before deleting it
|
|
299
301
|
for tag in BusTags._tag_by_id.values():
|
|
@@ -55,7 +55,6 @@ class OpNotes:
|
|
|
55
55
|
self.rta = Tag(rta_tag, dict)
|
|
56
56
|
self.rta.value = {'__rta_id__': 0}
|
|
57
57
|
self.busclient.add_callback_rta(rta_tag, self.rta_cb)
|
|
58
|
-
self.busclient.add_tag(self.rta)
|
|
59
58
|
|
|
60
59
|
def _init_table(self):
|
|
61
60
|
"""Initialize or upgrade the database table schema."""
|
|
@@ -105,6 +104,7 @@ class OpNotes:
|
|
|
105
104
|
"""Respond to Request to Author and publish on rta_tag as needed."""
|
|
106
105
|
local_time = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
|
|
107
106
|
logging.info(f'[{local_time}] RTA callback received: {request}')
|
|
107
|
+
logging.info(f'[{local_time}] DEBUG: rta_tag.id={self.rta.id}, rta_tag.name={self.rta.name}')
|
|
108
108
|
|
|
109
109
|
if 'action' not in request:
|
|
110
110
|
logging.warning(f'rta_cb malformed {request}')
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{pymscada-0.2.6b1 → pymscada-0.2.6b2}/src/pymscada/demo/__pycache__/__init__.cpython-311.pyc
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|