pymscada 0.2.6b1__tar.gz → 0.2.6b3__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.

Potentially problematic release.


This version of pymscada might be problematic. Click here for more details.

Files changed (105) hide show
  1. {pymscada-0.2.6b1/src/pymscada.egg-info → pymscada-0.2.6b3}/PKG-INFO +1 -1
  2. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/pyproject.toml +1 -1
  3. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/bus_client.py +11 -2
  4. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/bus_server.py +6 -2
  5. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/opnotes.py +1 -1
  6. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/www_server.py +1 -0
  7. {pymscada-0.2.6b1 → pymscada-0.2.6b3/src/pymscada.egg-info}/PKG-INFO +1 -1
  8. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/LICENSE +0 -0
  9. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/MANIFEST.in +0 -0
  10. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/README.md +0 -0
  11. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/setup.cfg +0 -0
  12. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/__init__.py +0 -0
  13. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/__main__.py +0 -0
  14. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/alarms.py +0 -0
  15. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/callout.py +0 -0
  16. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/checkout.py +0 -0
  17. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/config.py +0 -0
  18. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/console.py +0 -0
  19. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/README.md +0 -0
  20. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/__init__.py +0 -0
  21. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/__pycache__/__init__.cpython-311.pyc +0 -0
  22. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/accuweather.yaml +0 -0
  23. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/alarms.yaml +0 -0
  24. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/bus.yaml +0 -0
  25. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/callout.yaml +0 -0
  26. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/files.yaml +0 -0
  27. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/history.yaml +0 -0
  28. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/logixclient.yaml +0 -0
  29. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/modbus_plc.py +0 -0
  30. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/modbusclient.yaml +0 -0
  31. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/modbusserver.yaml +0 -0
  32. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/openweather.yaml +0 -0
  33. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/opnotes.yaml +0 -0
  34. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/piapi.yaml +0 -0
  35. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/ping.yaml +0 -0
  36. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-alarms.service +0 -0
  37. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-bus.service +0 -0
  38. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-callout.service +0 -0
  39. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-demo-modbus_plc.service +0 -0
  40. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-files.service +0 -0
  41. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-history.service +0 -0
  42. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-logixclient.service +0 -0
  43. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-modbusclient.service +0 -0
  44. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-modbusserver.service +0 -0
  45. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-openweather.service +0 -0
  46. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-piapi.service +0 -0
  47. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-ping.service +0 -0
  48. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-sms.service +0 -0
  49. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-snmpclient.service +0 -0
  50. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-io-witsapi.service +0 -0
  51. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-opnotes.service +0 -0
  52. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/pymscada-wwwserver.service +0 -0
  53. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/sms.yaml +0 -0
  54. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/snmpclient.yaml +0 -0
  55. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/tags.yaml +0 -0
  56. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/witsapi.yaml +0 -0
  57. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/demo/wwwserver.yaml +0 -0
  58. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/files.py +0 -0
  59. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/history.py +0 -0
  60. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/__init__.py +0 -0
  61. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/accuweather.py +0 -0
  62. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/logix_client.py +0 -0
  63. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/logix_map.py +0 -0
  64. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/modbus_client.py +0 -0
  65. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/modbus_map.py +0 -0
  66. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/modbus_server.py +0 -0
  67. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/openweather.py +0 -0
  68. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/piapi.py +0 -0
  69. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/ping_client.py +0 -0
  70. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/ping_map.py +0 -0
  71. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/sms.py +0 -0
  72. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/snmp_client.py +0 -0
  73. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/snmp_map.py +0 -0
  74. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/witsapi.py +0 -0
  75. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/iodrivers/witsapi_POC.py +0 -0
  76. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/main.py +0 -0
  77. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/misc.py +0 -0
  78. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/module_config.py +0 -0
  79. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/pdf/__init__.py +0 -0
  80. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/pdf/__pycache__/__init__.cpython-311.pyc +0 -0
  81. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/pdf/one.pdf +0 -0
  82. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/pdf/two.pdf +0 -0
  83. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/periodic.py +0 -0
  84. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/protocol_constants.py +0 -0
  85. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/samplers.py +0 -0
  86. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/tag.py +0 -0
  87. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/tools/get_history.py +0 -0
  88. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/tools/snmp_client2.py +0 -0
  89. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada/tools/walk.py +0 -0
  90. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada.egg-info/SOURCES.txt +0 -0
  91. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada.egg-info/dependency_links.txt +0 -0
  92. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada.egg-info/entry_points.txt +0 -0
  93. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada.egg-info/requires.txt +0 -0
  94. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/src/pymscada.egg-info/top_level.txt +0 -0
  95. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_alarms.py +0 -0
  96. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_bus_server.py +0 -0
  97. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_callout.py +0 -0
  98. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_config.py +0 -0
  99. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_history.py +0 -0
  100. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_misc.py +0 -0
  101. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_opnotes.py +0 -0
  102. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_periodic.py +0 -0
  103. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_samplers.py +0 -0
  104. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_sms.py +0 -0
  105. {pymscada-0.2.6b1 → pymscada-0.2.6b3}/tests/test_tag.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: pymscada
