qolsys-controller 0.0.45__py3-none-any.whl → 0.0.48__py3-none-any.whl

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 qolsys-controller might be problematic. Click here for more details.

@@ -92,6 +92,7 @@ class QolsysTable:
92
92
 
93
93
  col_str = ", ".join(full_data.keys())
94
94
  placeholder_str = ", ".join([f":{key}" for key in full_data])
95
+
95
96
  query = f"INSERT OR IGNORE INTO {self.table} ({col_str}) VALUES ({placeholder_str})"
96
97
  self._cursor.execute(query, full_data)
97
98
  self._db.commit()
@@ -112,9 +113,14 @@ class QolsysTable:
112
113
  # selection_argument:
113
114
  # Firmware 4.4.1: selection_argument: '[3,1]'
114
115
  # Firmware 4.6.1: selection_argument: ['3','1']
115
-
116
116
  # contentValues:{"partition_id":"0","sensorgroup":"safetymotion","sensorstatus":"Idle"}"
117
117
 
118
+ if selection_argument == "":
119
+ LOGGER.debug("Update called with empty selection_argument")
120
+ LOGGER.debug("Table: %s", self.table)
121
+ LOGGER.debug("Selection: %s", selection)
122
+ LOGGER.debug("selection_argument: %s", selection_argument)
123
+ return
118
124
 
119
125
  # Selection Argument
120
126
  # Panel send selection_argument as list in Firmware 4.6.1
@@ -164,6 +170,14 @@ class QolsysTable:
164
170
  # Firmware 4.4.1: selection_argument: '[3,1]'
165
171
  # Firmware 4.6.1: selection_argument: ['3','1']
166
172
 
173
+
174
+ if selection_argument == "":
175
+ LOGGER.debug("Delete called with empty selection_argument")
176
+ LOGGER.debug("Table: %s", self.table)
177
+ LOGGER.debug("Selection: %s", selection)
178
+ LOGGER.debug("selection_argument: %s", selection_argument)
179
+ return
180
+
167
181
  # Selection Argument
168
182
  if(type(selection_argument) is not list):
169
183
  #Firmware 4.4.1, seletion_argument is sent as a string
@@ -369,9 +369,13 @@ class QolsysPanel(QolsysObservable):
369
369
  match dbOperation:
370
370
 
371
371
  case "update":
372
- content_values = data.get("contentValues")
373
- selection = data.get("selection")
374
- selection_argument = data.get("selectionArgs")
372
+ content_values = data.get("contentValues","")
373
+ selection = data.get("selection","")
374
+ selection_argument = data.get("selectionArgs","")
375
+
376
+ if selection_argument == "" or selection == "":
377
+ LOGGER.debug("iq2meid invalid update selection or selectionArgs")
378
+ LOGGER.debug("data:%s", data)
375
379
 
376
380
  match uri:
377
381
 
@@ -535,8 +539,12 @@ class QolsysPanel(QolsysObservable):
535
539
  LOGGER.debug(data)
536
540
 
537
541
  case "delete":
538
- selection = data.get("selection")
539
- selection_argument = data.get("selectionArgs")
542
+ selection = data.get("selection","")
543
+ selection_argument = data.get("selectionArgs","")
544
+
545
+ if selection_argument == "" or selection == "":
546
+ LOGGER.debug("iq2meid invalid delete selection or selectionArgs")
547
+ LOGGER.debug("data:%s", data)
540
548
 
541
549
  match uri:
542
550
 
@@ -635,7 +643,7 @@ class QolsysPanel(QolsysObservable):
635
643
  partition.alarm_state = PartitionAlarmState(new_value)
636
644
 
637
645
  # Inser Partition Content Provider
638
- case self.db.table_partition:
646
+ case self.db.table_partition.uri:
639
647
  self.db.table_partition.insert(data=content_values)
640
648
  self._state.sync_partitions_data(self.get_partitions_from_db())
641
649
 
@@ -44,7 +44,7 @@ class QolsysPartition(QolsysObservable):
44
44
  self._command_arm_entry_delay = True
45
45
 
46
46
  @property
47
- def id(self) -> int:
47
+ def id(self) -> str:
48
48
  return self._id
49
49
 
50
50
  @property
@@ -68,7 +68,6 @@ class QolsysSettings:
68
68
  @property
69
69
  def motion_sensor_delay(self) -> bool:
70
70
  return self._motion_sensor_delay
71
-
72
71
  @property
73
72
  def motion_sensor_delay_sec(self) -> int:
74
73
  return self._motion_sensor_delay_sec
@@ -77,6 +76,10 @@ class QolsysSettings:
77
76
  def motion_sensor_delay(self, value: bool) -> None:
78
77
  self._motion_sensor_delay = value
79
78
 
79
+ @motion_sensor_delay_sec.setter
80
+ def motion_sensor_delay_sec(self, value: int) -> None:
81
+ self._motion_sensor_delay_sec = value
82
+
80
83
  @panel_ip.setter
81
84
  def panel_ip(self, panel_ip: str) -> None:
82
85
  self._panel_ip = panel_ip
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: qolsys-controller
3
- Version: 0.0.45
3
+ Version: 0.0.48
4
4
  Summary: A Python module that emulates a virtual IQ Remote device, enabling full local control of a Qolsys IQ Panel
5
5
  Project-URL: Homepage, https://github.com/EHylands/QolsysController
6
6
  Project-URL: Issues, https://github.com/EHylands/QolsysController/issues
@@ -6,14 +6,14 @@ qolsys_controller/errors.py,sha256=Z_eVJ4XqWucdn1lu_83DPnEKEG4L3FMfjhz5iO6RuBM,1
6
6
  qolsys_controller/mdns.py,sha256=3_d-_K5Fyxc-2s0Fo1advTSpD72P369Hou1Ko0z__Ag,606
7
7
  qolsys_controller/mqtt_command_queue.py,sha256=FjSbjK3_3SXV5eQPfQ-k8HOI5Tbu2aWzAxe4uXymK64,937
8
8
  qolsys_controller/observable.py,sha256=X7uMnBHGpklPTa-RHKldXA0Rq38Cs1yOIuxl8ODeKV4,1049
9
- qolsys_controller/panel.py,sha256=sQlSrnm6s2GR-sD_xNmMcogDLwdc9zIOa1LtqdzN-zk,42942
10
- qolsys_controller/partition.py,sha256=ZRSWDqXE1aPlTvxwSbvp28OyOXgTYOUH73zOtZFHIIo,8943
9
+ qolsys_controller/panel.py,sha256=hHQgrpu5ruhTrC0OFhDB32k1miMpDpShCTNrgCJSX9w,43411
10
+ qolsys_controller/partition.py,sha256=zJGPN1KYpEHiWJOL7AZ7gF5N-Y7rD98_-mRLSSOMkq4,8943
11
11
  qolsys_controller/pki.py,sha256=_e0tiNF8Hypb37cHr7x8yqUZDaqbzRzP45AitTtmzk4,8663
12
12
  qolsys_controller/plugin.py,sha256=Qh0irFbuw9R2QF3jOFTJw70ceVxK1ld5_sW7VnpOrA8,819
13
13
  qolsys_controller/plugin_c4.py,sha256=71o5Y7Y13GO0vWCPIsCtpqXxrplryyqt8ua5L8F4StQ,382
14
14
  qolsys_controller/plugin_remote.py,sha256=D2lTjF8UYR5SkK681-5wLQs89S83UmQ3nJCTcpU15dw,49627
15
15
  qolsys_controller/scene.py,sha256=b_8pzAJ08L7Nc-vouzkDxZKkcDQ239pLnvSDnN4g_oQ,1899
16
- qolsys_controller/settings.py,sha256=Drv2Vg84h8ZVWzOIex9xs96AZmWZkBT7cM4yvPJB4zc,6113
16
+ qolsys_controller/settings.py,sha256=voIC4DOjzEyOKDfD6VqGVgA6s5wi3ftZcBVq5F5A9sA,6254
17
17
  qolsys_controller/state.py,sha256=QMGgHdrDf0xHFoUTD6BWa7o2OWxAGvYDp95EYDLlpGc,17665
18
18
  qolsys_controller/task_manager.py,sha256=8TT1KhNHVjMIXTQz_vdUJ3eHgsKsUdPX3SHd29MP4pI,1629
19
19
  qolsys_controller/utils_mqtt.py,sha256=2hf9_BnQbsWi8t0KBiK5MSsDgGjlbWVJi-Sd3H5VVt0,575
@@ -26,7 +26,7 @@ qolsys_controller/zwave_lock.py,sha256=nodvZyjVurP5Eezjam4yRoFSfgnqlDM0e0MyXUqTp
26
26
  qolsys_controller/zwave_outlet.py,sha256=lxGB-jth11dHPUkT7jC411GdLCGDdct4mAGu05SndCA,185
27
27
  qolsys_controller/zwave_thermostat.py,sha256=IVe6F16aTt3v7ibC0C5X77jzmZOgNWNtfElMwVC3VXU,14610
28
28
  qolsys_controller/database/db.py,sha256=YsuhIeHxobe5OSXwdklwjBYpUCynEx6Zuj9SzIi0YNo,15161
29
- qolsys_controller/database/table.py,sha256=eIbHt1UvcNxVje2w3g_YMnQGIY85_nOtkOMxUlVtSVI,6451
29
+ qolsys_controller/database/table.py,sha256=lbyGQgu2-43hciOWq5zBwS4p_iuF5yZih3SRrqfQYxI,7057
30
30
  qolsys_controller/database/table_alarmedsensor.py,sha256=BZ6K9CQbcXRw0rf6WODS0NFf1wptu5CxuRtsLQrCsSQ,808
31
31
  qolsys_controller/database/table_automation.py,sha256=1qCdSIX2ALSdGxkZdMbHWT43VjqX4WgmNed4HcC7wc8,1287
32
32
  qolsys_controller/database/table_country_locale.py,sha256=OkjqGhYhYaGptZGN74eJI-dkRYSv_Cpex_zCs93v1Wo,1013
@@ -62,7 +62,7 @@ qolsys_controller/database/table_zwave_association_group.py,sha256=B8SHPU335a2wh
62
62
  qolsys_controller/database/table_zwave_history.py,sha256=iLCkRZOsQmc5TQT0-IngyNkrG78kQrEhITPChmNt1bM,942
63
63
  qolsys_controller/database/table_zwave_node.py,sha256=bbL0WOH1kY8kdyfRUj2ZuOo0TNRXzX5i6CDtj4kb6YI,2609
64
64
  qolsys_controller/database/table_zwave_other.py,sha256=VlGO5VOTRQtq7NqquH_NryswxB_pwG3KoKjvrz2xGao,915
65
- qolsys_controller-0.0.45.dist-info/METADATA,sha256=VzMOSo9NQBowUG4Vm3r8xW8r12cVgA2RdkgPPfz6MTA,4329
66
- qolsys_controller-0.0.45.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
67
- qolsys_controller-0.0.45.dist-info/licenses/LICENSE,sha256=GBHv9eggdA5ablDMW1xiLzGDZ2gCIhcKGW__c2aVIOc,1069
68
- qolsys_controller-0.0.45.dist-info/RECORD,,
65
+ qolsys_controller-0.0.48.dist-info/METADATA,sha256=o0PEGBFx4T3QoqVTRGQRTMO2BsvSFQ61v70edvXfDQY,4329
66
+ qolsys_controller-0.0.48.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
67
+ qolsys_controller-0.0.48.dist-info/licenses/LICENSE,sha256=GBHv9eggdA5ablDMW1xiLzGDZ2gCIhcKGW__c2aVIOc,1069
68
+ qolsys_controller-0.0.48.dist-info/RECORD,,