UNPKG

19.3 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 `members` resource.
23 */
24var Members = function () {
25 _createClass(Members, null, [{
26 key: "PATH",
27
28 /**
29 * The path to the `members` resource.
30 */
31 get: function get() {
32 return "/v0.1/conversations/{conversation_uuid}/members";
33 }
34
35 /**
36 * Creates a new Members.
37 *
38 * @param {Credentials} creds - Credentials used when interacting with the Nexmo API.
39 * @param {Object} options - additional options for the class.
40 */
41
42 }]);
43
44 function Members(creds, options) {
45 _classCallCheck(this, Members);
46
47 this.creds = creds;
48 this.options = options;
49 }
50
51 /**
52 * Creates a member in a conversation.
53 *
54 * @param {string} conversationId - The unique identifier for the conversation
55 * @param {Object} params - Parameters used when adding a member to the conversation. See https://ea.developer.nexmo.com/api/conversation#add-a-user-to-a-conversation for more information.
56 * @param {function} callback - function to be called when the request completes.
57 */
58
59
60 _createClass(Members, [{
61 key: "create",
62 value: function create(conversationId, params, callback) {
63 params = JSON.stringify(params);
64
65 var config = {
66 host: this.options.host || "api.nexmo.com",
67 path: Members.PATH.replace("{conversation_uuid}", conversationId),
68 method: "POST",
69 body: params,
70 headers: {
71 "Content-Type": "application/json",
72 Authorization: "Bearer " + this.creds.generateJwt()
73 }
74 };
75 this.options.httpClient.request(config, callback);
76 }
77
78 // backwards compatibility to 2.4.0-beta1. Remove for 3.0.0
79
80 }, {
81 key: "add",
82 value: function add(conversationId, params, callback) {
83 this.create(conversationId, params, callback);
84 }
85
86 /**
87 * Get an existing member.
88 *
89 * @param {string} conversationId - The unique identifier for the conversation
90 * @param {string|object} query - The unique identifier for the member to retrieve
91 * or a set of filter parameters for the query. For more information
92 * see https://ea.developer.nexmo.com/api/conversation#retrieve-members-of-a-conversation
93 * @param {function} callback - function to be called when the request completes.
94 */
95
96 }, {
97 key: "get",
98 value: function get(conversationId, query, callback) {
99 var config = {
100 host: this.options.host || "api.nexmo.com",
101 path: _Utils2.default.createPathWithQuery(Members.PATH.replace("{conversation_uuid}", conversationId), query),
102 method: "GET",
103 body: undefined,
104 headers: {
105 "Content-Type": "application/json",
106 Authorization: "Bearer " + this.creds.generateJwt()
107 }
108 };
109 this.options.httpClient.request(config, callback);
110 }
111
112 /**
113 * Get next page of members for a conversation.
114 *
115 * @param {object} response - The response from a paginated members list
116 * see https://ea.developer.nexmo.com/api/conversation#getMembers
117 * @param {function} callback - function to be called when the request completes.
118 */
119
120 }, {
121 key: "next",
122 value: function next(response, callback) {
123 if (response._links.next) {
124 var conversationId = response._links.next.href.match(/CON-[^/]*/g);
125 this.get(conversationId, _Utils2.default.getQuery(response._links.next.href), callback);
126 } else {
127 var error = new Error("The response doesn't have a next page.");
128 callback(error, null);
129 }
130 }
131
132 /**
133 * Get previous page members for a conversation.
134 *
135 * @param {object} response - The response from a paginated members list
136 * see https://ea.developer.nexmo.com/api/conversation#getMembers
137 * @param {function} callback - function to be called when the request completes.
138 */
139
140 }, {
141 key: "prev",
142 value: function prev(response, callback) {
143 if (response._links.prev) {
144 var conversationId = response._links.prev.href.match(/CON-[^/]*/g);
145 this.get(conversationId, _Utils2.default.getQuery(response._links.prev.href), callback);
146 } else {
147 var error = new Error("The response doesn't have a previous page.");
148 callback(error, null);
149 }
150 }
151
152 /**
153 * Update an existing member.
154 *
155 * @param {string} conversationId - The unique identifier for the conversation to update the member in.
156 * @param {string} memberId - The unique identifier for the member to update.
157 * @param {Object} params - Parameters used when updating the member.
158 * @param {function} callback - function to be called when the request completes.
159 */
160
161 }, {
162 key: "update",
163 value: function update(conversationId, memberId, params, callback) {
164 params = JSON.stringify(params);
165
166 var config = {
167 host: this.options.host || "api.nexmo.com",
168 path: Members.PATH.replace("{conversation_uuid}", conversationId) + "/" + memberId,
169 method: "PUT",
170 body: params,
171 headers: {
172 "Content-Type": "application/json",
173 Authorization: "Bearer " + this.creds.generateJwt()
174 }
175 };
176
177 this.options.httpClient.request(config, callback);
178 }
179
180 /**
181 * Deleta an existing member.
182 *
183 * @param {string} conversationId- The unique identifier for the conversation to delete the member from.
184 * @param {string} memberId - The unique identifier for the member to delete.
185 * @param {function} callback - function to be called when the request completes.
186 */
187
188 }, {
189 key: "delete",
190 value: function _delete(conversationId, memberId, callback) {
191 var config = {
192 host: this.options.host || "api.nexmo.com",
193 path: Members.PATH.replace("{conversation_uuid}", conversationId) + "/" + memberId,
194 method: "DELETE",
195 headers: {
196 "Content-Type": "application/json",
197 Authorization: "Bearer " + this.creds.generateJwt()
198 }
199 };
200
201 this.options.httpClient.request(config, callback);
202 }
203 }]);
204
205 return Members;
206}();
207
208exports.default = Members;
209module.exports = exports["default"];
210//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Members.js"],"names":["Members","creds","options","conversationId","params","callback","JSON","stringify","config","host","path","PATH","replace","method","body","headers","Authorization","generateJwt","httpClient","request","create","query","createPathWithQuery","undefined","response","_links","next","href","match","get","getQuery","error","Error","prev","memberId"],"mappings":"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","file":"Members.js","sourcesContent":["import nexmo from \"./index\";\n\nimport Utils from \"./Utils\";\n\n/**\n * Provides access to the `members` resource.\n */\nclass Members {\n  /**\n   * The path to the `members` resource.\n   */\n  static get PATH() {\n    return \"/v0.1/conversations/{conversation_uuid}/members\";\n  }\n\n  /**\n   * Creates a new Members.\n   *\n   * @param {Credentials} creds - Credentials used when interacting with the Nexmo API.\n   * @param {Object} options - additional options for the class.\n   */\n  constructor(creds, options) {\n    this.creds = creds;\n    this.options = options;\n  }\n\n  /**\n   * Creates a member in a conversation.\n   *\n   * @param {string} conversationId - The unique identifier for the conversation\n   * @param {Object} params - Parameters used when adding a member to the conversation. See https://ea.developer.nexmo.com/api/conversation#add-a-user-to-a-conversation for more information.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  create(conversationId, params, callback) {\n    params = JSON.stringify(params);\n\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: Members.PATH.replace(\"{conversation_uuid}\", conversationId),\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  // backwards compatibility to 2.4.0-beta1. Remove for 3.0.0\n  add(conversationId, params, callback) {\n    this.create(conversationId, params, callback);\n  }\n\n  /**\n   * Get an existing member.\n   *\n   * @param {string} conversationId - The unique identifier for the conversation\n   * @param {string|object} query - The unique identifier for the member 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-members-of-a-conversation\n   * @param {function} callback - function to be called when the request completes.\n   */\n  get(conversationId, query, callback) {\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: Utils.createPathWithQuery(\n        Members.PATH.replace(\"{conversation_uuid}\", conversationId),\n        query\n      ),\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 members for a conversation.\n   *\n   * @param {object} response - The response from a paginated members list\n   *               see https://ea.developer.nexmo.com/api/conversation#getMembers\n   * @param {function} callback - function to be called when the request completes.\n   */\n  next(response, callback) {\n    if (response._links.next) {\n      const conversationId = response._links.next.href.match(/CON-[^/]*/g);\n      this.get(\n        conversationId,\n        Utils.getQuery(response._links.next.href),\n        callback\n      );\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 members for a conversation.\n   *\n   * @param {object} response - The response from a paginated members list\n   *               see https://ea.developer.nexmo.com/api/conversation#getMembers\n   * @param {function} callback - function to be called when the request completes.\n   */\n  prev(response, callback) {\n    if (response._links.prev) {\n      const conversationId = response._links.prev.href.match(/CON-[^/]*/g);\n      this.get(\n        conversationId,\n        Utils.getQuery(response._links.prev.href),\n        callback\n      );\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 member.\n   *\n   * @param {string} conversationId - The unique identifier for the conversation to update the member in.\n   * @param {string} memberId - The unique identifier for the member to update.\n   * @param {Object} params - Parameters used when updating the member.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  update(conversationId, memberId, params, callback) {\n    params = JSON.stringify(params);\n\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Members.PATH.replace(\n        \"{conversation_uuid}\",\n        conversationId\n      )}/${memberId}`,\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 member.\n   *\n   * @param {string} conversationId- The unique identifier for the conversation to delete the member from.\n   * @param {string} memberId - The unique identifier for the member to delete.\n   * @param {function} callback - function to be called when the request completes.\n   */\n  delete(conversationId, memberId, callback) {\n    var config = {\n      host: this.options.host || \"api.nexmo.com\",\n      path: `${Members.PATH.replace(\n        \"{conversation_uuid}\",\n        conversationId\n      )}/${memberId}`,\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 Members;\n"]}
\No newline at end of file