dt-common-device 2.0.7 → 3.0.1
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/README.md +352 -98
- package/dist/alerts/Alert.model.d.ts +28 -0
- package/dist/alerts/Alert.model.js +222 -0
- package/dist/alerts/Alert.repository.d.ts +106 -0
- package/dist/alerts/Alert.repository.js +374 -0
- package/dist/alerts/Alert.service.d.ts +137 -0
- package/dist/alerts/Alert.service.js +476 -0
- package/dist/alerts/AlertBuilder.d.ts +87 -0
- package/dist/alerts/AlertBuilder.example.d.ts +11 -0
- package/dist/alerts/AlertBuilder.example.js +117 -0
- package/dist/alerts/AlertBuilder.js +185 -0
- package/dist/alerts/AlertService.example.d.ts +55 -0
- package/dist/alerts/AlertService.example.js +148 -0
- package/dist/alerts/alert.types.d.ts +57 -0
- package/dist/alerts/alert.types.js +22 -0
- package/dist/alerts/index.d.ts +3 -0
- package/dist/alerts/index.js +19 -0
- package/dist/config/config.d.ts +4 -4
- package/dist/config/config.js +3 -3
- package/dist/config/config.types.d.ts +19 -0
- package/dist/config/config.types.js +2 -0
- package/dist/connection/Connection.repository.d.ts +8 -0
- package/dist/connection/Connection.repository.js +92 -0
- package/dist/connection/Connection.service.d.ts +8 -0
- package/dist/connection/Connection.service.js +32 -0
- package/dist/connection/IConnection.d.ts +26 -0
- package/dist/connection/IConnection.js +14 -0
- package/dist/connection/index.d.ts +2 -0
- package/dist/connection/index.js +18 -0
- package/dist/device/cloud/entities/CloudDevice.d.ts +2 -2
- package/dist/device/cloud/entities/CloudDeviceService.d.ts +1 -1
- package/dist/device/cloud/entities/DeviceFactory.d.ts +1 -1
- package/dist/device/cloud/entities/DeviceFactory.js +1 -1
- package/dist/device/cloud/interface.d.ts +101 -0
- package/dist/device/cloud/interface.js +3 -0
- package/dist/device/cloud/interfaces/ICloudDeviceService.d.ts +1 -1
- package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +7 -0
- package/dist/device/cloud/interfaces/IDeviceConnectionService.js +3 -0
- package/dist/device/cloud/interfaces/IDevicesService.d.ts +9 -0
- package/dist/device/cloud/interfaces/IDevicesService.js +2 -0
- package/dist/device/cloud/interfaces/IRawDevice.d.ts +1 -1
- package/dist/device/cloud/services/Device.service.d.ts +39 -0
- package/dist/device/cloud/services/Device.service.js +9 -0
- package/dist/device/cloud/services/DeviceCloudService.d.ts +42 -0
- package/dist/device/cloud/services/DeviceCloudService.js +59 -0
- package/dist/device/cloud/services/DeviceHub.service.d.ts +3 -0
- package/dist/device/cloud/services/DeviceHub.service.js +6 -0
- package/dist/device/cloud/services/Hub.service.d.ts +25 -0
- package/dist/device/cloud/services/Hub.service.js +9 -0
- package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +38 -0
- package/dist/device/cloud/services/SmartThingsDeviceService.js +52 -0
- package/dist/device/index.d.ts +4 -0
- package/dist/device/index.js +20 -0
- package/dist/device/local/events/EventHandler.js +6 -6
- package/dist/device/local/events/Events.d.ts +12 -33
- package/dist/device/local/events/Events.js +12 -33
- package/dist/device/local/interface.d.ts +0 -0
- package/dist/device/local/interface.js +1 -0
- package/dist/device/local/interfaces/index.d.ts +2 -3
- package/dist/device/local/interfaces/index.js +2 -3
- package/dist/device/local/repository/Device.repository.js +3 -3
- package/dist/device/local/repository/Hub.repository.js +4 -4
- package/dist/device/local/repository/Schedule.repository.js +2 -2
- package/dist/device/local/services/Device.service.d.ts +2 -2
- package/dist/device/local/services/Device.service.js +1 -1
- package/dist/device/local/services/DeviceHub.service.d.ts +11 -0
- package/dist/device/local/services/DeviceHub.service.js +40 -0
- package/dist/device/local/services/index.d.ts +0 -4
- package/dist/device/local/services/index.js +0 -4
- package/dist/events/BaseEventHandler.d.ts +2 -2
- package/dist/events/BaseEventHandler.js +2 -2
- package/dist/events/BaseEventTransformer.d.ts +1 -1
- package/dist/events/BaseEventTransformer.js +1 -1
- package/dist/events/DeviceEventHandler.d.ts +1 -1
- package/dist/events/DeviceEventHandler.js +2 -2
- package/dist/events/EventHandler.js +1 -1
- package/dist/events/EventHandlerOrchestrator.js +1 -1
- package/dist/events/EventProcessingService.js +1 -1
- package/dist/events/InternalEventSubscription.js +1 -1
- package/dist/index.d.ts +7 -5
- package/dist/index.js +16 -13
- package/dist/issues/Issue.model.d.ts +28 -0
- package/dist/issues/Issue.model.js +260 -0
- package/dist/issues/Issue.repository.d.ts +113 -0
- package/dist/issues/Issue.repository.js +401 -0
- package/dist/issues/Issue.service.d.ts +168 -0
- package/dist/issues/Issue.service.js +642 -0
- package/dist/issues/IssueBuilder.d.ts +109 -0
- package/dist/issues/IssueBuilder.example.d.ts +16 -0
- package/dist/issues/IssueBuilder.example.js +196 -0
- package/dist/issues/IssueBuilder.js +237 -0
- package/dist/issues/IssueService.example.d.ts +68 -0
- package/dist/issues/IssueService.example.js +177 -0
- package/dist/issues/index.d.ts +2 -0
- package/dist/issues/index.js +18 -0
- package/dist/issues/issue.types.d.ts +90 -0
- package/dist/issues/issue.types.js +40 -0
- package/dist/property/IProperty.d.ts +29 -0
- package/dist/property/IProperty.js +2 -0
- package/dist/property/Property.repository.d.ts +8 -0
- package/dist/property/Property.repository.js +95 -0
- package/dist/property/Property.service.d.ts +8 -0
- package/dist/property/Property.service.js +36 -0
- package/dist/property/index.d.ts +2 -0
- package/dist/property/index.js +18 -0
- package/dist/queue/entities/HybridHttpQueue.d.ts +24 -0
- package/dist/queue/entities/HybridHttpQueue.js +241 -0
- package/dist/queue/entities/index.d.ts +1 -0
- package/dist/queue/entities/index.js +17 -0
- package/dist/queue/index.d.ts +5 -0
- package/dist/queue/index.js +22 -0
- package/dist/queue/interfaces/IHttpRequestJob.d.ts +9 -0
- package/dist/queue/interfaces/IHttpRequestJob.js +2 -0
- package/dist/queue/interfaces/IHybridHttpQueue.d.ts +17 -0
- package/dist/queue/interfaces/IHybridHttpQueue.js +2 -0
- package/dist/queue/interfaces/IJobResult.d.ts +14 -0
- package/dist/queue/interfaces/IJobResult.js +2 -0
- package/dist/queue/interfaces/IRateLimitConfig.d.ts +5 -0
- package/dist/queue/interfaces/IRateLimitConfig.js +2 -0
- package/dist/queue/interfaces/index.d.ts +4 -0
- package/dist/queue/interfaces/index.js +20 -0
- package/dist/queue/services/QueueService.d.ts +19 -0
- package/dist/queue/services/QueueService.js +73 -0
- package/dist/queue/services/index.d.ts +1 -0
- package/dist/queue/services/index.js +17 -0
- package/dist/queue/types/http.types.d.ts +21 -0
- package/dist/queue/types/http.types.js +2 -0
- package/dist/queue/types/index.d.ts +2 -0
- package/dist/queue/types/index.js +18 -0
- package/dist/queue/types/queue.types.d.ts +31 -0
- package/dist/queue/types/queue.types.js +2 -0
- package/dist/queue/utils/index.d.ts +3 -0
- package/dist/queue/utils/index.js +19 -0
- package/dist/queue/utils/jobUtils.d.ts +10 -0
- package/dist/queue/utils/jobUtils.js +64 -0
- package/dist/queue/utils/queueUtils.d.ts +5 -0
- package/dist/queue/utils/queueUtils.js +60 -0
- package/dist/queue/utils/rateLimit.utils.d.ts +10 -0
- package/dist/queue/utils/rateLimit.utils.js +97 -0
- package/package.json +2 -1
- package/src/{device/local/models → alerts}/Alert.model.ts +1 -1
- package/src/{device/local/repository → alerts}/Alert.repository.ts +2 -2
- package/src/{device/local/services → alerts}/Alert.service.ts +14 -7
- package/src/{device/local/entities → alerts}/AlertBuilder.example.ts +2 -2
- package/src/{device/local/entities → alerts}/AlertBuilder.ts +14 -8
- package/src/{device/local/services → alerts}/AlertService.example.ts +6 -5
- package/src/{types → alerts}/alert.types.ts +2 -2
- package/src/alerts/index.ts +3 -0
- package/src/config/config.ts +7 -7
- package/src/{types → config}/config.types.ts +1 -1
- package/src/{device/local/repository → connection}/Connection.repository.ts +2 -2
- package/src/{device/local/services → connection}/Connection.service.ts +2 -2
- package/src/connection/index.ts +3 -0
- package/src/device/cloud/entities/CloudDevice.ts +2 -2
- package/src/device/cloud/entities/CloudDeviceService.ts +1 -1
- package/src/device/cloud/entities/DeviceFactory.ts +2 -2
- package/src/device/cloud/interfaces/ICloudDeviceService.ts +1 -1
- package/src/device/cloud/interfaces/IRawDevice.ts +1 -1
- package/src/device/local/interfaces/index.ts +2 -3
- package/src/device/local/repository/Device.repository.ts +3 -3
- package/src/device/local/repository/Hub.repository.ts +4 -4
- package/src/device/local/repository/Schedule.repository.ts +2 -2
- package/src/device/local/services/Device.service.ts +1 -1
- package/src/device/local/services/index.ts +0 -4
- package/{TROUBLESHOOTING.md → src/docs/TROUBLESHOOTING.md} +2 -2
- package/src/events/BaseEventHandler.ts +3 -3
- package/src/events/BaseEventTransformer.ts +2 -2
- package/src/events/DeviceEventHandler.ts +3 -3
- package/src/events/EventHandler.ts +1 -1
- package/src/events/EventHandlerOrchestrator.ts +2 -2
- package/src/events/EventProcessingService.ts +2 -2
- package/src/events/InternalEventSubscription.ts +2 -2
- package/src/index.ts +19 -13
- package/src/{device/local/models → issues}/Issue.model.ts +1 -1
- package/src/{device/local/repository → issues}/Issue.repository.ts +2 -2
- package/src/{device/local/services → issues}/Issue.service.ts +4 -4
- package/src/{device/local/entities → issues}/IssueBuilder.example.ts +1 -1
- package/src/{device/local/entities → issues}/IssueBuilder.ts +1 -1
- package/src/{device/local/services → issues}/IssueService.example.ts +6 -5
- package/src/issues/index.ts +2 -0
- package/src/{device/local/repository → property}/Property.repository.ts +2 -2
- package/src/{device/local/services → property}/Property.service.ts +1 -1
- package/src/property/index.ts +2 -0
- package/src/queue/entities/HybridHttpQueue.ts +272 -0
- package/src/queue/entities/index.ts +1 -0
- package/src/queue/index.ts +6 -0
- package/src/queue/interfaces/IHttpRequestJob.ts +10 -0
- package/src/queue/interfaces/IHybridHttpQueue.ts +24 -0
- package/src/queue/interfaces/IJobResult.ts +15 -0
- package/src/queue/interfaces/IRateLimitConfig.ts +5 -0
- package/src/queue/interfaces/index.ts +4 -0
- package/src/queue/services/QueueService.ts +39 -0
- package/src/queue/services/index.ts +1 -0
- package/src/queue/types/http.types.ts +22 -0
- package/src/queue/types/index.ts +2 -0
- package/src/queue/types/queue.types.ts +21 -0
- package/src/queue/utils/index.ts +3 -0
- package/src/queue/utils/jobUtils.ts +80 -0
- package/src/queue/utils/queueUtils.ts +91 -0
- package/src/queue/utils/rateLimit.utils.ts +131 -0
- package/tsconfig.json +4 -0
- package/src/device/local/entities/README.md +0 -173
- package/src/device/local/entities/index.ts +0 -2
- package/src/types/index.ts +0 -3
- /package/src/{device/local/interfaces → connection}/IConnection.ts +0 -0
- /package/src/{device/local/models → docs}/Alert.model.md +0 -0
- /package/src/{device/local/models/README.md → docs/Alerts&IssuesModel.md} +0 -0
- /package/src/{device/local/models → docs}/Issue.model.md +0 -0
- /package/{SECURITY.md → src/docs/SECURITY.md} +0 -0
- /package/src/{types → issues}/issue.types.ts +0 -0
- /package/src/{device/local/interfaces → property}/IProperty.ts +0 -0
|
@@ -0,0 +1,19 @@
|
|
|
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("./Alert.service"), exports);
|
|
18
|
+
__exportStar(require("./AlertBuilder"), exports);
|
|
19
|
+
__exportStar(require("./alert.types"), exports);
|
package/dist/config/config.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
export declare function initialize(cfg:
|
|
4
|
-
export declare function getConfig():
|
|
1
|
+
import { InternalEventSubscription } from "src/events";
|
|
2
|
+
import { IConfig } from "./config.types";
|
|
3
|
+
export declare function initialize(cfg: IConfig): Promise<void>;
|
|
4
|
+
export declare function getConfig(): IConfig;
|
|
5
5
|
export declare function getEventSubscription(): InternalEventSubscription | null;
|
|
6
6
|
export declare function checkRequiredEnv(): void;
|
|
7
7
|
export declare function ensureAuditInitialized(): void;
|
package/dist/config/config.js
CHANGED
|
@@ -13,10 +13,10 @@ exports.getMongoUri = getMongoUri;
|
|
|
13
13
|
exports.getRedisDbHostAndPort = getRedisDbHostAndPort;
|
|
14
14
|
exports.shutdown = shutdown;
|
|
15
15
|
const dt_audit_library_1 = require("dt-audit-library");
|
|
16
|
-
const db_1 = require("
|
|
16
|
+
const db_1 = require("src/db/db");
|
|
17
17
|
const dotenv_1 = __importDefault(require("dotenv"));
|
|
18
|
-
const events_1 = require("
|
|
19
|
-
const http_utils_1 = require("
|
|
18
|
+
const events_1 = require("src/events");
|
|
19
|
+
const http_utils_1 = require("src/utils/http.utils");
|
|
20
20
|
dotenv_1.default.config();
|
|
21
21
|
let config = null;
|
|
22
22
|
let auditInitialized = false;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { IInternalEvent } from "../events/interfaces/IInternalEvent";
|
|
2
|
+
export interface ILogger {
|
|
3
|
+
info(message: string, ...args: any[]): void;
|
|
4
|
+
warn(message: string, ...args: any[]): void;
|
|
5
|
+
error(message: string, ...args: any[]): void;
|
|
6
|
+
}
|
|
7
|
+
type AllowedSource = "ACCESS_SERVICE" | "ADMIN_SERVICE" | "ENERGY_SERVICE";
|
|
8
|
+
export type IConfig = {
|
|
9
|
+
SOURCE: AllowedSource;
|
|
10
|
+
SQS_QUEUE_URL: string;
|
|
11
|
+
DEVICE_SERVICE?: string;
|
|
12
|
+
ADMIN_SERVICE?: string;
|
|
13
|
+
ACCESS_SERVICE?: string;
|
|
14
|
+
ENERGY_SERVICE?: string;
|
|
15
|
+
INTERNAL_EVENT_HANDLER: IInternalEvent;
|
|
16
|
+
LOGGER: ILogger;
|
|
17
|
+
[key: string]: any;
|
|
18
|
+
};
|
|
19
|
+
export {};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { IConnection } from "./IConnection";
|
|
2
|
+
export declare class ConnectionRepository {
|
|
3
|
+
private readonly pool;
|
|
4
|
+
constructor();
|
|
5
|
+
createConnection(data: Partial<IConnection>): Promise<IConnection>;
|
|
6
|
+
getConnectionById(connectionId: string): Promise<IConnection>;
|
|
7
|
+
updateConnection(connectionId: string, data: Partial<IConnection>): Promise<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
41
|
+
exports.ConnectionRepository = void 0;
|
|
42
|
+
const db_1 = require("src/db");
|
|
43
|
+
const typedi_1 = require("typedi");
|
|
44
|
+
let ConnectionRepository = (() => {
|
|
45
|
+
let _classDecorators = [(0, typedi_1.Service)()];
|
|
46
|
+
let _classDescriptor;
|
|
47
|
+
let _classExtraInitializers = [];
|
|
48
|
+
let _classThis;
|
|
49
|
+
var ConnectionRepository = _classThis = class {
|
|
50
|
+
constructor() {
|
|
51
|
+
this.pool = (0, db_1.getPostgresClient)();
|
|
52
|
+
}
|
|
53
|
+
async createConnection(data) {
|
|
54
|
+
const result = await this.pool.query('INSERT INTO dt_connections ("connectionName", "connectionRefId", "propertyId", "connectionProvider", "accessToken", "refreshToken", "clientId", "clientSecret", "isActive", "metaData") VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10) RETURNING *', [
|
|
55
|
+
data.connectionName,
|
|
56
|
+
data.connectionRefId,
|
|
57
|
+
data.propertyId,
|
|
58
|
+
data.connectionProvider,
|
|
59
|
+
data.accessToken,
|
|
60
|
+
data.refreshToken,
|
|
61
|
+
data.clientId,
|
|
62
|
+
data.clientSecret,
|
|
63
|
+
data.isActive,
|
|
64
|
+
data.metaData,
|
|
65
|
+
]);
|
|
66
|
+
return result.rows[0];
|
|
67
|
+
}
|
|
68
|
+
async getConnectionById(connectionId) {
|
|
69
|
+
const result = await this.pool.query("SELECT * FROM dt_connections WHERE id = $1", [connectionId]);
|
|
70
|
+
return result.rows[0];
|
|
71
|
+
}
|
|
72
|
+
async updateConnection(connectionId, data) {
|
|
73
|
+
// Build dynamic SET clause with quoted column names
|
|
74
|
+
const setClause = Object.keys(data)
|
|
75
|
+
.map((key, index) => `"${key}" = $${index + 2}`)
|
|
76
|
+
.join(", ");
|
|
77
|
+
const values = Object.values(data);
|
|
78
|
+
const result = await this.pool.query(`UPDATE dt_connections SET ${setClause}, "updatedAt" = NOW() WHERE id = $1 RETURNING *`, [connectionId, ...values]);
|
|
79
|
+
return result.rows[0];
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
__setFunctionName(_classThis, "ConnectionRepository");
|
|
83
|
+
(() => {
|
|
84
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
85
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
86
|
+
ConnectionRepository = _classThis = _classDescriptor.value;
|
|
87
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
88
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
89
|
+
})();
|
|
90
|
+
return ConnectionRepository = _classThis;
|
|
91
|
+
})();
|
|
92
|
+
exports.ConnectionRepository = ConnectionRepository;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { IConnection } from "./IConnection";
|
|
2
|
+
export declare class LocalConnectionService {
|
|
3
|
+
private readonly connectionRepository;
|
|
4
|
+
constructor();
|
|
5
|
+
createConnection(data: Partial<IConnection>): Promise<IConnection>;
|
|
6
|
+
getConnection(connectionId: string): Promise<IConnection>;
|
|
7
|
+
updateConnection(connectionId: string, data: Partial<IConnection>): Promise<IConnection>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LocalConnectionService = void 0;
|
|
4
|
+
const typedi_1 = require("typedi");
|
|
5
|
+
const Connection_repository_1 = require("./Connection.repository");
|
|
6
|
+
class LocalConnectionService {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.connectionRepository = typedi_1.Container.get(Connection_repository_1.ConnectionRepository);
|
|
9
|
+
}
|
|
10
|
+
async createConnection(data) {
|
|
11
|
+
if (!data.connectionName ||
|
|
12
|
+
!data.connectionRefId ||
|
|
13
|
+
!data.propertyId ||
|
|
14
|
+
!data.connectionProvider) {
|
|
15
|
+
throw new Error("Missing required fields");
|
|
16
|
+
}
|
|
17
|
+
return await this.connectionRepository.createConnection(data);
|
|
18
|
+
}
|
|
19
|
+
async getConnection(connectionId) {
|
|
20
|
+
if (!connectionId) {
|
|
21
|
+
throw new Error("Connection ID is required");
|
|
22
|
+
}
|
|
23
|
+
return await this.connectionRepository.getConnectionById(connectionId);
|
|
24
|
+
}
|
|
25
|
+
async updateConnection(connectionId, data) {
|
|
26
|
+
if (!connectionId) {
|
|
27
|
+
throw new Error("Connection ID is required");
|
|
28
|
+
}
|
|
29
|
+
return await this.connectionRepository.updateConnection(connectionId, data);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.LocalConnectionService = LocalConnectionService;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export interface IConnection {
|
|
2
|
+
id?: string;
|
|
3
|
+
createdAt?: Date;
|
|
4
|
+
updatedAt?: Date;
|
|
5
|
+
isDeleted?: boolean;
|
|
6
|
+
connectionName: string;
|
|
7
|
+
connectionRefId: string;
|
|
8
|
+
propertyId: string;
|
|
9
|
+
connectionProvider: ConnectionProvider;
|
|
10
|
+
accessToken?: string;
|
|
11
|
+
refreshToken?: string;
|
|
12
|
+
clientId?: string;
|
|
13
|
+
clientSecret: string;
|
|
14
|
+
isActive?: boolean;
|
|
15
|
+
metaData?: any;
|
|
16
|
+
}
|
|
17
|
+
export declare enum ConnectionProvider {
|
|
18
|
+
Smartthings = "Smartthings",
|
|
19
|
+
SaltoKS = "SaltoKS",
|
|
20
|
+
TTLock = "TTLock",
|
|
21
|
+
Tuya = "Tuya",
|
|
22
|
+
Schlage = "Schlage",
|
|
23
|
+
YaleWifi = "YaleWifi",
|
|
24
|
+
Sensibo = "Sensibo",
|
|
25
|
+
Devicethread = "Devicethread"
|
|
26
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ConnectionProvider = void 0;
|
|
4
|
+
var ConnectionProvider;
|
|
5
|
+
(function (ConnectionProvider) {
|
|
6
|
+
ConnectionProvider["Smartthings"] = "Smartthings";
|
|
7
|
+
ConnectionProvider["SaltoKS"] = "SaltoKS";
|
|
8
|
+
ConnectionProvider["TTLock"] = "TTLock";
|
|
9
|
+
ConnectionProvider["Tuya"] = "Tuya";
|
|
10
|
+
ConnectionProvider["Schlage"] = "Schlage";
|
|
11
|
+
ConnectionProvider["YaleWifi"] = "YaleWifi";
|
|
12
|
+
ConnectionProvider["Sensibo"] = "Sensibo";
|
|
13
|
+
ConnectionProvider["Devicethread"] = "Devicethread";
|
|
14
|
+
})(ConnectionProvider || (exports.ConnectionProvider = ConnectionProvider = {}));
|
|
@@ -0,0 +1,18 @@
|
|
|
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("./IConnection"), exports);
|
|
18
|
+
__exportStar(require("./Connection.service"), exports);
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { IDevice } from "
|
|
1
|
+
import { IDevice } from "src/device/local/interfaces";
|
|
2
2
|
import { ICloudDevice } from "../interfaces/ICloudDevice";
|
|
3
3
|
import { ICloudDeviceService } from "../interfaces/ICloudDeviceService";
|
|
4
|
-
import { IConnection } from "
|
|
4
|
+
import { IConnection } from "src/connection";
|
|
5
5
|
export declare abstract class CloudDevice implements ICloudDevice {
|
|
6
6
|
deviceId: string;
|
|
7
7
|
localDevice?: IDevice;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ICloudDeviceService } from "../interfaces/ICloudDeviceService";
|
|
2
|
-
import { IConnection } from "
|
|
2
|
+
import { IConnection } from "src/connection";
|
|
3
3
|
export declare class CloudDeviceService implements ICloudDeviceService {
|
|
4
4
|
getConnection(deviceId: string): Promise<IConnection>;
|
|
5
5
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IDevice } from "
|
|
1
|
+
import { IDevice } from "src/device/local/interfaces";
|
|
2
2
|
import { IDeviceFactory } from "../interfaces/IDeviceFactory";
|
|
3
3
|
export declare class DeviceFactory implements IDeviceFactory {
|
|
4
4
|
private readonly localDeviceService;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.DeviceFactory = void 0;
|
|
4
|
-
const Device_service_1 = require("
|
|
4
|
+
const Device_service_1 = require("src/device/local/services/Device.service");
|
|
5
5
|
class DeviceFactory {
|
|
6
6
|
constructor() {
|
|
7
7
|
this.localDeviceService = new Device_service_1.LocalDeviceService();
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { IConnection, IConnectionConnectParams, IDevice, IDeviceAccountResponse, IDeviceCommand, ISmartthingsDeviceCommand, ICommandResponse } from "./types";
|
|
2
|
+
/**
|
|
3
|
+
* Class interface for device cloud operations and connection management
|
|
4
|
+
*/
|
|
5
|
+
export interface IDeviceCloudService {
|
|
6
|
+
/**
|
|
7
|
+
* Creates a new connection for device management
|
|
8
|
+
* @param data - Connection data
|
|
9
|
+
* @param userId - User identifier
|
|
10
|
+
* @returns Promise with connection result
|
|
11
|
+
*/
|
|
12
|
+
createConnection(data: IConnection, userId: string): Promise<any>;
|
|
13
|
+
/**
|
|
14
|
+
* Gets device account information for a connection
|
|
15
|
+
* @param connection - Connection object
|
|
16
|
+
* @returns Promise with device account response
|
|
17
|
+
*/
|
|
18
|
+
getDeviceAccount(connection: IConnection): Promise<IDeviceAccountResponse>;
|
|
19
|
+
/**
|
|
20
|
+
* Gets all devices for a connection
|
|
21
|
+
* @param connection - Connection object
|
|
22
|
+
* @returns Promise with array of devices
|
|
23
|
+
*/
|
|
24
|
+
getDevices(connection: IConnection): Promise<IDevice[]>;
|
|
25
|
+
/**
|
|
26
|
+
* Filters devices based on connection and device list
|
|
27
|
+
* @param connection - Connection object
|
|
28
|
+
* @param devices - Array of devices to filter
|
|
29
|
+
* @returns Promise with filtered devices
|
|
30
|
+
*/
|
|
31
|
+
filterDevices(connection: IConnection, devices: any[]): Promise<IDevice[]>;
|
|
32
|
+
/**
|
|
33
|
+
* Connects to a device service
|
|
34
|
+
* @param connection - Connection object
|
|
35
|
+
* @param connectionConnect - Connection parameters
|
|
36
|
+
* @returns Promise with connection result
|
|
37
|
+
*/
|
|
38
|
+
connect(connection: IConnection, connectionConnect: IConnectionConnectParams): Promise<any>;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Interface for device command operations
|
|
42
|
+
*/
|
|
43
|
+
export interface IDeviceCommandManager {
|
|
44
|
+
/**
|
|
45
|
+
* Invokes a command on a device
|
|
46
|
+
* @param command - Device command to execute
|
|
47
|
+
* @param deviceId - Device identifier
|
|
48
|
+
* @returns Promise with command response
|
|
49
|
+
*/
|
|
50
|
+
invokeCommand(command: IDeviceCommand, deviceId: string): Promise<ICommandResponse>;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Interface for SmartThings specific device command operations
|
|
54
|
+
*/
|
|
55
|
+
export interface ISmartthingsDeviceCommandManager extends IDeviceCommandManager {
|
|
56
|
+
/**
|
|
57
|
+
* Performs device action for SmartThings
|
|
58
|
+
* @param commands - Array of SmartThings device commands
|
|
59
|
+
* @param deviceId - Device identifier
|
|
60
|
+
* @param accessToken - Access token for authentication
|
|
61
|
+
* @returns Promise with action result
|
|
62
|
+
*/
|
|
63
|
+
performDeviceAction(commands: ISmartthingsDeviceCommand[], deviceId: string, accessToken: string): Promise<any>;
|
|
64
|
+
/**
|
|
65
|
+
* Gets device status for SmartThings
|
|
66
|
+
* @param deviceId - Device identifier
|
|
67
|
+
* @param accessToken - Access token for authentication
|
|
68
|
+
* @returns Promise with device status
|
|
69
|
+
*/
|
|
70
|
+
getDeviceStatus(deviceId: string, accessToken: string): Promise<any>;
|
|
71
|
+
/**
|
|
72
|
+
* Gets device lock status for SmartThings
|
|
73
|
+
* @param deviceId - Device identifier
|
|
74
|
+
* @param accessToken - Access token for authentication
|
|
75
|
+
* @returns Promise with lock status
|
|
76
|
+
*/
|
|
77
|
+
getDeviceLockStatus(deviceId: string, accessToken: string): Promise<any>;
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Interface for device command factory
|
|
81
|
+
*/
|
|
82
|
+
export interface IDeviceCommandManagerFactory {
|
|
83
|
+
/**
|
|
84
|
+
* Creates a device command manager for a specific connection provider
|
|
85
|
+
* @param connectionProvider - Connection provider type
|
|
86
|
+
* @param connection - Connection object
|
|
87
|
+
* @returns Device command manager instance
|
|
88
|
+
*/
|
|
89
|
+
createDeviceCommandManager(connectionProvider: string, connection: IConnection): IDeviceCommandManager;
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Interface for device command classes
|
|
93
|
+
*/
|
|
94
|
+
export interface IDeviceCommandClass {
|
|
95
|
+
/**
|
|
96
|
+
* Creates a SmartThings device command from a generic device command
|
|
97
|
+
* @param deviceCommand - Generic device command
|
|
98
|
+
* @returns SmartThings device command
|
|
99
|
+
*/
|
|
100
|
+
fromDeviceCommand(deviceCommand: IDeviceCommand): ISmartthingsDeviceCommand;
|
|
101
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { IConnection, IConnectionConnectParams, IDeviceAccountResponse } from "../types";
|
|
2
|
+
export interface IDeviceConnectionService {
|
|
3
|
+
createConnection(data: IConnection, userId: string): Promise<any>;
|
|
4
|
+
getDeviceAccount(connection: IConnection): Promise<IDeviceAccountResponse>;
|
|
5
|
+
getDevices(connection: IConnection): Promise<any>;
|
|
6
|
+
connect(connection: IConnection, connectionConnect: IConnectionConnectParams): Promise<any>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { IConnection } from "../types";
|
|
2
|
+
export interface IDeviceService {
|
|
3
|
+
getDevices(connection: IConnection): Promise<Record<string, any>[]>;
|
|
4
|
+
getDevice(connectionId: string, deviceId: string): Promise<Record<string, any>>;
|
|
5
|
+
getStatus(connectionId: string, deviceId: string): Promise<string | null>;
|
|
6
|
+
getState(deviceId: string): Promise<Record<string, any>>;
|
|
7
|
+
getGateways(connectionId: string): Promise<any[] | null>;
|
|
8
|
+
getGatewayDetails(connectionId: string, gatewayId: string): Promise<any>;
|
|
9
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { IDeviceService } from "../interfaces";
|
|
2
|
+
import { IConnection, IDevice } from "../types";
|
|
3
|
+
export declare abstract class DeviceService implements IDeviceService {
|
|
4
|
+
deviceId: string;
|
|
5
|
+
propertyId: string;
|
|
6
|
+
name: string;
|
|
7
|
+
hubId: string[];
|
|
8
|
+
deviceType: {
|
|
9
|
+
id: string;
|
|
10
|
+
type: string;
|
|
11
|
+
};
|
|
12
|
+
status: {
|
|
13
|
+
online: boolean;
|
|
14
|
+
error?: {
|
|
15
|
+
type?: string;
|
|
16
|
+
message?: string;
|
|
17
|
+
};
|
|
18
|
+
lastUpdated?: string;
|
|
19
|
+
};
|
|
20
|
+
state?: Record<string, any>;
|
|
21
|
+
metaData?: Record<string, any>;
|
|
22
|
+
zone?: {
|
|
23
|
+
id: string;
|
|
24
|
+
name: string;
|
|
25
|
+
zoneType: string;
|
|
26
|
+
parentZone?: {
|
|
27
|
+
id: string;
|
|
28
|
+
name: string;
|
|
29
|
+
zoneType: string;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
connection: IConnection;
|
|
33
|
+
constructor(device: IDevice);
|
|
34
|
+
abstract getDevices(connection: IConnection): Promise<Record<string, any>[]>;
|
|
35
|
+
abstract getDevice(connectionId: string, deviceId: string): Promise<any>;
|
|
36
|
+
abstract getBattery(deviceId: string): Promise<number | string>;
|
|
37
|
+
abstract getStatus(connectionId: string, deviceId: string): Promise<string>;
|
|
38
|
+
abstract getState(deviceId: string): Promise<string>;
|
|
39
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { IDeviceCloudService } from "../interface";
|
|
2
|
+
import { IConnection, IDevice, IDeviceAccountResponse, IConnectionConnectParams } from "../types";
|
|
3
|
+
/**
|
|
4
|
+
* Device Cloud Service Class
|
|
5
|
+
* Implements IDeviceCloudService interface with empty implementations
|
|
6
|
+
* Implementation will be provided by the consuming project
|
|
7
|
+
*/
|
|
8
|
+
export declare class DeviceCloudService implements IDeviceCloudService {
|
|
9
|
+
/**
|
|
10
|
+
* Creates a new connection for device management
|
|
11
|
+
* @param data - Connection data
|
|
12
|
+
* @param userId - User identifier
|
|
13
|
+
* @returns Promise with connection result
|
|
14
|
+
*/
|
|
15
|
+
createConnection(data: IConnection, userId: string): Promise<any>;
|
|
16
|
+
/**
|
|
17
|
+
* Gets device account information for a connection
|
|
18
|
+
* @param connection - Connection object
|
|
19
|
+
* @returns Promise with device account response
|
|
20
|
+
*/
|
|
21
|
+
getDeviceAccount(connection: IConnection): Promise<IDeviceAccountResponse>;
|
|
22
|
+
/**
|
|
23
|
+
* Gets all devices for a connection
|
|
24
|
+
* @param connection - Connection object
|
|
25
|
+
* @returns Promise with array of devices
|
|
26
|
+
*/
|
|
27
|
+
getDevices(connection: IConnection): Promise<IDevice[]>;
|
|
28
|
+
/**
|
|
29
|
+
* Filters devices based on connection and device list
|
|
30
|
+
* @param connection - Connection object
|
|
31
|
+
* @param devices - Array of devices to filter
|
|
32
|
+
* @returns Promise with filtered devices
|
|
33
|
+
*/
|
|
34
|
+
filterDevices(connection: IConnection, devices: any[]): Promise<IDevice[]>;
|
|
35
|
+
/**
|
|
36
|
+
* Connects to a device service
|
|
37
|
+
* @param connection - Connection object
|
|
38
|
+
* @param connectionConnect - Connection parameters
|
|
39
|
+
* @returns Promise with connection result
|
|
40
|
+
*/
|
|
41
|
+
connect(connection: IConnection, connectionConnect: IConnectionConnectParams): Promise<any>;
|
|
42
|
+
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DeviceCloudService = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Device Cloud Service Class
|
|
6
|
+
* Implements IDeviceCloudService interface with empty implementations
|
|
7
|
+
* Implementation will be provided by the consuming project
|
|
8
|
+
*/
|
|
9
|
+
class DeviceCloudService {
|
|
10
|
+
/**
|
|
11
|
+
* Creates a new connection for device management
|
|
12
|
+
* @param data - Connection data
|
|
13
|
+
* @param userId - User identifier
|
|
14
|
+
* @returns Promise with connection result
|
|
15
|
+
*/
|
|
16
|
+
async createConnection(data, userId) {
|
|
17
|
+
// Implementation will be provided by the consuming project
|
|
18
|
+
throw new Error("createConnection method not implemented");
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Gets device account information for a connection
|
|
22
|
+
* @param connection - Connection object
|
|
23
|
+
* @returns Promise with device account response
|
|
24
|
+
*/
|
|
25
|
+
async getDeviceAccount(connection) {
|
|
26
|
+
// Implementation will be provided by the consuming project
|
|
27
|
+
throw new Error("getDeviceAccount method not implemented");
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Gets all devices for a connection
|
|
31
|
+
* @param connection - Connection object
|
|
32
|
+
* @returns Promise with array of devices
|
|
33
|
+
*/
|
|
34
|
+
async getDevices(connection) {
|
|
35
|
+
// Implementation will be provided by the consuming project
|
|
36
|
+
throw new Error("getDevices method not implemented");
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Filters devices based on connection and device list
|
|
40
|
+
* @param connection - Connection object
|
|
41
|
+
* @param devices - Array of devices to filter
|
|
42
|
+
* @returns Promise with filtered devices
|
|
43
|
+
*/
|
|
44
|
+
async filterDevices(connection, devices) {
|
|
45
|
+
// Implementation will be provided by the consuming project
|
|
46
|
+
throw new Error("filterDevices method not implemented");
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Connects to a device service
|
|
50
|
+
* @param connection - Connection object
|
|
51
|
+
* @param connectionConnect - Connection parameters
|
|
52
|
+
* @returns Promise with connection result
|
|
53
|
+
*/
|
|
54
|
+
async connect(connection, connectionConnect) {
|
|
55
|
+
// Implementation will be provided by the consuming project
|
|
56
|
+
throw new Error("connect method not implemented");
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
exports.DeviceCloudService = DeviceCloudService;
|