1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 |
|
7 | var _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 |
|
9 | var _index = require("./index");
|
10 |
|
11 | var _index2 = _interopRequireDefault(_index);
|
12 |
|
13 | var _Utils = require("./Utils");
|
14 |
|
15 | var _Utils2 = _interopRequireDefault(_Utils);
|
16 |
|
17 | var _Members = require("./Members");
|
18 |
|
19 | var _Members2 = _interopRequireDefault(_Members);
|
20 |
|
21 | var _Events = require("./Events");
|
22 |
|
23 | var _Events2 = _interopRequireDefault(_Events);
|
24 |
|
25 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
26 |
|
27 | function _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 | */
|
32 | var 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 |
|
242 | exports.default = Conversations;
|
243 | module.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 |