forked from electricimp/imp-central-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathImpCentralApi.js
135 lines (117 loc) · 4.73 KB
/
ImpCentralApi.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
// MIT License
//
// Copyright 2017 Electric Imp
//
// SPDX-License-Identifier: MIT
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO
// EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES
// OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
// OTHER DEALINGS IN THE SOFTWARE.
'use strict';
const Accounts = require('./Accounts');
const Auth = require('./Auth');
const DeviceGroups = require('./DeviceGroups');
const Devices = require('./Devices');
const Deployments = require('./Deployments');
const Products = require('./Products');
const LogStreams = require('./LogStreams');
const Webhooks = require('./Webhooks');
const HttpHelper = require('./util/HttpHelper');
const Logger = require('./util/Logger');
// Client library for Electric Imp impCentral API (v5).
// Provides access to Accounts, Authentication, Products, Device Groups, Devices,
// Deployments, Logs interfaces of impCentral API.
//
// All requests to impCentral API are made asynchronously via Promises.
// Any method which sends a request returns Promise that resolves with HTTP response body
// if operation succeeds, or rejects with an error if operation fails.
//
// The exact format of HTTP response body for every request can be found in
// Electric Imp impCentral API (v5).
//
// The possible errors are defined in Errors module.
// They are:
// - InvalidDataError - the library detects an error, e.g. the library is wrongly initialized
// (apiEndpoint has invalid scheme or accessToken is not provided)
// or the library method is called with invalid argument(s).
// The error details can be found in message property.
// - ImpCentralApiError - HTTP request to impCentral API failed.
// The error details can be found in message, statusCode and body properties.
// The exact body format is described in Error Handling section of Electric Imp impCentral API (v5).
class ImpCentralApi {
// Creates ImpCentralApi library instance.
//
// Parameters:
// apiEndpoint : String impCentral API endpoint
// If not specified, the default one is used.
constructor(apiEndpoint = null) {
HttpHelper.apiEndpoint = apiEndpoint;
this._auth = new Auth();
this._accounts = new Accounts();
this._products = new Products();
this._deviceGroups = new DeviceGroups();
this._devices = new Devices();
this._deployments = new Deployments();
this._logStreams = new LogStreams();
this._webhooks = new Webhooks();
}
// Provides access to Accounts impCentral API methods.
get accounts() {
return this._accounts;
}
// Provides access to Authentication impCentral API methods.
get auth() {
return this._auth;
}
// Provides access to Products impCentral API methods.
get products() {
return this._products;
}
// Provides access to Device Groups impCentral API methods.
get deviceGroups() {
return this._deviceGroups;
}
// Provides access to Devices impCentral API methods.
get devices() {
return this._devices;
}
// Provides access to Deployments impCentral API methods.
get deployments() {
return this._deployments;
}
// Provides access to LogStreams impCentral API methods.
get logStreams() {
return this._logStreams;
}
// Provides access to Webhooks impCentral API methods.
get webhooks() {
return this._webhooks;
}
// Enables/disables the library debug output (including errors logging).
// Disabled by default (after the library instantiation).
//
// Parameters:
// value : Boolean true to enable, false to disable
set debug(value) {
Logger.debug = value;
}
// Returns impCentral API endpoint used by the library.
get apiEndpoint() {
return HttpHelper.apiEndpoint;
}
}
module.exports = ImpCentralApi;