dt-common-device 3.1.1 → 3.1.4

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.
@@ -0,0 +1,7 @@
1
+ export declare class AdminRepository {
2
+ private readonly axiosInstance;
3
+ private readonly deviceRepository;
4
+ private readonly postgres;
5
+ constructor();
6
+ getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[]>;
7
+ }
@@ -0,0 +1,182 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
19
+ function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
20
+ var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
21
+ var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
22
+ var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
23
+ var _, done = false;
24
+ for (var i = decorators.length - 1; i >= 0; i--) {
25
+ var context = {};
26
+ for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
27
+ for (var p in contextIn.access) context.access[p] = contextIn.access[p];
28
+ context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
29
+ var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
30
+ if (kind === "accessor") {
31
+ if (result === void 0) continue;
32
+ if (result === null || typeof result !== "object") throw new TypeError("Object expected");
33
+ if (_ = accept(result.get)) descriptor.get = _;
34
+ if (_ = accept(result.set)) descriptor.set = _;
35
+ if (_ = accept(result.init)) initializers.unshift(_);
36
+ }
37
+ else if (_ = accept(result)) {
38
+ if (kind === "field") initializers.unshift(_);
39
+ else descriptor[key] = _;
40
+ }
41
+ }
42
+ if (target) Object.defineProperty(target, contextIn.name, descriptor);
43
+ done = true;
44
+ };
45
+ var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
46
+ var useValue = arguments.length > 2;
47
+ for (var i = 0; i < initializers.length; i++) {
48
+ value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
49
+ }
50
+ return useValue ? value : void 0;
51
+ };
52
+ var __importStar = (this && this.__importStar) || (function () {
53
+ var ownKeys = function(o) {
54
+ ownKeys = Object.getOwnPropertyNames || function (o) {
55
+ var ar = [];
56
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
57
+ return ar;
58
+ };
59
+ return ownKeys(o);
60
+ };
61
+ return function (mod) {
62
+ if (mod && mod.__esModule) return mod;
63
+ var result = {};
64
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
65
+ __setModuleDefault(result, mod);
66
+ return result;
67
+ };
68
+ })();
69
+ var __setFunctionName = (this && this.__setFunctionName) || function (f, name, prefix) {
70
+ if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
71
+ return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
72
+ };
73
+ Object.defineProperty(exports, "__esModule", { value: true });
74
+ exports.AdminRepository = void 0;
75
+ const typedi_1 = __importStar(require("typedi"));
76
+ const utils_1 = require("../utils");
77
+ const Device_repository_1 = require("../device/local/repository/Device.repository");
78
+ const db_1 = require("../db/db");
79
+ const interfaces_1 = require("../device/cloud/interfaces");
80
+ let AdminRepository = (() => {
81
+ let _classDecorators = [(0, typedi_1.Service)()];
82
+ let _classDescriptor;
83
+ let _classExtraInitializers = [];
84
+ let _classThis;
85
+ var AdminRepository = _classThis = class {
86
+ constructor() {
87
+ this.axiosInstance = (0, utils_1.getCloudServiceAxiosInstance)();
88
+ this.deviceRepository = typedi_1.default.get(Device_repository_1.DeviceRepository);
89
+ this.postgres = (0, db_1.getPostgresClient)();
90
+ }
91
+ async getZonesByAccessGroupIds(accessGroupIds) {
92
+ const result = await this.postgres.query(`SELECT "zc".*, "z"."id", "z"."name"
93
+ FROM "dt_zones_collection_map" "zc"
94
+ INNER JOIN "dt_zones" "z" ON "zc"."zoneId" = "z"."id"
95
+ WHERE "zc"."collectionId" = ANY($1)`, [accessGroupIds]);
96
+ const response = result.rows;
97
+ const _zones = (nestedZones, allzones = []) => {
98
+ nestedZones.forEach((z) => {
99
+ const onlyZone = { ...z };
100
+ delete onlyZone.childZones;
101
+ allzones.push(onlyZone);
102
+ if (!Array.isArray(z.childZones)) {
103
+ if (z.childZones.id)
104
+ z.childZones = [z.childZones];
105
+ }
106
+ if (z.childZones.length) {
107
+ _zones(z.childZones, allzones);
108
+ }
109
+ });
110
+ return allzones.map((e) => e.id);
111
+ };
112
+ // const zones = _zones(response);
113
+ const zoneIds = response.map((el) => el.id);
114
+ const collectionZone = [];
115
+ for (let i = 0; i < response.length; i++) {
116
+ let zoneIds = [];
117
+ const zones = await this.axiosInstance.get(`/zones/child?zoneId=${response[i].zoneId}`);
118
+ zoneIds.push(response[i].zoneId);
119
+ if (zones.childZones?.length > 0) {
120
+ const nestedZoneIds = new Set(_zones(zones.childZones));
121
+ zoneIds = [...zoneIds, ...nestedZoneIds];
122
+ }
123
+ if (collectionZone.length == 0) {
124
+ const obj = {
125
+ collectionId: response[i].collectionId,
126
+ zoneIds,
127
+ };
128
+ collectionZone.push(obj);
129
+ }
130
+ else {
131
+ const obj = collectionZone.find((e) => e.collectionId == response[i].collectionId);
132
+ if (obj) {
133
+ obj.zoneIds = [...obj.zoneIds, ...zoneIds];
134
+ }
135
+ else {
136
+ collectionZone.push({
137
+ collectionId: response[i].collectionId,
138
+ zoneIds,
139
+ });
140
+ }
141
+ }
142
+ }
143
+ let _zoneIds = collectionZone.flatMap((e) => {
144
+ return e.zoneIds.map((z) => z);
145
+ });
146
+ if (_zoneIds.length === 0)
147
+ return [];
148
+ const deviecDetail = await this.deviceRepository.queryDevices({
149
+ zoneIds: _zoneIds,
150
+ excludeDeviceType: interfaces_1.DeviceType.HUB
151
+ });
152
+ const _collectionZone = collectionZone.map((e) => {
153
+ const zones = e.zoneIds;
154
+ let devices = [];
155
+ zones.forEach((element) => {
156
+ const device = deviecDetail.filter((d) => d.zoneId == element);
157
+ // Add collectionId to each device
158
+ device.forEach((dev) => {
159
+ dev.collectionId = e.collectionId;
160
+ });
161
+ const _devices = devices.concat(device);
162
+ devices = _devices;
163
+ });
164
+ e.devices = devices;
165
+ e.parentZone = response;
166
+ return e;
167
+ });
168
+ const collectionZoneDevices = Array.from(new Set(_collectionZone));
169
+ return collectionZoneDevices;
170
+ }
171
+ };
172
+ __setFunctionName(_classThis, "AdminRepository");
173
+ (() => {
174
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
175
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
176
+ AdminRepository = _classThis = _classDescriptor.value;
177
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
178
+ __runInitializers(_classThis, _classExtraInitializers);
179
+ })();
180
+ return AdminRepository = _classThis;
181
+ })();
182
+ exports.AdminRepository = AdminRepository;
@@ -0,0 +1,5 @@
1
+ export declare class AdminService {
2
+ private readonly adminRepository;
3
+ constructor();
4
+ getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[]>;
5
+ }
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.AdminService = void 0;
7
+ const typedi_1 = __importDefault(require("typedi"));
8
+ const Admin_repository_1 = require("./Admin.repository");
9
+ class AdminService {
10
+ constructor() {
11
+ this.adminRepository = typedi_1.default.get(Admin_repository_1.AdminRepository);
12
+ }
13
+ async getZonesByAccessGroupIds(accessGroupIds) {
14
+ return await this.adminRepository.getZonesByAccessGroupIds(accessGroupIds);
15
+ }
16
+ }
17
+ exports.AdminService = AdminService;
@@ -0,0 +1 @@
1
+ export * from "./Admin.service";
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./Admin.service"), exports);
@@ -14,6 +14,7 @@ export type IConfig = {
14
14
  ENERGY_SERVICE?: string;
15
15
  INTERNAL_EVENT_HANDLER: IInternalEvent;
16
16
  LOGGER: ILogger;
17
+ CLOUD_SERVICE_API_KEY?: string;
17
18
  [key: string]: any;
18
19
  };
