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 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
18 |
|
19 | function _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 | */
|
24 | var 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 |
|
208 | exports.default = Members;
|
209 | module.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 |