3
- Version: 0.2.6b1
3
+ Version: 0.2.6b3
4
4
  Summary: Shared tag value SCADA with python backup and Angular UI
5
5
  Author-email: Jamie Walton <jamie@walton.net.nz>
6
6
  License: GPL-3.0-or-later
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "pymscada"
3
- version = "0.2.6b1"
3
+ version = "0.2.6b3"
4
4
  description = "Shared tag value SCADA with python backup and Angular UI"
5
5
  authors = [
6
6
  {name = "Jamie Walton", email = "jamie@walton.net.nz"},
@@ -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 tag_id {tag_id}')
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('Attribute Error, TO DO, fix in test')
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."""
@@ -111,7 +111,8 @@ class BusConnection():
111
111
  head = await self.reader.readexactly(14)
112
112
  _, cmd, tag_id, size, time_us = unpack('!BBHHQ', head)
113
113
  except (ConnectionResetError, asyncio.IncompleteReadError,
114
- asyncio.CancelledError):
114
+ asyncio.CancelledError) as e:
115
+ logging.warning(f'{self.addr} read error: {e}')
115
116
  break
116
117
  # if the command packet indicates data, get that too
117
118
  if size == 0:
@@ -121,7 +122,8 @@ class BusConnection():
121
122
  payload = await self.reader.readexactly(size)
122
123
  data = unpack(f'!{size}s', payload)[0]
123
124
  except (ConnectionResetError, asyncio.IncompleteReadError,
124
- asyncio.CancelledError):
125
+ asyncio.CancelledError) as e:
126
+ logging.warning(f'{self.addr} read payload error: {e}')
125
127
  break
126
128
  # if MAX_LEN then a continuation packet is required
127
129
  if size == pc.MAX_LEN:
@@ -294,6 +296,8 @@ class BusServer:
294
296
  def read_callback(self, command):
295
297
  """Process read messages, delete broken connections."""
296
298
  bus_id, cmd, tag_id, time_us, data = command
299
+ logging.info(f'recv cmd={cmd} tag_id={tag_id} bus_id={bus_id} '
300
+ f'size={(0 if data is None else len(data))}')
297
301
  if cmd is None:
298
302
  # Clean up tag subscriptions before deleting it
299
303
  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}')
@@ -132,6 +132,7 @@ class WSHandler():
132
132
  elif tag.type is bytes:
133
133
  rta_id = unpack_from('>H', tag.value)[0]
134
134
  if rta_id in [0, self.rta_id]:
135
+ logging.info(f'{self.rta_id}: {tag.name} bytes matches id')
135
136
  self.queue.put_nowait((True, pack(
136
137
  f'!HHQ{len(tag.value)}s', # Network big-endian
137
138
  tag.id, # Uint16
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: pymscada
3
- Version: 0.2.6b1
3
+ Version: 0.2.6b3
4
4
  Summary: Shared tag value SCADA with python backup and Angular UI
5
5
  Author-email: Jamie Walton <jamie@walton.net.nz>
6
6
  License: GPL-3.0-or-later
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes