matterbridge-iotas 1.1.3 → 1.1.5

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.
package/CHANGELOG.md CHANGED
@@ -1,44 +1,53 @@
1
1
  # Changelog
2
2
 
3
- ## [1.1.3](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.0.2...v1.1.3) (2026-04-12)
3
+ ## [1.1.5](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.1.4...v1.1.5) (2026-04-13)
4
4
 
5
5
 
6
6
  ### Bug Fixes
7
7
 
8
- * :bug: Fix dimmer lights not showing ([#10](https://github.com/mezaugusto/matterbridge-iotas/issues/10)) ([ea56bd7](https://github.com/mezaugusto/matterbridge-iotas/commit/ea56bd7641edd71d119779ad5d32bd66eeb8eb5b))
8
+ * :bug: Register both moveToLevel AND moveToLevelWithOnOff handlers for… ([#15](https://github.com/mezaugusto/matterbridge-iotas/issues/15)) ([bf9fc17](https://github.com/mezaugusto/matterbridge-iotas/commit/bf9fc177d466a623b195881e4b08e7ffee2fdcc9))
9
+ * Update iotas-ts ([#17](https://github.com/mezaugusto/matterbridge-iotas/issues/17)) ([a76d0e9](https://github.com/mezaugusto/matterbridge-iotas/commit/a76d0e9f8c2b4d0c2e7f8c82dbb0d52591fa9fe0))
9
10
 
11
+ ## [1.1.4](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.1.3...v1.1.4) (2026-04-13)
10
12
 
11
- ### Miscellaneous Chores
12
13
 
13
- * release 1.1.3 ([#12](https://github.com/mezaugusto/matterbridge-iotas/issues/12)) Release-As: 1.1.3 ([6a15143](https://github.com/mezaugusto/matterbridge-iotas/commit/6a15143b05f92e5475dfa0e8ccf3b33c3a388dc1))
14
+ ### Bug Fixes
14
15
 
15
- ## [1.0.2](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.0.1...v1.0.2) (2026-04-12)
16
+ * :bug: Apply light value clamping through the app ([#13](https://github.com/mezaugusto/matterbridge-iotas/issues/13)) ([3fe8e60](https://github.com/mezaugusto/matterbridge-iotas/commit/3fe8e60e72959608f23e358e1c3d76d63313c047))
16
17
 
18
+ ## [1.1.3](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.0.2...v1.1.3) (2026-04-12)
17
19
 
18
20
  ### Bug Fixes
19
21
 
20
- * :bug: dimmable lights not showing ([#6](https://github.com/mezaugusto/matterbridge-iotas/issues/6)) ([d15f5a7](https://github.com/mezaugusto/matterbridge-iotas/commit/d15f5a7cf67fac017d75d9a623dc6c4c68423775))
22
+ - :bug: Fix dimmer lights not showing ([#10](https://github.com/mezaugusto/matterbridge-iotas/issues/10)) ([ea56bd7](https://github.com/mezaugusto/matterbridge-iotas/commit/ea56bd7641edd71d119779ad5d32bd66eeb8eb5b))
23
+
24
+ ### Miscellaneous Chores
25
+
26
+ - release 1.1.3 ([#12](https://github.com/mezaugusto/matterbridge-iotas/issues/12)) Release-As: 1.1.3 ([6a15143](https://github.com/mezaugusto/matterbridge-iotas/commit/6a15143b05f92e5475dfa0e8ccf3b33c3a388dc1))
21
27
 
22
28
  ## [1.0.2](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.0.1...v1.0.2) (2026-04-12)
23
29
 
30
+ ### Bug Fixes
31
+
32
+ - :bug: dimmable lights not showing ([#6](https://github.com/mezaugusto/matterbridge-iotas/issues/6)) ([d15f5a7](https://github.com/mezaugusto/matterbridge-iotas/commit/d15f5a7cf67fac017d75d9a623dc6c4c68423775))
33
+
34
+ ## [1.0.2](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.0.1...v1.0.2) (2026-04-12)
24
35
 
25
36
  ### Bug Fixes
26
37
 
27
- * :bug: dimmable lights not showing ([#6](https://github.com/mezaugusto/matterbridge-iotas/issues/6)) ([d15f5a7](https://github.com/mezaugusto/matterbridge-iotas/commit/d15f5a7cf67fac017d75d9a623dc6c4c68423775))
38
+ - :bug: dimmable lights not showing ([#6](https://github.com/mezaugusto/matterbridge-iotas/issues/6)) ([d15f5a7](https://github.com/mezaugusto/matterbridge-iotas/commit/d15f5a7cf67fac017d75d9a623dc6c4c68423775))
28
39
 
29
40
  ## [1.0.1](https://github.com/mezaugusto/matterbridge-iotas/compare/v1.0.0...v1.0.1) (2026-04-12)
30
41
 
31
-
32
42
  ### Bug Fixes
33
43
 
34
- * :bug: fix deadlock on feature update ([#4](https://github.com/mezaugusto/matterbridge-iotas/issues/4)) ([e38bb09](https://github.com/mezaugusto/matterbridge-iotas/commit/e38bb09c92281fb3c1057eaeb397eeaf25f52590))
44
+ - :bug: fix deadlock on feature update ([#4](https://github.com/mezaugusto/matterbridge-iotas/issues/4)) ([e38bb09](https://github.com/mezaugusto/matterbridge-iotas/commit/e38bb09c92281fb3c1057eaeb397eeaf25f52590))
35
45
 
36
46
  ## 1.0.0 (2026-04-12)
37
47
 
38
-
39
48
  ### Features
40
49
 
41
- * :sparkles: Use iotas v1 fire and forget for update ([#2](https://github.com/mezaugusto/matterbridge-iotas/issues/2)) ([f225ec6](https://github.com/mezaugusto/matterbridge-iotas/commit/f225ec66baa98f64e59e84e8afee9035aedb5aeb))
50
+ - :sparkles: Use iotas v1 fire and forget for update ([#2](https://github.com/mezaugusto/matterbridge-iotas/issues/2)) ([f225ec6](https://github.com/mezaugusto/matterbridge-iotas/commit/f225ec66baa98f64e59e84e8afee9035aedb5aeb))
42
51
 
43
52
  ## 0.1.0
44
53
 
@@ -2,6 +2,13 @@ import { dimmableLight, onOffLight } from 'matterbridge';
2
2
  import { LevelControl, OnOff } from 'matterbridge/matter/clusters';
3
3
  import { EventTypeName, findFeatureByEventType } from 'iotas-ts';
4
4
  import { addOnOffHandlers, bridgedNode, createBridgedEndpoint, createSimpleOnOffDevice, fromMatterLevel, multiFeatureResult, singleFeatureResult, toMatterLevel, } from './helpers.js';
5
+ // Matter LevelControl with Lighting feature constrains currentLevel to [minLevel, maxLevel].
6
+ // Defaults: minLevel=1, maxLevel=254. The on/off state is represented by the OnOff cluster.
7
+ const MATTER_MIN_LEVEL = 1;
8
+ const MATTER_MAX_LEVEL = 254;
9
+ function clampLevel(level) {
10
+ return Math.max(Math.min(level, MATTER_MAX_LEVEL), MATTER_MIN_LEVEL);
11
+ }
5
12
  function createStandardDimmableLight(device, ctx, onOffFeature, levelFeature, level) {
6
13
  const isOn = (onOffFeature.value ?? 0) === 1;
7
14
  const endpoint = createBridgedEndpoint([dimmableLight, bridgedNode], device, ctx)
@@ -9,17 +16,19 @@ function createStandardDimmableLight(device, ctx, onOffFeature, levelFeature, le
9
16
  .createDefaultLevelControlClusterServer(level)
10
17
  .addRequiredClusterServers();
11
18
  addOnOffHandlers(endpoint, onOffFeature.id, ctx);
12
- endpoint.addCommandHandler('moveToLevel', ({ request }) => {
19
+ const handleLevel = ({ request }) => {
13
20
  const matterLevel = request.level;
14
21
  const iotasLevel = fromMatterLevel(matterLevel);
15
22
  ctx.onFeatureUpdate(levelFeature.id, iotasLevel);
16
- endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', matterLevel);
17
- });
23
+ endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', clampLevel(matterLevel));
24
+ };
25
+ endpoint.addCommandHandler('moveToLevel', handleLevel);
26
+ endpoint.addCommandHandler('moveToLevelWithOnOff', handleLevel);
18
27
  return multiFeatureResult(endpoint, new Map([
19
28
  [onOffFeature.id, (value) => endpoint.setAttribute(OnOff.Cluster.id, 'onOff', value === 1)],
20
29
  [
21
30
  levelFeature.id,
22
- (value) => endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', toMatterLevel(value)),
31
+ (value) => endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', clampLevel(toMatterLevel(value))),
23
32
  ],
24
33
  ]));
25
34
  }
@@ -33,22 +42,24 @@ function createLevelOnlyDimmableLight(device, ctx, levelFeature, level) {
33
42
  endpoint.addCommandHandler('on', () => {
34
43
  ctx.onFeatureUpdate(levelFeature.id, 1);
35
44
  endpoint.setAttribute(OnOff.Cluster.id, 'onOff', true);
36
- endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', 254);
45
+ endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', MATTER_MAX_LEVEL);
37
46
  });
38
47
  endpoint.addCommandHandler('off', () => {
39
48
  ctx.onFeatureUpdate(levelFeature.id, 0);
40
49
  endpoint.setAttribute(OnOff.Cluster.id, 'onOff', false);
41
- endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', 0);
42
50
  });
43
- endpoint.addCommandHandler('moveToLevel', ({ request }) => {
51
+ const handleLevel = ({ request }) => {
44
52
  const matterLevel = request.level;
45
53
  const iotasLevel = fromMatterLevel(matterLevel);
46
54
  ctx.onFeatureUpdate(levelFeature.id, iotasLevel);
47
- endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', matterLevel);
55
+ // When level=0, currentLevel is clamped to 1 (minLevel) while onOff=false handles the off state
56
+ endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', clampLevel(matterLevel));
48
57
  endpoint.setAttribute(OnOff.Cluster.id, 'onOff', matterLevel > 0);
49
- });
58
+ };
59
+ endpoint.addCommandHandler('moveToLevel', handleLevel);
60
+ endpoint.addCommandHandler('moveToLevelWithOnOff', handleLevel);
50
61
  return singleFeatureResult(endpoint, levelFeature.id, (value) => {
51
- endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', toMatterLevel(value));
62
+ endpoint.setAttribute(LevelControl.Cluster.id, 'currentLevel', clampLevel(toMatterLevel(value)));
52
63
  endpoint.setAttribute(OnOff.Cluster.id, 'onOff', value > 0);
53
64
  });
54
65
  }
@@ -59,8 +70,7 @@ export function createDimmableLight(device, ctx) {
59
70
  ctx.log.warn(`Device ${device.name} missing Level feature for dimmable light`);
60
71
  return null;
61
72
  }
62
- // Matter LevelControl minLevel defaults to 1; clamp initial value to avoid constraint violation
63
- const level = Math.max(toMatterLevel(levelFeature.value ?? 0), 1);
73
+ const level = clampLevel(toMatterLevel(levelFeature.value ?? 0));
64
74
  if (onOffFeature) {
65
75
  return createStandardDimmableLight(device, ctx, onOffFeature, levelFeature, level);
66
76
  }
@@ -1 +1 @@
1
- {"version":3,"file":"lights.js","sourceRoot":"","sources":["../../../src/devices/lights.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"lights.js","sourceRoot":"","sources":["../../../src/devices/lights.ts"],"names":[],"mappings":"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"}
@@ -18,8 +18,6 @@ export class IotasPlatform extends MatterbridgeDynamicPlatform {
18
18
  this.iotasClient = IotasClient.withCredentials(log, config.username, config.password, config.unit);
19
19
  this.featureCache = new FeatureCache(log, this.iotasClient, {
20
20
  pollIntervalMs: this.pollingInterval * 1000,
21
- // Increased to 15s as lock takes ~10s to acquire in worst case, and we want to avoid unnecessary retries
22
- writeBarrierMs: 15_000,
23
21
  snapshotFilter: this.createSnapshotFilter(),
24
22
  });
25
23
  this.log.info('IOTAS platform initialized');
@@ -1 +1 @@
1
- {"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/module.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/module.ts"],"names":[],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { describe, it } from 'node:test';
2
2
  import assert from 'node:assert/strict';
3
3
  import { createDimmableLight, createOnOffLight } from '../../src/devices/lights.js';
4
- import { assertResult, makeCtx, makeDevice, makeFeature } from './helpers.js';
4
+ import { assertResult, makeCtx, makeDevice, makeFeature, suppressLogs } from './helpers.js';
5
5
  describe('lights', () => {
6
6
  const ctx = makeCtx();
7
7
  describe('createDimmableLight', () => {
@@ -26,6 +26,33 @@ describe('lights', () => {
26
26
  const result = assertResult(createDimmableLight(device, ctx));
27
27
  assert.deepEqual(result.featureIds, [11]);
28
28
  });
29
+ it('should clamp initial level to minimum 1 when device level is 0', () => {
30
+ const device = makeDevice({
31
+ name: 'Off Dimmer',
32
+ category: 'dimmer',
33
+ features: [makeFeature({ id: 11, eventTypeName: 'Level', value: 0 })],
34
+ });
35
+ // Should not throw — level=0 is clamped to 1 internally
36
+ const result = assertResult(createDimmableLight(device, ctx));
37
+ assert.deepEqual(result.featureIds, [11]);
38
+ });
39
+ it('should handle off command sending IOTAS level 0 in level-only mode', () => {
40
+ const updates = [];
41
+ const testCtx = makeCtx({
42
+ onFeatureUpdate: (featureId, value) => {
43
+ updates.push({ featureId, value });
44
+ },
45
+ });
46
+ const device = makeDevice({
47
+ name: 'Level Dimmer',
48
+ category: 'dimmer',
49
+ features: [makeFeature({ id: 11, eventTypeName: 'Level', value: 0.5 })],
50
+ });
51
+ const result = assertResult(createDimmableLight(device, testCtx));
52
+ // Trigger off via the poll update callback (simulates IOTAS returning level=0)
53
+ // This exercises the clampLevel path — should not throw on the constraint
54
+ suppressLogs(() => result.updateAttribute(11, 0));
55
+ });
29
56
  it('should return null when Level feature is missing', () => {
30
57
  const device = makeDevice({
31
58
  features: [makeFeature({ id: 10, eventTypeName: 'OnOff', value: 1 })],
@@ -1 +1 @@
1
- {"version":3,"file":"lights.test.js","sourceRoot":"","sources":["../../../test/devices/lights.test.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"lights.test.js","sourceRoot":"","sources":["../../../test/devices/lights.test.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "matterbridge-iotas",
3
- "version": "1.1.3",
3
+ "version": "1.1.5",
4
4
  "description": "Matterbridge plugin for IOTAS smart home devices",
5
5
  "author": "Augusto Meza <mezaugusto@proton.me>",
6
6
  "license": "Apache-2.0",
@@ -54,7 +54,7 @@
54
54
  "printWidth": 120
55
55
  },
56
56
  "dependencies": {
57
- "iotas-ts": "^1.2.0"
57
+ "iotas-ts": "^1.3.1"
58
58
  },
59
59
  "devDependencies": {
60
60
  "@eslint/js": "^9.0.0",