UNPKG

20.2 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
17var _Members = require("./Members");
18
19var _Members2 = _interopRequireDefault(_Members);
20
21var _Events = require("./Events");
22
23var _Events2 = _interopRequireDefault(_Events);
24
25function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
26
27function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
28
29/**
30 * Provides access to the `conversations` endpoint.
31 */
32var Conversations = function () {
33 _createClass(Conversations, null, [{
34 key: "PATH",
35 get: function get() {
36 return "/v0.1/conversations";
37 }
38 }, {
39 key: "V1_PATH",
40 get: function get() {
41 return "/v1/conversations";
42 }
43
44 /**
45 * @param {Credentials} credentials
46 * credentials to be used when interacting with the API.
47 * @param {Object} options
48 * Additional Conversations options.
49 */
50
51 }]);
52
53 function Conversations(credentials) {
54 var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
55
56 _classCallCheck(this, Conversations);
57
58 this.creds = credentials;
59 this.options = options;
60
61 /**
62 * @type Members
63 */
64 this.members = new _Members2.default(this.creds, this.options);
65
66 /**
67 * @type Events
68 */
69 this.events = new _Events2.default(this.creds, this.options);
70 }
71
72 /**
73 * Create a new conversation.
74 *
75 * @param {Object} params - Parameters used when creating the conversation. See https://ea.developer.nexmo.com/api/conversation#create-a-conversation for more information.
76 * @param {function} callback - function to be called when the request completes.
77 */
78
79
80 _createClass(Conversations, [{
81 key: "create",
82 value: function create(params, callback) {
83 params = JSON.stringify(params);
84
85 var config = {
86 host: this.options.host || "api.nexmo.com",
87 path: Conversations.PATH,
88 method: "POST",
89 body: params,
90 headers: {
91 "Content-Type": "application/json",
92 Authorization: "Bearer " + this.creds.generateJwt()
93 }
94 };
95 this.options.httpClient.request(config, callback);
96 }
97
98 /**
99 * Get an existing conversation.
100 *
101 * @param {string|object} query - The unique identifier for the conversation to retrieve
102 * or a set of filter parameters for the query. For more information
103 * see https://ea.developer.nexmo.com/api/conversation#retrieve-a-conversation
104 * @param {function} callback - function to be called when the request completes.
105 */
106
107 }, {
108 key: "get",
109 value: function get(query, callback) {
110 var config = {
111 host: this.options.host || "api.nexmo.com",
112 path: typeof query === "string" ? Conversations.PATH + "/" + query : _Utils2.default.createPathWithQuery(Conversations.PATH, query),
113 method: "GET",
114 body: undefined,
115 headers: {
116 "Content-Type": "application/json",
117 Authorization: "Bearer " + this.creds.generateJwt()
118 }
119 };
120 this.options.httpClient.request(config, callback);
121 }
122
123 /**
124 * Get next page of conversations.
125 *
126 * @param {object} response - The response from a paginated conversations list
127 * see https://ea.developer.nexmo.com/api/conversation#listConversations
128 * @param {function} callback - function to be called when the request completes.
129 */
130
131 }, {
132 key: "next",
133 value: function next(response, callback) {
134 if (response._links.next) {
135 this.get(_Utils2.default.getQuery(response._links.next.href), callback);
136 } else {
137 var error = new Error("The response doesn't have a next page.");
138 callback(error, null);
139 }
140 }
141
142 /**
143 * Get previous page of conversations.
144 *
145 * @param {object} response - The response from a paginated conversations list
146 * see https://ea.developer.nexmo.com/api/conversation#listConversations
147 * @param {function} callback - function to be called when the request completes.
148 */
149
150 }, {
151 key: "prev",
152 value: function prev(response, callback) {
153 if (response._links.prev) {
154 this.get(_Utils2.default.getQuery(response._links.prev.href), callback);
155 } else {
156 var error = new Error("The response doesn't have a previous page.");
157 callback(error, null);
158 }
159 }
160
161 /**
162 * Update an existing conversation.
163 *
164 * @param {string} conversationId - The unique identifier for the conversation to update.
165 * @param {Object} params - Parameters used when updating the conversation.
166 * @param {function} callback - function to be called when the request completes.
167 */
168
169 }, {
170 key: "update",
171 value: function update(conversationId, params, callback) {
172 params = JSON.stringify(params);
173
174 var config = {
175 host: this.options.host || "api.nexmo.com",
176 path: Conversations.PATH + "/" + conversationId,
177 method: "PUT",
178 body: params,
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 * Record an existing conversation.
190 *
191 * @param {string} conversationId - The unique identifier for the conversation to record.
192 * @param {Object} params - Parameters used when recording the conversation.
193 * @param {function} callback - function to be called when the request completes.
194 */
195
196 }, {
197 key: "record",
198 value: function record(conversationId, params, callback) {
199 params = JSON.stringify(params);
200
201 var config = {
202 host: this.options.host || "api.nexmo.com",
203 path: Conversations.V1_PATH + "/" + conversationId + "/record",
204 method: "PUT",
205 body: params,
206 headers: {
207 "Content-Type": "application/json",
208 Authorization: "Bearer " + this.creds.generateJwt()
209 }
210 };
211
212 this.options.httpClient.request(config, callback);
213 }
214
215 /**
216 * Deleta an existing conversation.
217 *
218 * @param {string} conversationId - The unique identifier for the conversation to delete.
219 * @param {function} callback - function to be called when the request completes.
220 */
221
222 }, {
223 key: "delete",
224 value: function _delete(conversationId, callback) {
225 var config = {
226 host: this.options.host || "api.nexmo.com",
227 path: Conversations.PATH + "/" + conversationId,
228 method: "DELETE",
229 headers: {
230 "Content-Type": "application/json",
231 Authorization: "Bearer " + this.creds.generateJwt()
232 }
233 };
234
235 this.options.httpClient.request(config, callback);
236 }
237 }]);
238
239 return Conversations;
240}();
241
242exports.default = Conversations;
243module.exports = exports["default"];
244//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Conversations.js"],"names":["Conversations","credentials","options","creds","members","events","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","conversationId","V1_PATH"],"mappings":"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","file":"Conversations.js","sourcesContent":["\"use strict\";\n\nimport nexmo from \"./index\";\n\nimport Utils from \"./Utils\";\n\nimport Members from \"./Members\";\nimport Events from \"./Events\";\n\n/**\n * Provides access to the `conversations` endpoint.\n */\nclass Conversations {\n  static get PATH() {\n    return \"/v0.1/conversations\";\n  }\n\n  static get V1_PATH() {\n    return \"/v1/conversations\";\n  }\n\n  /**\n   * @param {Credentials} credentials\n   *    credentials to be used when interacting with the API.\n   * @param {Object} options\n   *    Additional Conversations options.\n   */\n  constructor(credentials, options = {}) {\n    this.creds = credentials;\n    this.options = options;\n\n    /**\n     * @type Members\n     */\n    this.members = new Members(this.creds, this.options);\n\n    /**\n     * @type Events\n     */\n    this.events = new Events(this.creds, this.options);\n  }\n\n  /**\n   * Create a new conversation.\n   *\n   * @param {Object} params - Parameters used when creating the conversation. See https://ea.developer.nexmo.com/api/conversation#create-a-conversation 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: Conversations.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 conversation.\n   *\n   * @param {string|object} query - The unique identifier for the conversation 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-a-conversation\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:\n        typeof query === \"string\"\n          ? `${Conversations.PATH}/${query}`\n          : Utils.createPathWithQuery(Conversations.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 conversations.\n   *\n   * @param {object} response - The response from a paginated conversations list\n   *               see https://ea.developer.nexmo.com/api/conversation#listConversations\n   * @param {function} callback - function to be called when the request completes.\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 conversations.\n   *\n   * @param {object} response - The response from a paginated conversations list\n   *               see https://ea.developer.nexmo.com/api/conversation#listConversations\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 conversation.\n   *\n   * @param {string} conversationId - The unique identifier for the conversation 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(conversationId, params, callback) {\n    params = JSON.stringify(params);\n\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Conversations.PATH}/${conversationId}`,\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   * Record an existing conversation.\n   *\n   * @param {string} conversationId - The unique identifier for the conversation to record.\n   * @param {Object} params - Parameters used when recording the conversation.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  record(conversationId, params, callback) {\n    params = JSON.stringify(params);\n\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Conversations.V1_PATH}/${conversationId}/record`,\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 conversation.\n   *\n   * @param {string} conversationId - The unique identifier for the conversation to delete.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  delete(conversationId, callback) {\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Conversations.PATH}/${conversationId}`,\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 Conversations;\n"]}
\No newline at end of file