19
20
  export {};
@@ -1,6 +1,8 @@
1
1
  export declare const CONNECTION_PROVIDERS: {
2
2
  readonly DEVICETHREAD: "Devicethread";
3
3
  readonly CLOUDBEDS: "Cloudbeds";
4
+ readonly STAYNTOUCH: "Stayntouch";
5
+ readonly HOTELKEY: "Hotelkey";
4
6
  readonly SALTOKS: "SaltoKS";
5
7
  readonly SCHLAGE: "Schlage";
6
8
  readonly SENSIBO: "Sensibo";
@@ -4,6 +4,8 @@ exports.CONNECTION_PROVIDERS = void 0;
4
4
  exports.CONNECTION_PROVIDERS = {
5
5
  DEVICETHREAD: "Devicethread",
6
6
  CLOUDBEDS: "Cloudbeds",
7
+ STAYNTOUCH: "Stayntouch",
8
+ HOTELKEY: "Hotelkey",
7
9
  SALTOKS: "SaltoKS",
8
10
  SCHLAGE: "Schlage",
9
11
  SENSIBO: "Sensibo",
@@ -1,21 +1,80 @@
1
1
  "use strict";
2
+ var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
3
+ function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
4
+ var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
5
+ var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
6
+ var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
7
+ var _, done = false;
8
+ for (var i = decorators.length - 1; i >= 0; i--) {
9
+ var context = {};
10
+ for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
11
+ for (var p in contextIn.access) context.access[p] = contextIn.access[p];
12
+ context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
13
+ var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
14
+ if (kind === "accessor") {
15
+ if (result === void 0) continue;
16
+ if (result === null || typeof result !== "object") throw new TypeError("Object expected");
17
+ if (_ = accept(result.get)) descriptor.get = _;
18
+ if (_ = accept(result.set)) descriptor.set = _;
19
+ if (_ = accept(result.init)) initializers.unshift(_);
20
+ }
21
+ else if (_ = accept(result)) {
22
+ if (kind === "field") initializers.unshift(_);
23
+ else descriptor[key] = _;
24
+ }
25
+ }
26
+ if (target) Object.defineProperty(target, contextIn.name, descriptor);
27
+ done = true;
28
+ };
29
+ var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
30
+ var useValue = arguments.length > 2;
31
+ for (var i = 0; i < initializers.length; i++) {
32
+ value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
33
+ }
34
+ return useValue ? value : void 0;
35
+ };
36
+ var __setFunctionName = (this && this.__setFunctionName) || function (f, name, prefix) {
37
+ if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
38
+ return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
39
+ };
40
+ var __importDefault = (this && this.__importDefault) || function (mod) {
41
+ return (mod && mod.__esModule) ? mod : { "default": mod };
42
+ };
2
43
  Object.defineProperty(exports, "__esModule", { value: true });
