@shieldiot/pulse-lib
v1.0.323
Published
Typescript client library for Pulse API backend
Downloads
767
Readme
Pulse IoT client library
This package is a typescript client library for the pulse IoT API. The library includes all the types and services exposed the the pulse API.
Install
Install client library:
npm i @shieldiot/pulse-lib
How to use:
To use the library, first create a PulseClient instance with the API endpoint URL and optionally the API key and Accesss Token.
The apiKey and accessToken parameters in the PulseClient constructor are optional since it is recomended to use HTTP interceptors to inject the API key and access token instead of constructor injection.
The use of interceptor is the preferred approach since for any API response, the response header includes new access toekn with new expiration time. Using the same token without refreshing it will eventually result access denied error after the expiration time of the original token (30 minutes). The use of constructor injection of access token is recomended for non-expired tokens only (system-to-system integration).
Example: how to search list of devices:
import { PulseClient } from '@shieldiot/pulse-lib'
function searchDevices() : void{
const apiUrl: string = "http://myaccount-api.pulseiot.io/v1";
const apiKey: string = "your_api_key";
const accessToken: string = "your_access_token";
// It is recomended to use a single instance of PulseClient for the entire application
let cli = new PulseClient(apiUrl, apiKey, accessToken);
// remember to release the subject: sub to avoid memory leaks
let sub = cli.UsrDevicesService.find("streamId").subscribe({
next: (res) => console.log("process response", res)
});
};
Example2: how to add account:
import { Account, AccountTypeCode, PulseClient } from '@shieldiot/pulse-lib'
function createAccount() : void{
const apiUrl: string = "http://myaccount-api.pulseiot.io/v1";
const apiKey: string = "your_api_key";
const accessToken: string = "your_access_token";
// It is recomended to use a single instance of PulseClient for the entire application
let cli = new PulseClient(apiUrl, apiKey, accessToken);
// Add account
let account = new Account("id");
account.name = "new account";
account.description = "account description";
account.type = AccountTypeCode.CUSTOMER;
// remember to release the subject: sub to avoid memory leaks
let sub = cli.SysAccountsService.create(account).subscribe({
next: (res) => console.log("process response", res)
});
};
Best Practices
- Use a single instance of the PulseClient (as a singleton) for the entire application to avoid high memory consumption since this instance initializes all the pulse services that can be access as readonly properties.
- All the service methods return a generic typed Observable (e.g.
Observable<EntitiesResponse<Device>>
) that can be used in async manner in the UI or with the subscribe method in the code. Always remember to delete the subject of the subscribe to avoid memory leaks.