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.
Files changed (48) hide show
  1. package/dist/config/config.js +1 -1
  2. package/dist/db/redis.js +1 -0
  3. package/dist/device/cloud/interface.d.ts +101 -0
  4. package/dist/device/cloud/interface.js +3 -0
  5. package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +7 -0
  6. package/dist/device/cloud/interfaces/IDeviceConnectionService.js +3 -0
  7. package/dist/device/cloud/interfaces/IDevicesService.d.ts +9 -0
  8. package/dist/device/cloud/interfaces/IDevicesService.js +2 -0
  9. package/dist/device/cloud/services/Device.service.d.ts +39 -0
  10. package/dist/device/cloud/services/Device.service.js +9 -0
  11. package/dist/device/cloud/services/DeviceCloudService.d.ts +42 -0
  12. package/dist/device/cloud/services/DeviceCloudService.js +59 -0
  13. package/dist/device/cloud/services/DeviceHub.service.d.ts +3 -0
  14. package/dist/device/cloud/services/DeviceHub.service.js +6 -0
  15. package/dist/device/cloud/services/Hub.service.d.ts +25 -0
  16. package/dist/device/cloud/services/Hub.service.js +9 -0
  17. package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +38 -0
  18. package/dist/device/cloud/services/SmartThingsDeviceService.js +52 -0
  19. package/dist/device/index.d.ts +4 -0
  20. package/dist/device/index.js +20 -0
  21. package/dist/device/local/events/EventHandler.js +6 -6
  22. package/dist/device/local/events/Events.d.ts +12 -33
  23. package/dist/device/local/events/Events.js +12 -33
  24. package/dist/device/local/interface.d.ts +0 -0
  25. package/dist/device/local/interface.js +1 -0
  26. package/dist/device/local/repository/Device.repository.js +1 -1
  27. package/dist/device/local/repository/Hub.repository.js +1 -1
  28. package/dist/device/local/repository/Schedule.repository.js +1 -1
  29. package/dist/device/local/services/DeviceHub.service.d.ts +11 -0
  30. package/dist/device/local/services/DeviceHub.service.js +40 -0
  31. package/dist/index.d.ts +1 -0
  32. package/dist/index.js +2 -0
  33. package/dist/utils/http.utils.d.ts +13 -0
  34. package/dist/utils/http.utils.js +117 -0
  35. package/dist/utils/index.d.ts +2 -0
  36. package/dist/utils/index.js +18 -0
  37. package/dist/utils/redis.utils.d.ts +8 -0
  38. package/dist/utils/redis.utils.js +124 -0
  39. package/package.json +1 -1
  40. package/src/config/config.ts +1 -1
  41. package/src/db/redis.ts +1 -0
  42. package/src/device/local/repository/Device.repository.ts +1 -1
  43. package/src/device/local/repository/Hub.repository.ts +1 -1
  44. package/src/device/local/repository/Schedule.repository.ts +1 -1
  45. package/src/index.ts +3 -0
  46. package/src/utils/index.ts +2 -0
  47. package/src/utils/redis.utils.ts +71 -0
  48. /package/src/utils/{http-utils.ts → http.utils.ts} +0 -0
@@ -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-utils");
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,3 @@
1
+ "use strict";
2
+ // Device Cloud Class Interface for DeviceThread Common Library
3
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,3 @@
1
+ "use strict";
2
+ // Device Cloud Class Interface for DeviceThread Common Library
3
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -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,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DeviceService = void 0;
4
+ class DeviceService {
5
+ constructor(device) {
6
+ Object.assign(this, device);
7
+ }
8
+ }
9
+ exports.DeviceService = DeviceService;
@@ -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,3 @@
1
+ export declare abstract class DeviceHubService {
2
+ abstract getHubs(): Promise<any>;
3
+ }
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DeviceHubService = void 0;
4
+ class DeviceHubService {
5
+ }
6
+ exports.DeviceHubService = DeviceHubService;
@@ -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,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.HubService = void 0;
4
+ class HubService {
5
+ constructor(hub) {
6
+ Object.assign(this, hub);
7
+ }
8
+ }
9
+ exports.HubService = HubService;
@@ -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,4 @@
1
+ export * from "./cloud/interface";
2
+ export * from "./cloud/types";
3
+ export type { IConnection, IConnectionConnectParams, IDevice, IDeviceAccountResponse, } from "./cloud/types";
4
+ export type { IDeviceCloudService } from "./cloud/interface";
@@ -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.CREATE.SUCCESS, body, this.source);
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.CREATE.SUCCESS,
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.UPDATE.SUCCESS, { deviceId, body }, this.source);
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.UPDATE.SUCCESS,
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.DELETE.SUCCESS, { deviceId }, this.source);
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.DELETE.SUCCESS,
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
- CREATE: {
4
- SUCCESS: string;
5
- FAILED: string;
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
- CREATE: {
45
- SUCCESS: string;
46
- FAILED: string;
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
- CREATE: {
59
- SUCCESS: string;
60
- FAILED: string;
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
- CREATE: {
7
- SUCCESS: "device.create.success",
8
- FAILED: "device.create.failed",
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
- CREATE: {
48
- SUCCESS: "connection.create.success",
49
- FAILED: "connection.create.failed",
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
- CREATE: {
62
- SUCCESS: "property.create.success",
63
- FAILED: "property.create.failed",
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-utils");
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-utils");
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-utils");
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
@@ -7,4 +7,5 @@ export * from "./device/local/interfaces";
7
7
  export * from "./events";
8
8
  export * from "./events/interfaces";
9
9
  export * from "./types";
10
+ export * from "./utils";
10
11
  export { initialize, getConfig, shutdown } from "./config/config";
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,2 @@
1
+ export * from "./redis.utils";
2
+ export * from "./http.utils";
@@ -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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dt-common-device",
3
- "version": "2.0.1",
3
+ "version": "2.0.3",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "scripts": {
@@ -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-utils";
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-utils";
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-utils";
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-utils";
4
+ import { getDeviceServiceAxiosInstance } from "../../../utils/http.utils";
5
5
 
6
6
  @Service()
7
7
  export class ScheduleRepository {
package/src/index.ts CHANGED
@@ -27,5 +27,8 @@ export * from "./events/interfaces";
27
27
  // Types exports
28
28
  export * from "./types";
29
29
 
30
+ // Redis utils
31
+ export * from "./utils";
32
+
30
33
  //initialize export
31
34
  export { initialize, getConfig, shutdown } from "./config/config";
@@ -0,0 +1,2 @@
1
+ export * from "./redis.utils";
2
+ export * from "./http.utils";
@@ -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