3
44
  exports.DeviceFactory = void 0;
4
45
  const Device_service_1 = require("../../local/services/Device.service");
5
- class DeviceFactory {
6
- constructor() {
7
- this.localDeviceService = new Device_service_1.LocalDeviceService();
8
- }
9
- async getDevice(deviceId) {
10
- try {
11
- return await this.localDeviceService.getDevice(deviceId);
46
+ const typedi_1 = __importDefault(require("typedi"));
47
+ const typedi_2 = require("typedi");
48
+ let DeviceFactory = (() => {
49
+ let _classDecorators = [(0, typedi_2.Service)()];
50
+ let _classDescriptor;
51
+ let _classExtraInitializers = [];
52
+ let _classThis;
53
+ var DeviceFactory = _classThis = class {
54
+ constructor() {
55
+ // Use dependency injection instead of creating new instance
56
+ this.localDeviceService = typedi_1.default.get(Device_service_1.LocalDeviceService);
12
57
  }
13
- catch (error) {
14
- // Log the error for debugging purposes
15
- console.error(`DeviceFactory: Failed to get device ${deviceId}:`, error);
16
- // Re-throw the error with additional context
17
- throw new Error(`DeviceFactory: Unable to retrieve device ${deviceId}. ${error instanceof Error ? error.message : "Unknown error occurred"}`);
58
+ async getDevice(deviceId) {
59
+ try {
60
+ return await this.localDeviceService.getDevice(deviceId);
61
+ }
62
+ catch (error) {
63
+ // Log the error for debugging purposes
64
+ console.error(`DeviceFactory: Failed to get device ${deviceId}:`, error);
65
+ // Re-throw the error with additional context
66
+ throw new Error(`DeviceFactory: Unable to retrieve device ${deviceId}. ${error instanceof Error ? error.message : "Unknown error occurred"}`);
67
+ }
18
68
  }
19
- }
20
- }
69
+ };
70
+ __setFunctionName(_classThis, "DeviceFactory");
71
+ (() => {
72
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
73
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
74
+ DeviceFactory = _classThis = _classDescriptor.value;
75
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
76
+ __runInitializers(_classThis, _classExtraInitializers);
77
+ })();
78
+ return DeviceFactory = _classThis;
79
+ })();
21
80
  exports.DeviceFactory = DeviceFactory;