dt-common-device 2.0.1 → 2.0.3
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/dist/config/config.js +1 -1
- package/dist/db/redis.js +1 -0
- package/dist/device/cloud/interface.d.ts +101 -0
- package/dist/device/cloud/interface.js +3 -0
- 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/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/repository/Device.repository.js +1 -1
- package/dist/device/local/repository/Hub.repository.js +1 -1
- package/dist/device/local/repository/Schedule.repository.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/index.d.ts +1 -0
- package/dist/index.js +2 -0
- package/dist/utils/http.utils.d.ts +13 -0
- package/dist/utils/http.utils.js +117 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +18 -0
- package/dist/utils/redis.utils.d.ts +8 -0
- package/dist/utils/redis.utils.js +124 -0
- package/package.json +1 -1
- package/src/config/config.ts +1 -1
- package/src/db/redis.ts +1 -0
- package/src/device/local/repository/Device.repository.ts +1 -1
- package/src/device/local/repository/Hub.repository.ts +1 -1
- package/src/device/local/repository/Schedule.repository.ts +1 -1
- package/src/index.ts +3 -0
- package/src/utils/index.ts +2 -0
- package/src/utils/redis.utils.ts +71 -0
- /package/src/utils/{http-utils.ts → http.utils.ts} +0 -0
package/dist/config/config.js
CHANGED
|
@@ -16,7 +16,7 @@ const dt_audit_library_1 = require("dt-audit-library");
|
|
|
16
16
|
const db_1 = require("../db/db");
|
|
17
17
|
const dotenv_1 = __importDefault(require("dotenv"));
|
|
18
18
|
const events_1 = require("../events");
|
|
19
|
-
const http_utils_1 = require("../utils/http
|
|
19
|
+
const http_utils_1 = require("../utils/http.utils");
|
|
20
20
|
dotenv_1.default.config();
|
|
21
21
|
let config = null;
|
|
22
22
|
let auditInitialized = false;
|
package/dist/db/redis.js
CHANGED
|
@@ -7,6 +7,7 @@ exports.getRedisClient = getRedisClient;
|
|
|
7
7
|
const config_1 = require("../config/config");
|
|
8
8
|
const ioredis_1 = __importDefault(require("ioredis"));
|
|
9
9
|
let redisClient = null;
|
|
10
|
+
//Singleton pattern to ensure only one Redis client instance is create only once and shared across the application
|
|
10
11
|
function getRedisClient() {
|
|
11
12
|
if (!redisClient) {
|
|
12
13
|
const { host, port } = (0, config_1.getRedisDbHostAndPort)();
|
|
@@ -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;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { IHubService } from "../interfaces";
|
|
2
|
+
import { IConnection, IDevice } from "../types";
|
|
3
|
+
export declare abstract class HubService implements IHubService {
|
|
4
|
+
deviceId: string;
|
|
5
|
+
propertyId: string;
|
|
6
|
+
name: string;
|
|
7
|
+
deviceType: {
|
|
8
|
+
id: string;
|
|
9
|
+
type: string;
|
|
10
|
+
};
|
|
11
|
+
status: {
|
|
12
|
+
online: boolean;
|
|
13
|
+
error?: {
|
|
14
|
+
type?: string;
|
|
15
|
+
message?: string;
|
|
16
|
+
};
|
|
17
|
+
lastUpdated?: string;
|
|
18
|
+
};
|
|
19
|
+
metaData?: Record<string, any>;
|
|
20
|
+
connection: IConnection;
|
|
21
|
+
constructor(hub: IDevice);
|
|
22
|
+
abstract getHubs(connectionId: string): Promise<any[] | null>;
|
|
23
|
+
abstract getHub(connectionId: string, hubId: string): Promise<Record<string, any>>;
|
|
24
|
+
abstract getStatus(connectionId: string, hubId: string): Promise<string>;
|
|
25
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { ISmartthingsDeviceCommandManager } from "../interface";
|
|
2
|
+
import { IDeviceCommand, ISmartthingsDeviceCommand, ICommandResponse } from "../types";
|
|
3
|
+
/**
|
|
4
|
+
* SmartThings Device Service Class
|
|
5
|
+
* Implements ISmartthingsDeviceCommandManager interface with empty implementations
|
|
6
|
+
* Implementation will be provided by the consuming project
|
|
7
|
+
*/
|
|
8
|
+
export declare class SmartThingsDeviceService implements ISmartthingsDeviceCommandManager {
|
|
9
|
+
/**
|
|
10
|
+
* Invokes a command on a device
|
|
11
|
+
* @param command - Device command to execute
|
|
12
|
+
* @param deviceId - Device identifier
|
|
13
|
+
* @returns Promise with command response
|
|
14
|
+
*/
|
|
15
|
+
invokeCommand(command: IDeviceCommand, deviceId: string): Promise<ICommandResponse>;
|
|
16
|
+
/**
|
|
17
|
+
* Performs device action for SmartThings
|
|
18
|
+
* @param commands - Array of SmartThings device commands
|
|
19
|
+
* @param deviceId - Device identifier
|
|
20
|
+
* @param accessToken - Access token for authentication
|
|
21
|
+
* @returns Promise with action result
|
|
22
|
+
*/
|
|
23
|
+
performDeviceAction(commands: ISmartthingsDeviceCommand[], deviceId: string, accessToken: string): Promise<any>;
|
|
24
|
+
/**
|
|
25
|
+
* Gets device status for SmartThings
|
|
26
|
+
* @param deviceId - Device identifier
|
|
27
|
+
* @param accessToken - Access token for authentication
|
|
28
|
+
* @returns Promise with device status
|
|
29
|
+
*/
|
|
30
|
+
getDeviceStatus(deviceId: string, accessToken: string): Promise<any>;
|
|
31
|
+
/**
|
|
32
|
+
* Gets device lock status for SmartThings
|
|
33
|
+
* @param deviceId - Device identifier
|
|
34
|
+
* @param accessToken - Access token for authentication
|
|
35
|
+
* @returns Promise with lock status
|
|
36
|
+
*/
|
|
37
|
+
getDeviceLockStatus(deviceId: string, accessToken: string): Promise<any>;
|
|
38
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SmartThingsDeviceService = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* SmartThings Device Service Class
|
|
6
|
+
* Implements ISmartthingsDeviceCommandManager interface with empty implementations
|
|
7
|
+
* Implementation will be provided by the consuming project
|
|
8
|
+
*/
|
|
9
|
+
class SmartThingsDeviceService {
|
|
10
|
+
/**
|
|
11
|
+
* Invokes a command on a device
|
|
12
|
+
* @param command - Device command to execute
|
|
13
|
+
* @param deviceId - Device identifier
|
|
14
|
+
* @returns Promise with command response
|
|
15
|
+
*/
|
|
16
|
+
async invokeCommand(command, deviceId) {
|
|
17
|
+
// Implementation will be provided by the consuming project
|
|
18
|
+
throw new Error("invokeCommand method not implemented");
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Performs device action for SmartThings
|
|
22
|
+
* @param commands - Array of SmartThings device commands
|
|
23
|
+
* @param deviceId - Device identifier
|
|
24
|
+
* @param accessToken - Access token for authentication
|
|
25
|
+
* @returns Promise with action result
|
|
26
|
+
*/
|
|
27
|
+
async performDeviceAction(commands, deviceId, accessToken) {
|
|
28
|
+
// Implementation will be provided by the consuming project
|
|
29
|
+
throw new Error("performDeviceAction method not implemented");
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Gets device status for SmartThings
|
|
33
|
+
* @param deviceId - Device identifier
|
|
34
|
+
* @param accessToken - Access token for authentication
|
|
35
|
+
* @returns Promise with device status
|
|
36
|
+
*/
|
|
37
|
+
async getDeviceStatus(deviceId, accessToken) {
|
|
38
|
+
// Implementation will be provided by the consuming project
|
|
39
|
+
throw new Error("getDeviceStatus method not implemented");
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Gets device lock status for SmartThings
|
|
43
|
+
* @param deviceId - Device identifier
|
|
44
|
+
* @param accessToken - Access token for authentication
|
|
45
|
+
* @returns Promise with lock status
|
|
46
|
+
*/
|
|
47
|
+
async getDeviceLockStatus(deviceId, accessToken) {
|
|
48
|
+
// Implementation will be provided by the consuming project
|
|
49
|
+
throw new Error("getDeviceLockStatus method not implemented");
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
exports.SmartThingsDeviceService = SmartThingsDeviceService;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// DeviceThread Common Library - Device Module
|
|
3
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
+
if (k2 === undefined) k2 = k;
|
|
5
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
+
}
|
|
9
|
+
Object.defineProperty(o, k2, desc);
|
|
10
|
+
}) : (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
o[k2] = m[k];
|
|
13
|
+
}));
|
|
14
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
16
|
+
};
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
// Export cloud device interfaces
|
|
19
|
+
__exportStar(require("./cloud/interface"), exports);
|
|
20
|
+
__exportStar(require("./cloud/types"), exports);
|
|
@@ -9,9 +9,9 @@ class EventHandler {
|
|
|
9
9
|
this.source = "dt-common-device";
|
|
10
10
|
}
|
|
11
11
|
async onDeviceCreate(body) {
|
|
12
|
-
await dt_pub_sub_1.eventDispatcher.publishEvent(Events_1.DT_EVENT_TYPES.DEVICE.
|
|
12
|
+
await dt_pub_sub_1.eventDispatcher.publishEvent(Events_1.DT_EVENT_TYPES.DEVICE.DEVICE.CREATED, body, this.source);
|
|
13
13
|
const payload = {
|
|
14
|
-
eventType: Events_1.DT_EVENT_TYPES.DEVICE.
|
|
14
|
+
eventType: Events_1.DT_EVENT_TYPES.DEVICE.DEVICE.CREATED,
|
|
15
15
|
properties: {
|
|
16
16
|
...body,
|
|
17
17
|
},
|
|
@@ -19,9 +19,9 @@ class EventHandler {
|
|
|
19
19
|
await (0, dt_audit_library_1.publishAudit)(payload);
|
|
20
20
|
}
|
|
21
21
|
async onDeviceUpdate(deviceId, body) {
|
|
22
|
-
await dt_pub_sub_1.eventDispatcher.publishEvent(Events_1.DT_EVENT_TYPES.DEVICE.
|
|
22
|
+
await dt_pub_sub_1.eventDispatcher.publishEvent(Events_1.DT_EVENT_TYPES.DEVICE.DEVICE.UPDATED, { deviceId, body }, this.source);
|
|
23
23
|
const payload = {
|
|
24
|
-
eventType: Events_1.DT_EVENT_TYPES.DEVICE.
|
|
24
|
+
eventType: Events_1.DT_EVENT_TYPES.DEVICE.DEVICE.UPDATED,
|
|
25
25
|
properties: {
|
|
26
26
|
...body,
|
|
27
27
|
},
|
|
@@ -29,9 +29,9 @@ class EventHandler {
|
|
|
29
29
|
await (0, dt_audit_library_1.publishAudit)(payload);
|
|
30
30
|
}
|
|
31
31
|
async onDeviceDelete(deviceId) {
|
|
32
|
-
await dt_pub_sub_1.eventDispatcher.publishEvent(Events_1.DT_EVENT_TYPES.DEVICE.
|
|
32
|
+
await dt_pub_sub_1.eventDispatcher.publishEvent(Events_1.DT_EVENT_TYPES.DEVICE.DEVICE.DELETED, { deviceId }, this.source);
|
|
33
33
|
const payload = {
|
|
34
|
-
eventType: Events_1.DT_EVENT_TYPES.DEVICE.
|
|
34
|
+
eventType: Events_1.DT_EVENT_TYPES.DEVICE.DEVICE.DELETED,
|
|
35
35
|
properties: {
|
|
36
36
|
deviceId,
|
|
37
37
|
},
|
|
@@ -1,16 +1,9 @@
|
|
|
1
1
|
export declare const DT_EVENT_TYPES: {
|
|
2
2
|
DEVICE: {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
UPDATE: {
|
|
8
|
-
SUCCESS: string;
|
|
9
|
-
FAILED: string;
|
|
10
|
-
};
|
|
11
|
-
DELETE: {
|
|
12
|
-
SUCCESS: string;
|
|
13
|
-
FAILED: string;
|
|
3
|
+
DEVICE: {
|
|
4
|
+
CREATED: string;
|
|
5
|
+
UPDATED: string;
|
|
6
|
+
DELETED: string;
|
|
14
7
|
};
|
|
15
8
|
STATE: {
|
|
16
9
|
SET: string;
|
|
@@ -41,31 +34,17 @@ export declare const DT_EVENT_TYPES: {
|
|
|
41
34
|
};
|
|
42
35
|
};
|
|
43
36
|
CONNECTION: {
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
UPDATE: {
|
|
49
|
-
SUCCESS: string;
|
|
50
|
-
FAILED: string;
|
|
51
|
-
};
|
|
52
|
-
DELETE: {
|
|
53
|
-
SUCCESS: string;
|
|
54
|
-
FAILED: string;
|
|
37
|
+
CONNECTION: {
|
|
38
|
+
CREATED: string;
|
|
39
|
+
UPDATED: string;
|
|
40
|
+
DELETED: string;
|
|
55
41
|
};
|
|
56
42
|
};
|
|
57
43
|
PROPERTY: {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
UPDATE: {
|
|
63
|
-
SUCCESS: string;
|
|
64
|
-
FAILED: string;
|
|
65
|
-
};
|
|
66
|
-
DELETE: {
|
|
67
|
-
SUCCESS: string;
|
|
68
|
-
FAILED: string;
|
|
44
|
+
PROPERTY: {
|
|
45
|
+
CREATED: string;
|
|
46
|
+
UPDATED: string;
|
|
47
|
+
DELETED: string;
|
|
69
48
|
};
|
|
70
49
|
PREFERENCES: {
|
|
71
50
|
UPDATED: string;
|
|
@@ -3,17 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.DT_EVENT_TYPES = void 0;
|
|
4
4
|
exports.DT_EVENT_TYPES = {
|
|
5
5
|
DEVICE: {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
UPDATE: {
|
|
11
|
-
SUCCESS: "device.update.success",
|
|
12
|
-
FAILED: "device.update.failed",
|
|
13
|
-
},
|
|
14
|
-
DELETE: {
|
|
15
|
-
SUCCESS: "device.delete.success",
|
|
16
|
-
FAILED: "device.delete.failed",
|
|
6
|
+
DEVICE: {
|
|
7
|
+
CREATED: "device.device.created",
|
|
8
|
+
UPDATED: "device.device.updated",
|
|
9
|
+
DELETED: "device.device.deleted",
|
|
17
10
|
},
|
|
18
11
|
STATE: {
|
|
19
12
|
SET: "device.state.set",
|
|
@@ -44,31 +37,17 @@ exports.DT_EVENT_TYPES = {
|
|
|
44
37
|
},
|
|
45
38
|
},
|
|
46
39
|
CONNECTION: {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
UPDATE: {
|
|
52
|
-
SUCCESS: "connection.update.success",
|
|
53
|
-
FAILED: "connection.update.failed",
|
|
54
|
-
},
|
|
55
|
-
DELETE: {
|
|
56
|
-
SUCCESS: "connection.delete.success",
|
|
57
|
-
FAILED: "connection.delete.failed",
|
|
40
|
+
CONNECTION: {
|
|
41
|
+
CREATED: "connection.connection.created",
|
|
42
|
+
UPDATED: "connection.connection.updated",
|
|
43
|
+
DELETED: "connection.connection.deleted",
|
|
58
44
|
},
|
|
59
45
|
},
|
|
60
46
|
PROPERTY: {
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
UPDATE: {
|
|
66
|
-
SUCCESS: "property.update.success",
|
|
67
|
-
FAILED: "property.update.failed",
|
|
68
|
-
},
|
|
69
|
-
DELETE: {
|
|
70
|
-
SUCCESS: "property.delete.success",
|
|
71
|
-
FAILED: "property.delete.failed",
|
|
47
|
+
PROPERTY: {
|
|
48
|
+
CREATED: "property.property.created",
|
|
49
|
+
UPDATED: "property.property.updated",
|
|
50
|
+
DELETED: "property.property.deleted",
|
|
72
51
|
},
|
|
73
52
|
PREFERENCES: {
|
|
74
53
|
UPDATED: "property.preferences.updated",
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -42,7 +42,7 @@ exports.DeviceRepository = void 0;
|
|
|
42
42
|
const config_1 = require("../../../config/config");
|
|
43
43
|
const db_1 = require("../../../db");
|
|
44
44
|
const typedi_1 = require("typedi");
|
|
45
|
-
const http_utils_1 = require("../../../utils/http
|
|
45
|
+
const http_utils_1 = require("../../../utils/http.utils");
|
|
46
46
|
let DeviceRepository = (() => {
|
|
47
47
|
let _classDecorators = [(0, typedi_1.Service)()];
|
|
48
48
|
let _classDescriptor;
|
|
@@ -42,7 +42,7 @@ exports.HubRepository = void 0;
|
|
|
42
42
|
const config_1 = require("../../../config/config");
|
|
43
43
|
const db_1 = require("../../../db");
|
|
44
44
|
const typedi_1 = require("typedi");
|
|
45
|
-
const http_utils_1 = require("../../../utils/http
|
|
45
|
+
const http_utils_1 = require("../../../utils/http.utils");
|
|
46
46
|
let HubRepository = (() => {
|
|
47
47
|
let _classDecorators = [(0, typedi_1.Service)()];
|
|
48
48
|
let _classDescriptor;
|
|
@@ -41,7 +41,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
41
41
|
exports.ScheduleRepository = void 0;
|
|
42
42
|
const typedi_1 = require("typedi");
|
|
43
43
|
const config_1 = require("../../../config/config");
|
|
44
|
-
const http_utils_1 = require("../../../utils/http
|
|
44
|
+
const http_utils_1 = require("../../../utils/http.utils");
|
|
45
45
|
let ScheduleRepository = (() => {
|
|
46
46
|
let _classDecorators = [(0, typedi_1.Service)()];
|
|
47
47
|
let _classDescriptor;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { IHubCreateParams } from "../interfaces";
|
|
2
|
+
export declare class DeviceHubService {
|
|
3
|
+
private readonly baseUrl;
|
|
4
|
+
constructor();
|
|
5
|
+
addHub(body: IHubCreateParams): Promise<any>;
|
|
6
|
+
getHubs(hubIds: string[]): Promise<any>;
|
|
7
|
+
getHub(hubId: string): Promise<any>;
|
|
8
|
+
updateHub(hubId: string, body: any): Promise<any>;
|
|
9
|
+
deleteHub(hubId: string): Promise<any>;
|
|
10
|
+
deleteAllHubs(hubIds: string[]): Promise<any>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
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.DeviceHubService = void 0;
|
|
7
|
+
const axios_1 = __importDefault(require("axios"));
|
|
8
|
+
const config_1 = require("../../../config/config");
|
|
9
|
+
class DeviceHubService {
|
|
10
|
+
constructor() {
|
|
11
|
+
const { DEVICE_SERVICE } = (0, config_1.getConfig)();
|
|
12
|
+
if (!DEVICE_SERVICE) {
|
|
13
|
+
throw new Error("DEVICE_SERVICE is not configured. Call initialize() first with DEVICE_SERVICE.");
|
|
14
|
+
}
|
|
15
|
+
this.baseUrl = DEVICE_SERVICE;
|
|
16
|
+
}
|
|
17
|
+
async addHub(body) {
|
|
18
|
+
return await axios_1.default.post(`${this.baseUrl}/devices/hubs`, body);
|
|
19
|
+
}
|
|
20
|
+
//get hubs takes an array of hub ids as query params
|
|
21
|
+
async getHubs(hubIds) {
|
|
22
|
+
const query = hubIds && hubIds.length ? `?ids=${hubIds.join(",")}` : "";
|
|
23
|
+
return await axios_1.default.get(`${this.baseUrl}/devices/hubs${query}`);
|
|
24
|
+
}
|
|
25
|
+
//get hub takes a hub id in params
|
|
26
|
+
async getHub(hubId) {
|
|
27
|
+
return await axios_1.default.get(`${this.baseUrl}/devices/hubs/${hubId}`);
|
|
28
|
+
}
|
|
29
|
+
async updateHub(hubId, body) {
|
|
30
|
+
return await axios_1.default.put(`${this.baseUrl}/devices/hubs/${hubId}`, body);
|
|
31
|
+
}
|
|
32
|
+
async deleteHub(hubId) {
|
|
33
|
+
return await axios_1.default.delete(`${this.baseUrl}/devices/hubs/${hubId}`);
|
|
34
|
+
}
|
|
35
|
+
async deleteAllHubs(hubIds) {
|
|
36
|
+
const query = hubIds.length ? `?ids=${hubIds.join(",")}` : "";
|
|
37
|
+
return await axios_1.default.delete(`${this.baseUrl}/devices/hubs${query}`);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
exports.DeviceHubService = DeviceHubService;
|
package/dist/index.d.ts
CHANGED
package/dist/index.js
CHANGED
|
@@ -37,6 +37,8 @@ __exportStar(require("./events"), exports);
|
|
|
37
37
|
__exportStar(require("./events/interfaces"), exports);
|
|
38
38
|
// Types exports
|
|
39
39
|
__exportStar(require("./types"), exports);
|
|
40
|
+
// Redis utils
|
|
41
|
+
__exportStar(require("./utils"), exports);
|
|
40
42
|
//initialize export
|
|
41
43
|
var config_1 = require("./config/config");
|
|
42
44
|
Object.defineProperty(exports, "initialize", { enumerable: true, get: function () { return config_1.initialize; } });
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Validates if a URL is properly formatted and accessible
|
|
3
|
+
*/
|
|
4
|
+
export declare function validateServiceUrl(url: string): boolean;
|
|
5
|
+
/**
|
|
6
|
+
* Creates a properly configured axios instance with error handling
|
|
7
|
+
*/
|
|
8
|
+
export declare function createAxiosInstance(baseURL?: string): import("axios").AxiosInstance;
|
|
9
|
+
export declare function getDeviceServiceAxiosInstance(): any;
|
|
10
|
+
/**
|
|
11
|
+
* Retry function for failed HTTP requests
|
|
12
|
+
*/
|
|
13
|
+
export declare function retryRequest<T>(requestFn: () => Promise<T>, maxRetries?: number, delay?: number): Promise<T>;
|
|
@@ -0,0 +1,117 @@
|
|
|
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.validateServiceUrl = validateServiceUrl;
|
|
7
|
+
exports.createAxiosInstance = createAxiosInstance;
|
|
8
|
+
exports.getDeviceServiceAxiosInstance = getDeviceServiceAxiosInstance;
|
|
9
|
+
exports.retryRequest = retryRequest;
|
|
10
|
+
const config_1 = require("../config/config");
|
|
11
|
+
const axios_1 = __importDefault(require("axios"));
|
|
12
|
+
/**
|
|
13
|
+
* Validates if a URL is properly formatted and accessible
|
|
14
|
+
*/
|
|
15
|
+
function validateServiceUrl(url) {
|
|
16
|
+
try {
|
|
17
|
+
const parsedUrl = new URL(url);
|
|
18
|
+
return parsedUrl.protocol === "http:" || parsedUrl.protocol === "https:";
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
(0, config_1.getConfig)().LOGGER.error(`Invalid service URL: ${url}`, error);
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Creates a properly configured axios instance with error handling
|
|
27
|
+
*/
|
|
28
|
+
function createAxiosInstance(baseURL) {
|
|
29
|
+
const instance = axios_1.default.create({
|
|
30
|
+
baseURL,
|
|
31
|
+
timeout: 30000, // 30 seconds timeout
|
|
32
|
+
maxRedirects: 5,
|
|
33
|
+
validateStatus: (status) => status < 500, // Don't throw on 4xx errors
|
|
34
|
+
headers: {
|
|
35
|
+
"Content-Type": "application/json",
|
|
36
|
+
"User-Agent": "dt-common-device/1.3.0",
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
// Add request interceptor for logging
|
|
40
|
+
instance.interceptors.request.use((config) => {
|
|
41
|
+
const logger = (0, config_1.getConfig)().LOGGER;
|
|
42
|
+
logger.info(`Making request to: ${config.method?.toUpperCase()} ${config.url}`, {
|
|
43
|
+
baseURL: config.baseURL,
|
|
44
|
+
timeout: config.timeout,
|
|
45
|
+
});
|
|
46
|
+
return config;
|
|
47
|
+
}, (error) => {
|
|
48
|
+
(0, config_1.getConfig)().LOGGER.error("Request interceptor error:", error);
|
|
49
|
+
return Promise.reject(error);
|
|
50
|
+
});
|
|
51
|
+
// Add response interceptor for error handling
|
|
52
|
+
instance.interceptors.response.use((response) => {
|
|
53
|
+
return response;
|
|
54
|
+
}, (error) => {
|
|
55
|
+
const logger = (0, config_1.getConfig)().LOGGER;
|
|
56
|
+
const errorInfo = {
|
|
57
|
+
url: error.config?.url,
|
|
58
|
+
method: error.config?.method,
|
|
59
|
+
status: error.response?.status,
|
|
60
|
+
statusText: error.response?.statusText,
|
|
61
|
+
message: error.message,
|
|
62
|
+
code: error.code,
|
|
63
|
+
baseURL: error.config?.baseURL,
|
|
64
|
+
};
|
|
65
|
+
logger.error("HTTP request failed:", errorInfo);
|
|
66
|
+
// Log additional details for network errors
|
|
67
|
+
if (error.code === "ECONNREFUSED" || error.code === "ENOTFOUND") {
|
|
68
|
+
logger.error("Network connectivity issue detected. Please check:", {
|
|
69
|
+
serviceUrl: error.config?.baseURL,
|
|
70
|
+
errorCode: error.code,
|
|
71
|
+
errorMessage: error.message,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
return Promise.reject(error);
|
|
75
|
+
});
|
|
76
|
+
return instance;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Centralized axios instance for device service
|
|
80
|
+
*/
|
|
81
|
+
let deviceServiceAxiosInstance = null;
|
|
82
|
+
function getDeviceServiceAxiosInstance() {
|
|
83
|
+
if (!deviceServiceAxiosInstance) {
|
|
84
|
+
const { DEVICE_SERVICE } = (0, config_1.getConfig)();
|
|
85
|
+
if (!DEVICE_SERVICE) {
|
|
86
|
+
throw new Error("DEVICE_SERVICE is not configured. Call initialize() first with DEVICE_SERVICE.");
|
|
87
|
+
}
|
|
88
|
+
deviceServiceAxiosInstance = createAxiosInstance(DEVICE_SERVICE);
|
|
89
|
+
}
|
|
90
|
+
return deviceServiceAxiosInstance;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Retry function for failed HTTP requests
|
|
94
|
+
*/
|
|
95
|
+
async function retryRequest(requestFn, maxRetries = 3, delay = 1000) {
|
|
96
|
+
let lastError;
|
|
97
|
+
for (let attempt = 1; attempt <= maxRetries; attempt++) {
|
|
98
|
+
try {
|
|
99
|
+
return await requestFn();
|
|
100
|
+
}
|
|
101
|
+
catch (error) {
|
|
102
|
+
lastError = error;
|
|
103
|
+
if (attempt === maxRetries) {
|
|
104
|
+
(0, config_1.getConfig)().LOGGER.error(`Request failed after ${maxRetries} attempts:`, error);
|
|
105
|
+
throw error;
|
|
106
|
+
}
|
|
107
|
+
(0, config_1.getConfig)().LOGGER.warn(`Request attempt ${attempt} failed, retrying in ${delay}ms:`, {
|
|
108
|
+
error: error.message,
|
|
109
|
+
attempt,
|
|
110
|
+
maxRetries,
|
|
111
|
+
});
|
|
112
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
113
|
+
delay *= 2; // Exponential backoff
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
throw lastError;
|
|
117
|
+
}
|
|
@@ -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("./redis.utils"), exports);
|
|
18
|
+
__exportStar(require("./http.utils"), exports);
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare class RedisUtils {
|
|
2
|
+
private client;
|
|
3
|
+
hget(key: string, field: string): Promise<any | null>;
|
|
4
|
+
hset(key: string, field: string, value: string): Promise<number>;
|
|
5
|
+
hdel(key: string, ...fields: string[]): Promise<number>;
|
|
6
|
+
exists(key: string): Promise<number>;
|
|
7
|
+
expire(key: string, seconds: number): Promise<any>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,124 @@
|
|
|
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.RedisUtils = void 0;
|
|
42
|
+
const typedi_1 = require("typedi");
|
|
43
|
+
const redis_1 = require("../db/redis");
|
|
44
|
+
let RedisUtils = (() => {
|
|
45
|
+
let _classDecorators = [(0, typedi_1.Service)()];
|
|
46
|
+
let _classDescriptor;
|
|
47
|
+
let _classExtraInitializers = [];
|
|
48
|
+
let _classThis;
|
|
49
|
+
var RedisUtils = _classThis = class {
|
|
50
|
+
constructor() {
|
|
51
|
+
this.client = (0, redis_1.getRedisClient)(); // singleton Redis client instance
|
|
52
|
+
}
|
|
53
|
+
async hget(key, field) {
|
|
54
|
+
try {
|
|
55
|
+
const value = await this.client.hget(key, field);
|
|
56
|
+
return JSON.parse(value);
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
console.error(`Error getting value for key ${key}:`, error);
|
|
60
|
+
throw error;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async hset(key, field, value) {
|
|
64
|
+
try {
|
|
65
|
+
return await this.client.hset(key, field, value);
|
|
66
|
+
}
|
|
67
|
+
catch (error) {
|
|
68
|
+
console.error(`Error setting value for key ${key}:`, error);
|
|
69
|
+
throw error;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
// async del(key: string): Promise<number> {
|
|
73
|
+
// return this.client.del(key);
|
|
74
|
+
// }
|
|
75
|
+
async hdel(key, ...fields) {
|
|
76
|
+
return this.client.hdel(key, ...fields);
|
|
77
|
+
}
|
|
78
|
+
// async get(key: string): Promise<string | null> {
|
|
79
|
+
// try {
|
|
80
|
+
// return await this.client.get(key);
|
|
81
|
+
// } catch (error) {
|
|
82
|
+
// console.error(`Error getting value for key ${key}:`, error);
|
|
83
|
+
// throw error;
|
|
84
|
+
// }
|
|
85
|
+
// }
|
|
86
|
+
/* async set(key: string, value: string): Promise<boolean> {
|
|
87
|
+
try {
|
|
88
|
+
await this.client.set(key, value);
|
|
89
|
+
return true;
|
|
90
|
+
} catch (error) {
|
|
91
|
+
console.error(`Error setting value for key ${key}:`, error);
|
|
92
|
+
throw error;
|
|
93
|
+
}
|
|
94
|
+
} */
|
|
95
|
+
async exists(key) {
|
|
96
|
+
try {
|
|
97
|
+
return this.client.exists(key);
|
|
98
|
+
}
|
|
99
|
+
catch (error) {
|
|
100
|
+
console.error(`Error checking existence for key ${key}:`, error);
|
|
101
|
+
throw error;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
async expire(key, seconds) {
|
|
105
|
+
try {
|
|
106
|
+
return this.client.expire(key, seconds);
|
|
107
|
+
}
|
|
108
|
+
catch (error) {
|
|
109
|
+
console.error(`Error setting expiration for key ${key}:`, error);
|
|
110
|
+
throw error;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
__setFunctionName(_classThis, "RedisUtils");
|
|
115
|
+
(() => {
|
|
116
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
117
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
118
|
+
RedisUtils = _classThis = _classDescriptor.value;
|
|
119
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
120
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
121
|
+
})();
|
|
122
|
+
return RedisUtils = _classThis;
|
|
123
|
+
})();
|
|
124
|
+
exports.RedisUtils = RedisUtils;
|
package/package.json
CHANGED
package/src/config/config.ts
CHANGED
|
@@ -3,7 +3,7 @@ import { initializeAudit } from "dt-audit-library";
|
|
|
3
3
|
import { connectDatabase } from "../db/db";
|
|
4
4
|
import dotenv from "dotenv";
|
|
5
5
|
import { InternalEventSubscription } from "../events";
|
|
6
|
-
import { validateServiceUrl } from "../utils/http
|
|
6
|
+
import { validateServiceUrl } from "../utils/http.utils";
|
|
7
7
|
|
|
8
8
|
dotenv.config();
|
|
9
9
|
|
package/src/db/redis.ts
CHANGED
|
@@ -3,6 +3,7 @@ import Redis from "ioredis";
|
|
|
3
3
|
|
|
4
4
|
let redisClient: Redis | null = null;
|
|
5
5
|
|
|
6
|
+
//Singleton pattern to ensure only one Redis client instance is create only once and shared across the application
|
|
6
7
|
export function getRedisClient() {
|
|
7
8
|
if (!redisClient) {
|
|
8
9
|
const { host, port } = getRedisDbHostAndPort();
|
|
@@ -3,7 +3,7 @@ import { getConfig } from "../../../config/config";
|
|
|
3
3
|
import { getPostgresClient } from "../../../db";
|
|
4
4
|
import { Service } from "typedi";
|
|
5
5
|
import { IDtDevice } from "../interfaces/IDtDevice";
|
|
6
|
-
import { getDeviceServiceAxiosInstance } from "../../../utils/http
|
|
6
|
+
import { getDeviceServiceAxiosInstance } from "../../../utils/http.utils";
|
|
7
7
|
|
|
8
8
|
@Service()
|
|
9
9
|
export class DeviceRepository {
|
|
@@ -2,7 +2,7 @@ import { getConfig } from "../../../config/config";
|
|
|
2
2
|
import { getPostgresClient } from "../../../db";
|
|
3
3
|
import { Service } from "typedi";
|
|
4
4
|
import { IDevice } from "../interfaces";
|
|
5
|
-
import { getDeviceServiceAxiosInstance } from "../../../utils/http
|
|
5
|
+
import { getDeviceServiceAxiosInstance } from "../../../utils/http.utils";
|
|
6
6
|
|
|
7
7
|
@Service()
|
|
8
8
|
export class HubRepository {
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Service } from "typedi";
|
|
2
2
|
import { getConfig } from "../../../config/config";
|
|
3
3
|
import { ISchedule } from "../interfaces/ISchedule";
|
|
4
|
-
import { getDeviceServiceAxiosInstance } from "../../../utils/http
|
|
4
|
+
import { getDeviceServiceAxiosInstance } from "../../../utils/http.utils";
|
|
5
5
|
|
|
6
6
|
@Service()
|
|
7
7
|
export class ScheduleRepository {
|
package/src/index.ts
CHANGED
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { Service } from "typedi";
|
|
2
|
+
import { getRedisClient } from "../db/redis";
|
|
3
|
+
|
|
4
|
+
@Service()
|
|
5
|
+
export class RedisUtils {
|
|
6
|
+
private client = getRedisClient(); // singleton Redis client instance
|
|
7
|
+
|
|
8
|
+
async hget(key: string, field: string): Promise<any | null> {
|
|
9
|
+
try {
|
|
10
|
+
const value: any = await this.client.hget(key, field);
|
|
11
|
+
return JSON.parse(value);
|
|
12
|
+
} catch (error) {
|
|
13
|
+
console.error(`Error getting value for key ${key}:`, error);
|
|
14
|
+
throw error;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
async hset(key: string, field: string, value: string): Promise<number> {
|
|
19
|
+
try {
|
|
20
|
+
return await this.client.hset(key, field, value);
|
|
21
|
+
} catch (error) {
|
|
22
|
+
console.error(`Error setting value for key ${key}:`, error);
|
|
23
|
+
throw error;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// async del(key: string): Promise<number> {
|
|
28
|
+
// return this.client.del(key);
|
|
29
|
+
// }
|
|
30
|
+
|
|
31
|
+
async hdel(key: string, ...fields: string[]): Promise<number> {
|
|
32
|
+
return this.client.hdel(key, ...fields);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
// async get(key: string): Promise<string | null> {
|
|
36
|
+
// try {
|
|
37
|
+
// return await this.client.get(key);
|
|
38
|
+
// } catch (error) {
|
|
39
|
+
// console.error(`Error getting value for key ${key}:`, error);
|
|
40
|
+
// throw error;
|
|
41
|
+
// }
|
|
42
|
+
// }
|
|
43
|
+
|
|
44
|
+
/* async set(key: string, value: string): Promise<boolean> {
|
|
45
|
+
try {
|
|
46
|
+
await this.client.set(key, value);
|
|
47
|
+
return true;
|
|
48
|
+
} catch (error) {
|
|
49
|
+
console.error(`Error setting value for key ${key}:`, error);
|
|
50
|
+
throw error;
|
|
51
|
+
}
|
|
52
|
+
} */
|
|
53
|
+
|
|
54
|
+
async exists(key: string): Promise<number> {
|
|
55
|
+
try {
|
|
56
|
+
return this.client.exists(key);
|
|
57
|
+
} catch (error) {
|
|
58
|
+
console.error(`Error checking existence for key ${key}:`, error);
|
|
59
|
+
throw error;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
async expire(key: string, seconds: number): Promise<any> {
|
|
64
|
+
try {
|
|
65
|
+
return this.client.expire(key, seconds);
|
|
66
|
+
} catch (error) {
|
|
67
|
+
console.error(`Error setting expiration for key ${key}:`, error);
|
|
68
|
+
throw error;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
File without changes
|