dt-common-device 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +73 -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 +39 -0
- package/dist/device/cloud/interfaces/IDeviceConnectionService.js +3 -0
- package/dist/device/cloud/interfaces/IDevicesService.d.ts +9 -0
- package/dist/device/cloud/interfaces/IDevicesService.js +2 -0
- package/dist/device/cloud/interfaces/index.d.ts +2 -0
- package/dist/device/cloud/interfaces/index.js +18 -0
- package/dist/device/cloud/services/Connection.service.d.ts +42 -0
- package/dist/device/cloud/services/Connection.service.js +59 -0
- package/dist/device/cloud/services/Device.service.d.ts +10 -0
- package/dist/device/cloud/services/Device.service.js +30 -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 +10 -0
- package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +38 -0
- package/dist/device/cloud/services/SmartThingsDeviceService.js +52 -0
- package/dist/device/cloud/services/index.d.ts +2 -0
- package/dist/device/cloud/services/index.js +19 -0
- package/dist/device/cloud/types.d.ts +77 -0
- package/dist/device/cloud/types.js +3 -0
- package/dist/device/index.d.ts +4 -0
- package/dist/device/index.js +20 -0
- package/dist/device/local/interface.d.ts +0 -0
- package/dist/device/local/interface.js +1 -0
- package/dist/device/local/interfaces/IDevice.d.ts +46 -0
- package/dist/device/local/interfaces/IDevice.js +3 -0
- package/dist/device/local/interfaces/IHub.d.ts +46 -0
- package/dist/device/local/interfaces/IHub.js +2 -0
- package/dist/device/local/interfaces/index.d.ts +2 -0
- package/dist/device/local/interfaces/index.js +18 -0
- package/dist/device/local/services/Device.service.d.ts +18 -0
- package/dist/device/local/services/Device.service.js +27 -0
- package/dist/device/local/services/DeviceHub.service.d.ts +21 -0
- package/dist/device/local/services/DeviceHub.service.js +28 -0
- package/dist/device/local/services/index.d.ts +2 -0
- package/dist/device/local/services/index.js +18 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +47 -0
- package/package.json +21 -0
- package/src/device/cloud/interfaces/IDeviceConnectionService.ts +54 -0
- package/src/device/cloud/interfaces/IDevicesService.ts +10 -0
- package/src/device/cloud/interfaces/index.ts +2 -0
- package/src/device/cloud/services/Connection.service.ts +76 -0
- package/src/device/cloud/services/Device.service.ts +40 -0
- package/src/device/cloud/services/DeviceHub.service.ts +6 -0
- package/src/device/cloud/services/index.ts +4 -0
- package/src/device/cloud/types.ts +83 -0
- package/src/device/local/interfaces/IDevice.ts +48 -0
- package/src/device/local/interfaces/IHub.ts +46 -0
- package/src/device/local/interfaces/index.ts +2 -0
- package/src/device/local/services/Device.service.ts +46 -0
- package/src/device/local/services/DeviceHub.service.ts +50 -0
- package/src/device/local/services/index.ts +2 -0
- package/src/index.ts +10 -0
- package/tsconfig.json +20 -0
package/README.md
ADDED
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
npm install dt-common-device
|
|
2
|
+
|
|
3
|
+
## Import
|
|
4
|
+
|
|
5
|
+
import { cloud, local, cloudInterfaces, localInterfaces } from "dt-common-device";
|
|
6
|
+
|
|
7
|
+
## Cloud Functions
|
|
8
|
+
|
|
9
|
+
These are stubs and must be implemented by the consuming project.
|
|
10
|
+
|
|
11
|
+
```ts
|
|
12
|
+
const connectionService = new cloud.ConnectionService();
|
|
13
|
+
|
|
14
|
+
// Example: create a connection (must implement this in your project)
|
|
15
|
+
await connectionService.createConnection(connectionData, userId);
|
|
16
|
+
|
|
17
|
+
// Example: get device account (must implement this in your project)
|
|
18
|
+
await connectionService.getDeviceAccount(connection);
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## Local Functions
|
|
22
|
+
|
|
23
|
+
### DeviceService
|
|
24
|
+
|
|
25
|
+
```ts
|
|
26
|
+
const deviceService = new local.DeviceService();
|
|
27
|
+
|
|
28
|
+
// Create a device
|
|
29
|
+
await deviceService.createDevice(deviceBody, httpClient);
|
|
30
|
+
|
|
31
|
+
// Get a device
|
|
32
|
+
const device = await deviceService.getDevice(deviceId, httpClient);
|
|
33
|
+
|
|
34
|
+
// Update a device
|
|
35
|
+
await deviceService.updateDevice(deviceId, updateBody, httpClient);
|
|
36
|
+
|
|
37
|
+
// Delete a device
|
|
38
|
+
await deviceService.deleteDevice(deviceId, httpClient);
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
## Local Functions
|
|
42
|
+
|
|
43
|
+
### DeviceHubService
|
|
44
|
+
|
|
45
|
+
```ts
|
|
46
|
+
const deviceHubService = new local.DeviceHubService();
|
|
47
|
+
|
|
48
|
+
// Add a hub
|
|
49
|
+
await deviceHubService.addHub(hubBody, httpClient);
|
|
50
|
+
|
|
51
|
+
// Get hubs
|
|
52
|
+
const hubs = await deviceHubService.getHubs(hubIds, httpClient);
|
|
53
|
+
|
|
54
|
+
// Get a single hub
|
|
55
|
+
const hub = await deviceHubService.getHub(hubId, httpClient);
|
|
56
|
+
|
|
57
|
+
// Update a hub
|
|
58
|
+
await deviceHubService.updateHub(hubId, updateBody, httpClient);
|
|
59
|
+
|
|
60
|
+
// Delete a hub
|
|
61
|
+
await deviceHubService.deleteHub(hubId, httpClient);
|
|
62
|
+
|
|
63
|
+
// Delete multiple hubs
|
|
64
|
+
await deviceHubService.deleteAllHubs(hubIds, httpClient);
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
### Types
|
|
68
|
+
|
|
69
|
+
All types and interfaces are available as named exports:
|
|
70
|
+
|
|
71
|
+
```ts
|
|
72
|
+
import { IDevice, IHubCreateParams } from "dt-common-device";
|
|
73
|
+
```
|
|
@@ -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,39 @@
|
|
|
1
|
+
import { IConnection, IConnectionConnectParams, IDevice, IDeviceAccountResponse } from "../types";
|
|
2
|
+
/**
|
|
3
|
+
* Class interface for device cloud operations and connection management
|
|
4
|
+
*/
|
|
5
|
+
export interface IDeviceConnectionService {
|
|
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<any>;
|
|
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
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { IConnection } from "../types";
|
|
2
|
+
export interface IDeviceService {
|
|
3
|
+
getDevices(connection: IConnection): Promise<any[]>;
|
|
4
|
+
getDevice(connectionId: string, deviceId: string): Promise<any>;
|
|
5
|
+
getStatus(connectionId: string, deviceId: string): Promise<string | null>;
|
|
6
|
+
getState(deviceId: string): Promise<any>;
|
|
7
|
+
getGateways(connectionId: string): Promise<any[] | null>;
|
|
8
|
+
getGatewayDetails(connectionId: string, gatewayId: string): Promise<any>;
|
|
9
|
+
}
|
|
@@ -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("./IDeviceConnectionService"), exports);
|
|
18
|
+
__exportStar(require("./IDevicesService"), exports);
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { IDeviceConnectionService } from "../interfaces";
|
|
2
|
+
import { IConnection, IConnectionConnectParams, IDevice, IDeviceAccountResponse } 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 ConnectionService implements IDeviceConnectionService {
|
|
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<any>;
|
|
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.ConnectionService = 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 ConnectionService {
|
|
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.ConnectionService = ConnectionService;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { IDeviceService } from "../interfaces";
|
|
2
|
+
import { IConnection } from "../types";
|
|
3
|
+
export declare class DeviceService implements IDeviceService {
|
|
4
|
+
getDevices(connection: IConnection): Promise<any[]>;
|
|
5
|
+
getDevice(connectionId: string, deviceId: string): Promise<any>;
|
|
6
|
+
getStatus(connectionId: string, deviceId: string): Promise<string | null>;
|
|
7
|
+
getState(deviceId: string): Promise<any>;
|
|
8
|
+
getGateways(connectionId: string): Promise<any[] | null>;
|
|
9
|
+
getGatewayDetails(connectionId: string, gatewayId: string): Promise<any>;
|
|
10
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DeviceService = void 0;
|
|
4
|
+
class DeviceService {
|
|
5
|
+
async getDevices(connection) {
|
|
6
|
+
// Implementation will be provided by the consuming project
|
|
7
|
+
throw new Error("getDevices method not implemented");
|
|
8
|
+
}
|
|
9
|
+
async getDevice(connectionId, deviceId) {
|
|
10
|
+
// Implementation will be provided by the consuming project
|
|
11
|
+
throw new Error("getDevice method not implemented");
|
|
12
|
+
}
|
|
13
|
+
async getStatus(connectionId, deviceId) {
|
|
14
|
+
// Implementation will be provided by the consuming project
|
|
15
|
+
throw new Error("getDeviceStatus method not implemented");
|
|
16
|
+
}
|
|
17
|
+
async getState(deviceId) {
|
|
18
|
+
// Implementation will be provided by the consuming project
|
|
19
|
+
throw new Error("getState method not implemented");
|
|
20
|
+
}
|
|
21
|
+
async getGateways(connectionId) {
|
|
22
|
+
// Implementation will be provided by the consuming project
|
|
23
|
+
throw new Error("getGateways method not implemented");
|
|
24
|
+
}
|
|
25
|
+
async getGatewayDetails(connectionId, gatewayId) {
|
|
26
|
+
// Implementation will be provided by the consuming project
|
|
27
|
+
throw new Error("getGatewayDetails method not implemented");
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
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,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DeviceHubService = void 0;
|
|
4
|
+
class DeviceHubService {
|
|
5
|
+
async getHubs() {
|
|
6
|
+
// implements will be provided by the consuming project
|
|
7
|
+
throw new Error("getHubs method not implemented");
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
exports.DeviceHubService = DeviceHubService;
|
|
@@ -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,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Device Cloud Services - Export all service classes
|
|
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
|
+
__exportStar(require("./Connection.service"), exports);
|
|
19
|
+
__exportStar(require("./Device.service"), exports);
|