@homebridge-plugins/homebridge-smarthq 0.5.0-beta.2 → 0.5.0-beta.21

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.
Files changed (143) hide show
  1. package/.github/ISSUE_TEMPLATE/config.yml +1 -1
  2. package/.github/copilot-instructions.md +90 -0
  3. package/.github/scripts/branch-helper.sh +41 -0
  4. package/.github/workflows/beta-release.yml +1 -1
  5. package/.github/workflows/release.yml +53 -17
  6. package/CHANGELOG.md +563 -18
  7. package/README.md +15 -0
  8. package/config.schema.json +4 -5
  9. package/dist/devices/OpalIceMaker/Managers/OpalDescaleSvcManager.d.ts.map +1 -1
  10. package/dist/devices/OpalIceMaker/Managers/OpalDescaleSvcManager.js +3 -1
  11. package/dist/devices/OpalIceMaker/Managers/OpalDescaleSvcManager.js.map +1 -1
  12. package/dist/devices/OpalIceMaker/Managers/OpalFilterMaintenanceSvcManager.d.ts.map +1 -1
  13. package/dist/devices/OpalIceMaker/Managers/OpalFilterMaintenanceSvcManager.js +3 -1
  14. package/dist/devices/OpalIceMaker/Managers/OpalFilterMaintenanceSvcManager.js.map +1 -1
  15. package/dist/devices/OpalIceMaker/Managers/OpalPowerSvcManager.js +1 -1
  16. package/dist/devices/OpalIceMaker/Managers/OpalPowerSvcManager.js.map +1 -1
  17. package/dist/devices/OpalIceMaker/Managers/OpalProgressSvcManager.d.ts +1 -1
  18. package/dist/devices/OpalIceMaker/Managers/OpalProgressSvcManager.d.ts.map +1 -1
  19. package/dist/devices/OpalIceMaker/Managers/OpalProgressSvcManager.js +12 -5
  20. package/dist/devices/OpalIceMaker/Managers/OpalProgressSvcManager.js.map +1 -1
  21. package/dist/devices/OpalIceMaker/Managers/StatusManagers/OpalStatusBase.d.ts.map +1 -1
  22. package/dist/devices/OpalIceMaker/Managers/StatusManagers/OpalStatusBase.js +4 -2
  23. package/dist/devices/OpalIceMaker/Managers/StatusManagers/OpalStatusBase.js.map +1 -1
  24. package/dist/devices/OpalIceMaker/OpalDeviceBase.d.ts +3 -4
  25. package/dist/devices/OpalIceMaker/OpalDeviceBase.d.ts.map +1 -1
  26. package/dist/devices/OpalIceMaker/OpalDeviceBase.js +3 -18
  27. package/dist/devices/OpalIceMaker/OpalDeviceBase.js.map +1 -1
  28. package/dist/devices/advantium.d.ts +10 -0
  29. package/dist/devices/advantium.d.ts.map +1 -0
  30. package/dist/devices/advantium.js +75 -0
  31. package/dist/devices/advantium.js.map +1 -0
  32. package/dist/devices/airConditioner.d.ts.map +1 -1
  33. package/dist/devices/airConditioner.js +14 -11
  34. package/dist/devices/airConditioner.js.map +1 -1
  35. package/dist/devices/beverageCenter.d.ts +10 -0
  36. package/dist/devices/beverageCenter.d.ts.map +1 -0
  37. package/dist/devices/beverageCenter.js +125 -0
  38. package/dist/devices/beverageCenter.js.map +1 -0
  39. package/dist/devices/clothesDryer.d.ts +12 -0
  40. package/dist/devices/clothesDryer.d.ts.map +1 -0
  41. package/dist/devices/clothesDryer.js +142 -0
  42. package/dist/devices/clothesDryer.js.map +1 -0
  43. package/dist/devices/clothesWasher.d.ts +12 -0
  44. package/dist/devices/clothesWasher.d.ts.map +1 -0
  45. package/dist/devices/clothesWasher.js +159 -0
  46. package/dist/devices/clothesWasher.js.map +1 -0
  47. package/dist/devices/coffeeMaker.d.ts +10 -0
  48. package/dist/devices/coffeeMaker.d.ts.map +1 -0
  49. package/dist/devices/coffeeMaker.js +79 -0
  50. package/dist/devices/coffeeMaker.js.map +1 -0
  51. package/dist/devices/device.d.ts +25 -0
  52. package/dist/devices/device.d.ts.map +1 -1
  53. package/dist/devices/device.js +105 -1
  54. package/dist/devices/device.js.map +1 -1
  55. package/dist/devices/dishwasher.d.ts +0 -3
  56. package/dist/devices/dishwasher.d.ts.map +1 -1
  57. package/dist/devices/dishwasher.js +46 -29
  58. package/dist/devices/dishwasher.js.map +1 -1
  59. package/dist/devices/hood.d.ts +32 -0
  60. package/dist/devices/hood.d.ts.map +1 -0
  61. package/dist/devices/hood.js +269 -0
  62. package/dist/devices/hood.js.map +1 -0
  63. package/dist/devices/microwave.d.ts +10 -0
  64. package/dist/devices/microwave.d.ts.map +1 -0
  65. package/dist/devices/microwave.js +84 -0
  66. package/dist/devices/microwave.js.map +1 -0
  67. package/dist/devices/oven.d.ts +0 -2
  68. package/dist/devices/oven.d.ts.map +1 -1
  69. package/dist/devices/oven.js +141 -43
  70. package/dist/devices/oven.js.map +1 -1
  71. package/dist/devices/refrigerator.d.ts +0 -2
  72. package/dist/devices/refrigerator.d.ts.map +1 -1
  73. package/dist/devices/refrigerator.js +314 -29
  74. package/dist/devices/refrigerator.js.map +1 -1
  75. package/dist/devices/waterFilter.d.ts +10 -0
  76. package/dist/devices/waterFilter.d.ts.map +1 -0
  77. package/dist/devices/waterFilter.js +67 -0
  78. package/dist/devices/waterFilter.js.map +1 -0
  79. package/dist/devices/waterHeater.d.ts +10 -0
  80. package/dist/devices/waterHeater.d.ts.map +1 -0
  81. package/dist/devices/waterHeater.js +95 -0
  82. package/dist/devices/waterHeater.js.map +1 -0
  83. package/dist/devices/waterSoftener.d.ts +10 -0
  84. package/dist/devices/waterSoftener.d.ts.map +1 -0
  85. package/dist/devices/waterSoftener.js +67 -0
  86. package/dist/devices/waterSoftener.js.map +1 -0
  87. package/dist/getAccessToken.d.ts.map +1 -1
  88. package/dist/getAccessToken.js +6 -0
  89. package/dist/getAccessToken.js.map +1 -1
  90. package/dist/platform.d.ts +10 -0
  91. package/dist/platform.d.ts.map +1 -1
  92. package/dist/platform.js +393 -0
  93. package/dist/platform.js.map +1 -1
  94. package/dist/platform.test.d.ts +2 -0
  95. package/dist/platform.test.d.ts.map +1 -0
  96. package/dist/platform.test.js +80 -0
  97. package/dist/platform.test.js.map +1 -0
  98. package/dist/settings.d.ts +22 -0
  99. package/dist/settings.d.ts.map +1 -1
  100. package/dist/settings.js +13 -0
  101. package/dist/settings.js.map +1 -1
  102. package/docs/assets/highlight.css +7 -0
  103. package/docs/assets/main.js +5 -5
  104. package/docs/assets/navigation.js +1 -0
  105. package/docs/assets/search.js +1 -0
  106. package/docs/assets/style.css +248 -226
  107. package/docs/classes/SmartHQPlatform.html +45 -56
  108. package/docs/hierarchy.html +1 -0
  109. package/docs/index.html +22 -12
  110. package/docs/interfaces/DeviceOptions.html +2 -3
  111. package/docs/interfaces/SmartHQPlatformConfig.html +6 -17
  112. package/docs/interfaces/SmartHqContext.html +6 -4
  113. package/docs/interfaces/SmartHqERDResponse.html +7 -8
  114. package/docs/interfaces/credentials.html +3 -4
  115. package/docs/interfaces/devicesConfig.html +7 -8
  116. package/docs/interfaces/options.html +7 -8
  117. package/docs/media/copilot-instructions.md +90 -0
  118. package/docs/modules.html +1 -2
  119. package/docs/variables/API_URL.html +1 -2
  120. package/docs/variables/ERD_CODES.html +1 -2
  121. package/docs/variables/ERD_TYPES.html +1 -2
  122. package/docs/variables/KEEPALIVE_TIMEOUT.html +1 -2
  123. package/docs/variables/LOGIN_URL.html +2 -3
  124. package/docs/variables/OAUTH2_CLIENT_ID.html +1 -2
  125. package/docs/variables/OAUTH2_CLIENT_SECRET.html +1 -2
  126. package/docs/variables/OAUTH2_REDIRECT_URI.html +1 -2
  127. package/docs/variables/PLATFORM_NAME.html +2 -3
  128. package/docs/variables/PLUGIN_NAME.html +2 -3
  129. package/docs/variables/SECURE_URL.html +2 -3
  130. package/docs/variables/default.html +1 -0
  131. package/package.json +21 -32
  132. package/typedoc.json +0 -4
  133. package/vitest.config.ts +6 -5
  134. package/.github/workflows/build.yml +0 -18
  135. package/.github/workflows/changerelease.yml +0 -11
  136. package/.github/workflows/labeler.yml +0 -9
  137. package/.github/workflows/release-drafter.yml +0 -14
  138. package/docs/assets/dmt/dmt-component-data.js +0 -1
  139. package/docs/assets/dmt/dmt-components.css +0 -20
  140. package/docs/assets/dmt/dmt-components.js +0 -67
  141. package/docs/assets/dmt/dmt-search.cmp +0 -0
  142. package/docs/assets/dmt/dmt-theme.css +0 -1
  143. package/docs/functions/default.html +0 -2
@@ -0,0 +1,67 @@
1
+ import { deviceBase } from './device.js';
2
+ export class SmartHQWaterSoftener extends deviceBase {
3
+ platform;
4
+ device;
5
+ constructor(platform, accessory, device) {
6
+ super(platform, accessory, device);
7
+ this.platform = platform;
8
+ this.device = device;
9
+ this.debugLog(`Water Softener Features: ${JSON.stringify(accessory.context.device.features)}`);
10
+ // Water Softener Filter/Salt Status
11
+ const filterService = this.accessory.getService('Softener Salt') ?? this.accessory.addService(this.platform.Service.FilterMaintenance, 'Softener Salt', 'SoftenerSalt');
12
+ filterService.setCharacteristic(this.platform.Characteristic.Name, 'Softener Salt');
13
+ filterService
14
+ .getCharacteristic(this.platform.Characteristic.FilterChangeIndication)
15
+ .onGet(async () => {
16
+ try {
17
+ // TODO: Implement salt level ERD
18
+ return this.platform.Characteristic.FilterChangeIndication.FILTER_OK;
19
+ }
20
+ catch (error) {
21
+ this.warnLog?.(`Softener Salt Status error: ${error?.message ?? error}`);
22
+ return this.platform.Characteristic.FilterChangeIndication.FILTER_OK;
23
+ }
24
+ });
25
+ filterService
26
+ .getCharacteristic(this.platform.Characteristic.FilterLifeLevel)
27
+ .onGet(async () => {
28
+ try {
29
+ // TODO: Implement salt level percentage ERD
30
+ return 100;
31
+ }
32
+ catch (error) {
33
+ this.warnLog?.(`Softener Salt Level error: ${error?.message ?? error}`);
34
+ return 100;
35
+ }
36
+ });
37
+ // Water Valve
38
+ const valveService = this.accessory.getService('Water Softener') ?? this.accessory.addService(this.platform.Service.Valve, 'Water Softener', 'WaterSoftener');
39
+ valveService.setCharacteristic(this.platform.Characteristic.Name, 'Water Softener');
40
+ valveService.setCharacteristic(this.platform.Characteristic.ValveType, this.platform.Characteristic.ValveType.WATER_FAUCET);
41
+ valveService
42
+ .getCharacteristic(this.platform.Characteristic.Active)
43
+ .onGet(async () => {
44
+ try {
45
+ // TODO: Implement softener active state ERD
46
+ return this.platform.Characteristic.Active.ACTIVE;
47
+ }
48
+ catch (error) {
49
+ this.warnLog?.(`Water Softener Active error: ${error?.message ?? error}`);
50
+ return this.platform.Characteristic.Active.INACTIVE;
51
+ }
52
+ });
53
+ valveService
54
+ .getCharacteristic(this.platform.Characteristic.InUse)
55
+ .onGet(async () => {
56
+ try {
57
+ // TODO: Implement softener in-use state ERD
58
+ return this.platform.Characteristic.InUse.IN_USE;
59
+ }
60
+ catch (error) {
61
+ this.warnLog?.(`Water Softener InUse error: ${error?.message ?? error}`);
62
+ return this.platform.Characteristic.InUse.NOT_IN_USE;
63
+ }
64
+ });
65
+ }
66
+ }
67
+ //# sourceMappingURL=waterSoftener.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"waterSoftener.js","sourceRoot":"","sources":["../../src/devices/waterSoftener.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"getAccessToken.d.ts","sourceRoot":"","sources":["../src/getAccessToken.ts"],"names":[],"mappings":"AAoBA,wBAAsB,kBAAkB,CAAC,aAAa,EAAE,MAAM,6CAG7D;AAED,wBAA8B,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,6CA+B9E"}
1
+ {"version":3,"file":"getAccessToken.d.ts","sourceRoot":"","sources":["../src/getAccessToken.ts"],"names":[],"mappings":"AAoBA,wBAAsB,kBAAkB,CAAC,aAAa,EAAE,MAAM,6CAG7D;AAED,wBAA8B,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,6CAuC9E"}
@@ -35,7 +35,13 @@ export default async function getAccessToken(username, password) {
35
35
  maxRedirects: 0,
36
36
  validateStatus: () => true,
37
37
  });
38
+ if (!res.headers.location) {
39
+ throw new Error('Authentication failed: No redirect location received');
40
+ }
38
41
  const code = new URL(res.headers.location).searchParams.get('code');
42
+ if (!code) {
43
+ throw new Error('Authentication failed: No authorization code received');
44
+ }
39
45
  return client.grant({ grant_type: 'authorization_code', code, redirect_uri: OAUTH2_REDIRECT_URI });
40
46
  }
41
47
  //# sourceMappingURL=getAccessToken.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getAccessToken.js","sourceRoot":"","sources":["../src/getAccessToken.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAA;AACjD,OAAO,KAAK,OAAO,MAAM,SAAS,CAAA;AAClC,OAAO,GAAG,MAAM,QAAQ,CAAA;AACxB,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAA;AACtC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AAExC,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AAE3F,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,GAAG,CAAA;AAEhC,MAAM,UAAU,GAAG,MAAM,CAAC,QAAQ,CAAC,6CAA6C,CAAC,CAAC,IAAI,CACpF,MAAM,CAAC,EAAE,CACP,IAAI,MAAM,CAAC,MAAM,CAAC;IAChB,SAAS,EAAE,gBAAgB;IAC3B,aAAa,EAAE,oBAAoB;IACnC,cAAc,EAAE,CAAC,MAAM,CAAC;CACzB,CAAC,CACL,CAAA;AAED,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,aAAqB;IAC5D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAA;IAC/B,OAAO,MAAM,CAAC,KAAK,CAAC,EAAE,aAAa,EAAE,UAAU,EAAE,eAAe,EAAE,CAAC,CAAA;AACrE,CAAC;AAED,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,cAAc,CAAC,QAAgB,EAAE,QAAgB;IAC7E,MAAM,MAAM,GAAG,MAAM,UAAU,CAAA;IAE/B,MAAM,QAAQ,GAAG,MAAM,CAAC,gBAAgB,EAAE,CAAA;IAE1C,MAAM,GAAG,GAAG,IAAI,SAAS,EAAE,CAAA;IAC3B,MAAM,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAA;IAC9C,MAAM,gBAAgB,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;IAEpD,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAA;IAChD,MAAM,WAAW,GAAG,SAAS,CAC3B,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EACvD,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CACb,CAAA;IAED,MAAM,IAAI,GAAG,IAAI,eAAe,CAAC,EAAE,GAAG,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAA;IAExE,MAAM,GAAG,GAAG,MAAM,OAAO,CAAC;QACxB,MAAM,EAAE,MAAM;QACd,OAAO,EAAE;YACP,cAAc,EAAE,mCAAmC;YACnD,QAAQ,EAAE,4CAA4C;SACvD;QACD,GAAG,EAAE,kEAAkE;QACvE,IAAI,EAAE,IAAI;QACV,YAAY,EAAE,CAAC;QACf,cAAc,EAAE,GAAG,EAAE,CAAC,IAAI;KAC3B,CAAC,CAAA;IAEF,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IACnE,OAAO,MAAM,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,oBAAoB,EAAE,IAAI,EAAE,YAAY,EAAE,mBAAmB,EAAE,CAAC,CAAA;AACpG,CAAC"}
1
+ {"version":3,"file":"getAccessToken.js","sourceRoot":"","sources":["../src/getAccessToken.ts"],"names":[],"mappings":"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"}
@@ -42,6 +42,16 @@ export declare class SmartHQPlatform implements DynamicPlatformPlugin {
42
42
  private createSmartHQIceMaker;
43
43
  private createSmartHQRefrigerator;
44
44
  private createSmartHQAirConditioner;
45
+ private createSmartHQHood;
46
+ private createSmartHQClothesWasher;
47
+ private createSmartHQClothesDryer;
48
+ private createSmartHQWaterFilter;
49
+ private createSmartHQWaterSoftener;
50
+ private createSmartHQWaterHeater;
51
+ private createSmartHQAdvantium;
52
+ private createSmartHQMicrowave;
53
+ private createSmartHQCoffeeMaker;
54
+ private createSmartHQBeverageCenter;
45
55
  unregisterPlatformAccessories(existingAccessory: PlatformAccessory): Promise<void>;
46
56
  getPlatformLogSettings(): Promise<void>;
47
57
  getPlatformRateSettings(): Promise<void>;
@@ -1 +1 @@
1
- {"version":3,"file":"platform.d.ts","sourceRoot":"","sources":["../src/platform.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,qBAAqB,EAAE,GAAG,EAAE,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAG7F,OAAO,KAAK,EAA8B,OAAO,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAA;AAqB/G;;;;GAIG;AACH,qBAAa,eAAgB,YAAW,qBAAqB;IACpD,WAAW,EAAE,iBAAiB,CAAC,cAAc,CAAC,EAAE,CAAA;IACvD,SAAgB,GAAG,EAAE,GAAG,CAAA;IACxB,SAAgB,GAAG,EAAE,OAAO,CAAA;IAC5B,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAA;IACpB,MAAM,EAAG,qBAAqB,CAAA;IAE9B,OAAO,EAAG,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,CAAA;IACrC,cAAc,EAAG,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,CAAA;IAC1D,OAAO,CAAC,QAAQ,CAAW;IAE3B,cAAc,EAAG,qBAAqB,CAAA;IACtC,eAAe,EAAG,OAAO,CAAC,SAAS,CAAC,CAAA;IACpC,mBAAmB,EAAG,OAAO,CAAC,aAAa,CAAC,CAAA;IAC5C,gBAAgB,EAAG,OAAO,CAAC,UAAU,CAAC,CAAA;IACtC,kBAAkB,EAAG,OAAO,CAAC,YAAY,CAAC,CAAA;IAC1C,SAAS,EAAG,OAAO,CAAA;IACnB,OAAO,EAAG,MAAM,CAAA;gBAGd,GAAG,EAAE,OAAO,EACZ,MAAM,EAAE,qBAAqB,EAC7B,GAAG,EAAE,GAAG;IA0DV;;;OAGG;IACH,kBAAkB,CAAC,SAAS,EAAE,iBAAiB;IAO/C;;OAEG;IACG,YAAY;IAaZ,sBAAsB;IAsB5B;;;OAGG;IACG,eAAe;YAsHP,uBAAuB;YAiDvB,iBAAiB;YAiDjB,qBAAqB;YAgDrB,yBAAyB;YAiDzB,2BAA2B;IAiD5B,6BAA6B,CAAC,iBAAiB,EAAE,iBAAiB;IAMzE,sBAAsB;IAUtB,uBAAuB;IAevB,yBAAyB;IAgB/B;;;;;;;;OAQG;IACG,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAMjC;;;;;;OAMG;IACG,2BAA2B,CAAC,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAgCpG;;;OAGG;IACG,OAAO,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMrC,UAAU,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMxC,eAAe,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7C,OAAO,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMrC,YAAY,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ1C,QAAQ,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMtC,aAAa,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ3C,QAAQ,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAUtC,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAIlC,uBAAuB,IAAI,OAAO,CAAC,OAAO,CAAC;CAGlD"}
1
+ {"version":3,"file":"platform.d.ts","sourceRoot":"","sources":["../src/platform.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,qBAAqB,EAAE,GAAG,EAAE,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAG7F,OAAO,KAAK,EAA8B,OAAO,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAA;AA+B/G;;;;GAIG;AACH,qBAAa,eAAgB,YAAW,qBAAqB;IACpD,WAAW,EAAE,iBAAiB,CAAC,cAAc,CAAC,EAAE,CAAA;IACvD,SAAgB,GAAG,EAAE,GAAG,CAAA;IACxB,SAAgB,GAAG,EAAE,OAAO,CAAA;IAC5B,SAAS,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAA;IACpB,MAAM,EAAG,qBAAqB,CAAA;IAE9B,OAAO,EAAG,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,OAAO,CAAA;IACrC,cAAc,EAAG,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,CAAA;IAC1D,OAAO,CAAC,QAAQ,CAAW;IAE3B,cAAc,EAAG,qBAAqB,CAAA;IACtC,eAAe,EAAG,OAAO,CAAC,SAAS,CAAC,CAAA;IACpC,mBAAmB,EAAG,OAAO,CAAC,aAAa,CAAC,CAAA;IAC5C,gBAAgB,EAAG,OAAO,CAAC,UAAU,CAAC,CAAA;IACtC,kBAAkB,EAAG,OAAO,CAAC,YAAY,CAAC,CAAA;IAC1C,SAAS,EAAG,OAAO,CAAA;IACnB,OAAO,EAAG,MAAM,CAAA;gBAGd,GAAG,EAAE,OAAO,EACZ,MAAM,EAAE,qBAAqB,EAC7B,GAAG,EAAE,GAAG;IA0DV;;;OAGG;IACH,kBAAkB,CAAC,SAAS,EAAE,iBAAiB;IAO/C;;OAEG;IACG,YAAY;IAaZ,sBAAsB;IA+B5B;;;OAGG;IACG,eAAe;YAyJP,uBAAuB;YAiDvB,iBAAiB;YAiDjB,qBAAqB;YAgDrB,yBAAyB;YAiDzB,2BAA2B;YAiD3B,iBAAiB;YAoCjB,0BAA0B;YAmC1B,yBAAyB;YAmCzB,wBAAwB;YAgCxB,0BAA0B;YAgC1B,wBAAwB;YAgCxB,sBAAsB;YAgCtB,sBAAsB;YAgCtB,wBAAwB;YAgCxB,2BAA2B;IAgC5B,6BAA6B,CAAC,iBAAiB,EAAE,iBAAiB;IAMzE,sBAAsB;IAUtB,uBAAuB;IAevB,yBAAyB;IAgB/B;;;;;;;;OAQG;IACG,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAMjC;;;;;;OAMG;IACG,2BAA2B,CAAC,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAgCpG;;;OAGG;IACG,OAAO,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMrC,UAAU,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMxC,eAAe,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7C,OAAO,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMrC,YAAY,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ1C,QAAQ,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAMtC,aAAa,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ3C,QAAQ,CAAC,GAAG,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAUtC,cAAc,IAAI,OAAO,CAAC,OAAO,CAAC;IAIlC,uBAAuB,IAAI,OAAO,CAAC,OAAO,CAAC;CAGlD"}
package/dist/platform.js CHANGED
@@ -4,10 +4,20 @@ import { SmartHQIceMaker } from './devices/OpalIceMaker/index.js';
4
4
  import axios from 'axios';
5
5
  import pkg from 'lodash';
6
6
  import ws from 'ws';
7
+ import { SmartHQAdvantium } from './devices/advantium.js';
7
8
  import { SmartHQAirConditioner } from './devices/airConditioner.js';
9
+ import { SmartHQBeverageCenter } from './devices/beverageCenter.js';
10
+ import { SmartHQClothesDryer } from './devices/clothesDryer.js';
11
+ import { SmartHQClothesWasher } from './devices/clothesWasher.js';
12
+ import { SmartHQCoffeeMaker } from './devices/coffeeMaker.js';
8
13
  import { SmartHQDishWasher } from './devices/dishwasher.js';
14
+ import { SmartHQHood } from './devices/hood.js';
15
+ import { SmartHQMicrowave } from './devices/microwave.js';
9
16
  import { SmartHQOven } from './devices/oven.js';
10
17
  import { SmartHQRefrigerator } from './devices/refrigerator.js';
18
+ import { SmartHQWaterFilter } from './devices/waterFilter.js';
19
+ import { SmartHQWaterHeater } from './devices/waterHeater.js';
20
+ import { SmartHQWaterSoftener } from './devices/waterSoftener.js';
11
21
  import getAccessToken, { refreshAccessToken } from './getAccessToken.js';
12
22
  import { API_URL, ERD_CODES, ERD_TYPES, KEEPALIVE_TIMEOUT, PLATFORM_NAME, PLUGIN_NAME } from './settings.js';
13
23
  const { find } = pkg;
@@ -112,17 +122,24 @@ export class SmartHQPlatform {
112
122
  }
113
123
  }
114
124
  async startRefreshTokenLogic() {
125
+ if (!this.tokenSet) {
126
+ throw new Error('Token set is undefined');
127
+ }
115
128
  if (this.tokenSet.refresh_token) {
116
129
  try {
117
130
  this.tokenSet = await refreshAccessToken(this.tokenSet.refresh_token);
118
131
  }
119
132
  catch (e) {
120
133
  await this.errorLog(`Failed to refresh Access Token, Error Message: ${e.message ?? e}, Submit Bugs Here: https://bit.ly/smarthq-bug-report`);
134
+ throw e; // Re-throw to stop execution
121
135
  }
122
136
  }
123
137
  else {
124
138
  throw new Error('Refresh token is undefined');
125
139
  }
140
+ if (!this.tokenSet.access_token) {
141
+ throw new Error('Access token is undefined after refresh');
142
+ }
126
143
  axios.defaults.headers.common = {
127
144
  Authorization: `Bearer ${this.tokenSet.access_token}`,
128
145
  };
@@ -148,12 +165,14 @@ export class SmartHQPlatform {
148
165
  }
149
166
  catch (e) {
150
167
  await this.errorLog(`discoverDevices, Failed to get Access Token, Error Message: ${e.message ?? e}, Submit Bugs Here: https://bit.ly/smarthq-bug-report`);
168
+ return; // Stop execution if authentication fails
151
169
  }
152
170
  try {
153
171
  await this.startRefreshTokenLogic();
154
172
  }
155
173
  catch (e) {
156
174
  await this.errorLog(`discoverDevices, Failed to start Refresh Token Logic, Error Message: ${e.message ?? e}, Submit Bugs Here: https://bit.ly/smarthq-bug-report`);
175
+ return; // Stop execution if token refresh setup fails
157
176
  }
158
177
  try {
159
178
  const wssData = await axios.get('/websocket');
@@ -222,9 +241,41 @@ export class SmartHQPlatform {
222
241
  await this.createSmartHQIceMaker(userId, device, details, features);
223
242
  break;
224
243
  case 'Air Conditioner':
244
+ case 'Portable AC':
225
245
  case 'Split Air Conditioner':
226
246
  await this.createSmartHQAirConditioner(userId, device, details, features);
227
247
  break;
248
+ case 'Hood':
249
+ await this.createSmartHQHood(userId, device, details, features);
250
+ break;
251
+ case 'Clothes Washer':
252
+ await this.createSmartHQClothesWasher(userId, device, details, features);
253
+ break;
254
+ case 'Clothes Dryer':
255
+ await this.createSmartHQClothesDryer(userId, device, details, features);
256
+ break;
257
+ case 'Whole Home Water Filter':
258
+ await this.createSmartHQWaterFilter(userId, device, details, features);
259
+ break;
260
+ case 'Whole Home Water Softener':
261
+ await this.createSmartHQWaterSoftener(userId, device, details, features);
262
+ break;
263
+ case 'Whole Home Water Heater':
264
+ await this.createSmartHQWaterHeater(userId, device, details, features);
265
+ break;
266
+ case 'Advantium':
267
+ await this.createSmartHQAdvantium(userId, device, details, features);
268
+ break;
269
+ case 'Microwave':
270
+ await this.createSmartHQMicrowave(userId, device, details, features);
271
+ break;
272
+ case 'Coffee Maker':
273
+ case 'Espresso Maker':
274
+ await this.createSmartHQCoffeeMaker(userId, device, details, features);
275
+ break;
276
+ case 'Beverage Center':
277
+ await this.createSmartHQBeverageCenter(userId, device, details, features);
278
+ break;
228
279
  default:
229
280
  await this.warnLog(`Device Type Not Supported: ${device.type}`);
230
281
  break;
@@ -473,6 +524,348 @@ export class SmartHQPlatform {
473
524
  this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
474
525
  }
475
526
  }
527
+ async createSmartHQHood(userId, device, details, features) {
528
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
529
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
530
+ if (existingAccessory) {
531
+ if (!device.hide_device) {
532
+ existingAccessory.context.device = device;
533
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
534
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
535
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
536
+ this.api.updatePlatformAccessories([existingAccessory]);
537
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
538
+ new SmartHQHood(this, existingAccessory, device);
539
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
540
+ }
541
+ else {
542
+ this.unregisterPlatformAccessories(existingAccessory);
543
+ }
544
+ }
545
+ else if (!device.hide_device && !existingAccessory) {
546
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
547
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
548
+ accessory.context.device = device;
549
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
550
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
551
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
552
+ new SmartHQHood(this, accessory, device);
553
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
554
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
555
+ this.accessories.push(accessory);
556
+ }
557
+ else {
558
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
559
+ }
560
+ }
561
+ async createSmartHQClothesWasher(userId, device, details, features) {
562
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
563
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
564
+ if (existingAccessory) {
565
+ if (!device.hide_device) {
566
+ existingAccessory.context.device = device;
567
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
568
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
569
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
570
+ this.api.updatePlatformAccessories([existingAccessory]);
571
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
572
+ // create the accessory handler for the restored accessory
573
+ new SmartHQClothesWasher(this, existingAccessory, device);
574
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
575
+ }
576
+ else {
577
+ this.unregisterPlatformAccessories(existingAccessory);
578
+ }
579
+ }
580
+ else if (!device.hide_device && !existingAccessory) {
581
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
582
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
583
+ accessory.context.device = device;
584
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
585
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
586
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
587
+ new SmartHQClothesWasher(this, accessory, device);
588
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
589
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
590
+ this.accessories.push(accessory);
591
+ }
592
+ else {
593
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
594
+ }
595
+ }
596
+ async createSmartHQClothesDryer(userId, device, details, features) {
597
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
598
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
599
+ if (existingAccessory) {
600
+ if (!device.hide_device) {
601
+ existingAccessory.context.device = device;
602
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
603
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
604
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
605
+ this.api.updatePlatformAccessories([existingAccessory]);
606
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
607
+ // create the accessory handler for the restored accessory
608
+ new SmartHQClothesDryer(this, existingAccessory, device);
609
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
610
+ }
611
+ else {
612
+ this.unregisterPlatformAccessories(existingAccessory);
613
+ }
614
+ }
615
+ else if (!device.hide_device && !existingAccessory) {
616
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
617
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
618
+ accessory.context.device = device;
619
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
620
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
621
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
622
+ new SmartHQClothesDryer(this, accessory, device);
623
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
624
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
625
+ this.accessories.push(accessory);
626
+ }
627
+ else {
628
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
629
+ }
630
+ }
631
+ async createSmartHQWaterFilter(userId, device, details, features) {
632
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
633
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
634
+ if (existingAccessory) {
635
+ if (!device.hide_device) {
636
+ existingAccessory.context.device = device;
637
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
638
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
639
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
640
+ this.api.updatePlatformAccessories([existingAccessory]);
641
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
642
+ new SmartHQWaterFilter(this, existingAccessory, device);
643
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
644
+ }
645
+ else {
646
+ this.unregisterPlatformAccessories(existingAccessory);
647
+ }
648
+ }
649
+ else if (!device.hide_device && !existingAccessory) {
650
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
651
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
652
+ accessory.context.device = device;
653
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
654
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
655
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
656
+ new SmartHQWaterFilter(this, accessory, device);
657
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
658
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
659
+ this.accessories.push(accessory);
660
+ }
661
+ else {
662
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
663
+ }
664
+ }
665
+ async createSmartHQWaterSoftener(userId, device, details, features) {
666
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
667
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
668
+ if (existingAccessory) {
669
+ if (!device.hide_device) {
670
+ existingAccessory.context.device = device;
671
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
672
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
673
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
674
+ this.api.updatePlatformAccessories([existingAccessory]);
675
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
676
+ new SmartHQWaterSoftener(this, existingAccessory, device);
677
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
678
+ }
679
+ else {
680
+ this.unregisterPlatformAccessories(existingAccessory);
681
+ }
682
+ }
683
+ else if (!device.hide_device && !existingAccessory) {
684
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
685
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
686
+ accessory.context.device = device;
687
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
688
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
689
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
690
+ new SmartHQWaterSoftener(this, accessory, device);
691
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
692
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
693
+ this.accessories.push(accessory);
694
+ }
695
+ else {
696
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
697
+ }
698
+ }
699
+ async createSmartHQWaterHeater(userId, device, details, features) {
700
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
701
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
702
+ if (existingAccessory) {
703
+ if (!device.hide_device) {
704
+ existingAccessory.context.device = device;
705
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
706
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
707
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
708
+ this.api.updatePlatformAccessories([existingAccessory]);
709
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
710
+ new SmartHQWaterHeater(this, existingAccessory, device);
711
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
712
+ }
713
+ else {
714
+ this.unregisterPlatformAccessories(existingAccessory);
715
+ }
716
+ }
717
+ else if (!device.hide_device && !existingAccessory) {
718
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
719
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
720
+ accessory.context.device = device;
721
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
722
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
723
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
724
+ new SmartHQWaterHeater(this, accessory, device);
725
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
726
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
727
+ this.accessories.push(accessory);
728
+ }
729
+ else {
730
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
731
+ }
732
+ }
733
+ async createSmartHQAdvantium(userId, device, details, features) {
734
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
735
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
736
+ if (existingAccessory) {
737
+ if (!device.hide_device) {
738
+ existingAccessory.context.device = device;
739
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
740
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
741
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
742
+ this.api.updatePlatformAccessories([existingAccessory]);
743
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
744
+ new SmartHQAdvantium(this, existingAccessory, device);
745
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
746
+ }
747
+ else {
748
+ this.unregisterPlatformAccessories(existingAccessory);
749
+ }
750
+ }
751
+ else if (!device.hide_device && !existingAccessory) {
752
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
753
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
754
+ accessory.context.device = device;
755
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
756
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
757
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
758
+ new SmartHQAdvantium(this, accessory, device);
759
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
760
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
761
+ this.accessories.push(accessory);
762
+ }
763
+ else {
764
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
765
+ }
766
+ }
767
+ async createSmartHQMicrowave(userId, device, details, features) {
768
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
769
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
770
+ if (existingAccessory) {
771
+ if (!device.hide_device) {
772
+ existingAccessory.context.device = device;
773
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
774
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
775
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
776
+ this.api.updatePlatformAccessories([existingAccessory]);
777
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
778
+ new SmartHQMicrowave(this, existingAccessory, device);
779
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
780
+ }
781
+ else {
782
+ this.unregisterPlatformAccessories(existingAccessory);
783
+ }
784
+ }
785
+ else if (!device.hide_device && !existingAccessory) {
786
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
787
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
788
+ accessory.context.device = device;
789
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
790
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
791
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
792
+ new SmartHQMicrowave(this, accessory, device);
793
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
794
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
795
+ this.accessories.push(accessory);
796
+ }
797
+ else {
798
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
799
+ }
800
+ }
801
+ async createSmartHQCoffeeMaker(userId, device, details, features) {
802
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
803
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
804
+ if (existingAccessory) {
805
+ if (!device.hide_device) {
806
+ existingAccessory.context.device = device;
807
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
808
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
809
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
810
+ this.api.updatePlatformAccessories([existingAccessory]);
811
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
812
+ new SmartHQCoffeeMaker(this, existingAccessory, device);
813
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
814
+ }
815
+ else {
816
+ this.unregisterPlatformAccessories(existingAccessory);
817
+ }
818
+ }
819
+ else if (!device.hide_device && !existingAccessory) {
820
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
821
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
822
+ accessory.context.device = device;
823
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
824
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
825
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
826
+ new SmartHQCoffeeMaker(this, accessory, device);
827
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
828
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
829
+ this.accessories.push(accessory);
830
+ }
831
+ else {
832
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
833
+ }
834
+ }
835
+ async createSmartHQBeverageCenter(userId, device, details, features) {
836
+ const uuid = this.api.hap.uuid.generate(device.applianceId);
837
+ const existingAccessory = this.accessories.find(accessory => accessory.UUID === uuid);
838
+ if (existingAccessory) {
839
+ if (!device.hide_device) {
840
+ existingAccessory.context.device = device;
841
+ existingAccessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
842
+ existingAccessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
843
+ existingAccessory.context.device.firmware = device.firmware ?? await this.getVersion();
844
+ this.api.updatePlatformAccessories([existingAccessory]);
845
+ this.infoLog(`Restoring existing accessory from cache: ${existingAccessory.displayName}`);
846
+ new SmartHQBeverageCenter(this, existingAccessory, device);
847
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
848
+ }
849
+ else {
850
+ this.unregisterPlatformAccessories(existingAccessory);
851
+ }
852
+ }
853
+ else if (!device.hide_device && !existingAccessory) {
854
+ this.infoLog(`Adding new accessory: ${device.nickname}`);
855
+ const accessory = new this.api.platformAccessory(device.nickname, uuid);
856
+ accessory.context.device = device;
857
+ accessory.context = { device: { brand: 'GE', ...details, ...features }, userId };
858
+ accessory.displayName = await this.validateAndCleanDisplayName(device.nickname, 'nickname', device.nickname);
859
+ accessory.context.device.firmware = device.firmware ?? await this.getVersion();
860
+ new SmartHQBeverageCenter(this, accessory, device);
861
+ this.debugLog(`${device.nickname} uuid: ${device.applianceId}`);
862
+ this.api.registerPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [accessory]);
863
+ this.accessories.push(accessory);
864
+ }
865
+ else {
866
+ this.debugErrorLog(`Unable to Register new device: ${JSON.stringify(device.nickname)}`);
867
+ }
868
+ }
476
869
  async unregisterPlatformAccessories(existingAccessory) {
477
870
  // remove platform accessories when no longer present
478
871
  this.api.unregisterPlatformAccessories(PLUGIN_NAME, PLATFORM_NAME, [existingAccessory]);