UNPKG

15.8 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6
7var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
8
9var _index = require("./index");
10
11var _index2 = _interopRequireDefault(_index);
12
13var _Utils = require("./Utils");
14
15var _Utils2 = _interopRequireDefault(_Utils);
16
17function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
19function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
20
21/**
22 * Provides access to the `users` endpoint.
23 */
24var Users = function () {
25 _createClass(Users, null, [{
26 key: "PATH",
27 get: function get() {
28 return "/v0.1/users";
29 }
30
31 /**
32 * @param {Credentials} credentials
33 * credentials to be used when interacting with the API.
34 * @param {Object} options
35 * Additional Users options.
36 */
37
38 }]);
39
40 function Users(credentials) {
41 var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
42
43 _classCallCheck(this, Users);
44
45 this.creds = credentials;
46 this.options = options;
47 }
48
49 /**
50 * Create a new user.
51 *
52 * @param {Object} params - Parameters used when creating the user. See https://ea.developer.nexmo.com/api/conversation#create-a-user for more information.
53 * @param {function} callback - function to be called when the request completes.
54 */
55
56
57 _createClass(Users, [{
58 key: "create",
59 value: function create(params, callback) {
60 params = JSON.stringify(params);
61
62 var config = {
63 host: this.options.host || "api.nexmo.com",
64 path: Users.PATH,
65 method: "POST",
66 body: params,
67 headers: {
68 "Content-Type": "application/json",
69 Authorization: "Bearer " + this.creds.generateJwt()
70 }
71 };
72 this.options.httpClient.request(config, callback);
73 }
74
75 /**
76 * Get an existing user.
77 *
78 * @param {string|object} query - The unique identifier for the user to retrieve
79 * or a set of filter parameters for the query. For more information
80 * see https://ea.developer.nexmo.com/api/conversation#retrieve-all-users
81 * @param {function} callback - function to be called when the request completes.
82 */
83
84 }, {
85 key: "get",
86 value: function get(query, callback) {
87 var config = {
88 host: this.options.host || "api.nexmo.com",
89 path: _Utils2.default.createPathWithQuery(Users.PATH, query),
90 method: "GET",
91 body: undefined,
92 headers: {
93 "Content-Type": "application/json",
94 Authorization: "Bearer " + this.creds.generateJwt()
95 }
96 };
97 this.options.httpClient.request(config, callback);
98 }
99
100 /**
101 * Get next page of users or conversations for a user.
102 *
103 * @param {object} response - The response from a paginated users list
104 * see https://ea.developer.nexmo.com/api/conversation#retrieve-all-users
105 * @param {function} callback - function to be called when the request completes.
106 */
107
108 }, {
109 key: "next",
110 value: function next(response, callback) {
111 if (response._links.next) {
112 this.get(_Utils2.default.getQuery(response._links.next.href), callback);
113 } else {
114 var error = new Error("The response doesn't have a next page.");
115 callback(error, null);
116 }
117 }
118
119 /**
120 * Get previous page of users or conversations for a user.
121 *
122 * @param {object} response - The response from a paginated users list
123 * see https://ea.developer.nexmo.com/api/conversation#retrieve-all-users
124 * @param {function} callback - function to be called when the request completes.
125 */
126
127 }, {
128 key: "prev",
129 value: function prev(response, callback) {
130 if (response._links.prev) {
131 this.get(_Utils2.default.getQuery(response._links.prev.href), callback);
132 } else {
133 var error = new Error("The response doesn't have a previous page.");
134 callback(error, null);
135 }
136 }
137
138 /**
139 * Update an existing user.
140 *
141 * @param {string} userId - The unique identifier for the user to update.
142 * @param {Object} params - Parameters used when updating the conversation.
143 * @param {function} callback - function to be called when the request completes.
144 */
145
146 }, {
147 key: "update",
148 value: function update(userId, params, callback) {
149 params = JSON.stringify(params);
150
151 var config = {
152 host: this.options.host || "api.nexmo.com",
153 path: Users.PATH + "/" + userId,
154 method: "PUT",
155 body: params,
156 headers: {
157 "Content-Type": "application/json",
158 Authorization: "Bearer " + this.creds.generateJwt()
159 }
160 };
161
162 this.options.httpClient.request(config, callback);
163 }
164
165 /**
166 * Deleta an existing user.
167 *
168 * @param {string} userId - The unique identifier for the user to delete.
169 * @param {function} callback - function to be called when the request completes.
170 */
171
172 }, {
173 key: "delete",
174 value: function _delete(userId, callback) {
175 var config = {
176 host: this.options.host || "api.nexmo.com",
177 path: Users.PATH + "/" + userId,
178 method: "DELETE",
179 headers: {
180 "Content-Type": "application/json",
181 Authorization: "Bearer " + this.creds.generateJwt()
182 }
183 };
184
185 this.options.httpClient.request(config, callback);
186 }
187 }]);
188
189 return Users;
190}();
191
192exports.default = Users;
193module.exports = exports["default"];
194//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Users.js"],"names":["Users","credentials","options","creds","params","callback","JSON","stringify","config","host","path","PATH","method","body","headers","Authorization","generateJwt","httpClient","request","query","createPathWithQuery","undefined","response","_links","next","get","getQuery","href","error","Error","prev","userId"],"mappings":"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","file":"Users.js","sourcesContent":["\"use strict\";\n\nimport nexmo from \"./index\";\n\nimport Utils from \"./Utils\";\n\n/**\n * Provides access to the `users` endpoint.\n */\nclass Users {\n  static get PATH() {\n    return \"/v0.1/users\";\n  }\n\n  /**\n   * @param {Credentials} credentials\n   *    credentials to be used when interacting with the API.\n   * @param {Object} options\n   *    Additional Users options.\n   */\n  constructor(credentials, options = {}) {\n    this.creds = credentials;\n    this.options = options;\n  }\n\n  /**\n   * Create a new user.\n   *\n   * @param {Object} params - Parameters used when creating the user. See https://ea.developer.nexmo.com/api/conversation#create-a-user for more information.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  create(params, callback) {\n    params = JSON.stringify(params);\n\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: Users.PATH,\n      method: \"POST\",\n      body: params,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Authorization: `Bearer ${this.creds.generateJwt()}`\n      }\n    };\n    this.options.httpClient.request(config, callback);\n  }\n\n  /**\n   * Get an existing user.\n   *\n   * @param {string|object} query - The unique identifier for the user to retrieve\n   *               or a set of filter parameters for the query. For more information\n   *               see https://ea.developer.nexmo.com/api/conversation#retrieve-all-users\n   * @param {function} callback - function to be called when the request completes.\n   */\n  get(query, callback) {\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: Utils.createPathWithQuery(Users.PATH, query),\n      method: \"GET\",\n      body: undefined,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Authorization: `Bearer ${this.creds.generateJwt()}`\n      }\n    };\n    this.options.httpClient.request(config, callback);\n  }\n\n  /**\n   * Get next page of users or conversations for a user.\n   *\n   * @param {object} response - The response from a paginated users list\n   *               see https://ea.developer.nexmo.com/api/conversation#retrieve-all-users\n   * @param {function} callback - function to be called when the request completes.\n   */\n\n  next(response, callback) {\n    if (response._links.next) {\n      this.get(Utils.getQuery(response._links.next.href), callback);\n    } else {\n      const error = new Error(\"The response doesn't have a next page.\");\n      callback(error, null);\n    }\n  }\n\n  /**\n   * Get previous page of users or conversations for a user.\n   *\n   * @param {object} response - The response from a paginated users list\n   *               see https://ea.developer.nexmo.com/api/conversation#retrieve-all-users\n   * @param {function} callback - function to be called when the request completes.\n   */\n  prev(response, callback) {\n    if (response._links.prev) {\n      this.get(Utils.getQuery(response._links.prev.href), callback);\n    } else {\n      const error = new Error(\"The response doesn't have a previous page.\");\n      callback(error, null);\n    }\n  }\n\n  /**\n   * Update an existing user.\n   *\n   * @param {string} userId - The unique identifier for the user to update.\n   * @param {Object} params - Parameters used when updating the conversation.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  update(userId, params, callback) {\n    params = JSON.stringify(params);\n\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Users.PATH}/${userId}`,\n      method: \"PUT\",\n      body: params,\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Authorization: `Bearer ${this.creds.generateJwt()}`\n      }\n    };\n\n    this.options.httpClient.request(config, callback);\n  }\n\n  /**\n   * Deleta an existing user.\n   *\n   * @param {string} userId - The unique identifier for the user to delete.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  delete(userId, callback) {\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Users.PATH}/${userId}`,\n      method: \"DELETE\",\n      headers: {\n        \"Content-Type\": \"application/json\",\n        Authorization: `Bearer ${this.creds.generateJwt()}`\n      }\n    };\n\n    this.options.httpClient.request(config, callback);\n  }\n}\n\nexport default Users;\n"]}
\No newline at end of file