@twilio/mcs-client 0.5.3 → 0.6.0-rc.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +87 -0
- package/builds/browser.js +733 -370
- package/builds/browser.js.map +1 -1
- package/builds/lib.d.ts +55 -26
- package/builds/lib.js +708 -370
- package/builds/lib.js.map +1 -1
- package/builds/twilio-mcs-client.js +3371 -2210
- package/builds/twilio-mcs-client.min.js +3 -17
- package/dist/_virtual/rng-browser.js +34 -0
- package/dist/_virtual/rng-browser.js.map +1 -0
- package/dist/cancellable-promise.js +98 -0
- package/dist/cancellable-promise.js.map +1 -0
- package/dist/client.js +88 -23
- package/dist/client.js.map +1 -1
- package/dist/configuration.js.map +1 -1
- package/dist/index.js +5 -9
- package/dist/index.js.map +1 -1
- package/dist/logger.js +2 -4
- package/dist/logger.js.map +1 -1
- package/dist/media.js +15 -22
- package/dist/media.js.map +1 -1
- package/dist/node_modules/tslib/tslib.es6.js +1 -1
- package/dist/node_modules/tslib/tslib.es6.js.map +1 -1
- package/dist/node_modules/uuid/index.js +44 -0
- package/dist/node_modules/uuid/index.js.map +1 -0
- package/dist/node_modules/uuid/lib/bytesToUuid.js +60 -0
- package/dist/node_modules/uuid/lib/bytesToUuid.js.map +1 -0
- package/dist/node_modules/uuid/lib/rng-browser.js +65 -0
- package/dist/node_modules/uuid/lib/rng-browser.js.map +1 -0
- package/dist/node_modules/uuid/v1.js +146 -0
- package/dist/node_modules/uuid/v1.js.map +1 -0
- package/dist/node_modules/uuid/v4.js +66 -0
- package/dist/node_modules/uuid/v4.js.map +1 -0
- package/dist/packages/mcs-client/package.json.js +1 -1
- package/dist/services/network.js +54 -32
- package/dist/services/network.js.map +1 -1
- package/dist/services/transport.js +26 -11
- package/dist/services/transport.js.map +1 -1
- package/dist/services/transporterror.js.map +1 -1
- package/package.json +16 -14
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/*
|
|
2
|
+
@license
|
|
3
|
+
Copyright (c) 2018, Twilio, Inc.
|
|
4
|
+
|
|
5
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
6
|
+
purpose with or without fee is hereby granted, provided that the above
|
|
7
|
+
copyright notice and this permission notice appear in all copies.
|
|
8
|
+
|
|
9
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
10
|
+
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
11
|
+
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
12
|
+
SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
13
|
+
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
|
14
|
+
OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
15
|
+
CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
16
|
+
|
|
17
|
+
*/
|
|
18
|
+
'use strict';
|
|
19
|
+
|
|
20
|
+
var global =
|
|
21
|
+
typeof global !== "undefined"
|
|
22
|
+
? global
|
|
23
|
+
: typeof self !== "undefined"
|
|
24
|
+
? self
|
|
25
|
+
: typeof window !== "undefined"
|
|
26
|
+
? window
|
|
27
|
+
: {};
|
|
28
|
+
|
|
29
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
30
|
+
|
|
31
|
+
var rngBrowser = {exports: {}};
|
|
32
|
+
|
|
33
|
+
exports.rngBrowser = rngBrowser;
|
|
34
|
+
//# sourceMappingURL=rng-browser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rng-browser.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/*
|
|
2
|
+
@license
|
|
3
|
+
Copyright (c) 2018, Twilio, Inc.
|
|
4
|
+
|
|
5
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
6
|
+
purpose with or without fee is hereby granted, provided that the above
|
|
7
|
+
copyright notice and this permission notice appear in all copies.
|
|
8
|
+
|
|
9
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
10
|
+
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
11
|
+
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
|
|
12
|
+
SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
13
|
+
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
|
|
14
|
+
OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
|
15
|
+
CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
16
|
+
|
|
17
|
+
*/
|
|
18
|
+
'use strict';
|
|
19
|
+
|
|
20
|
+
var global =
|
|
21
|
+
typeof global !== "undefined"
|
|
22
|
+
? global
|
|
23
|
+
: typeof self !== "undefined"
|
|
24
|
+
? self
|
|
25
|
+
: typeof window !== "undefined"
|
|
26
|
+
? window
|
|
27
|
+
: {};
|
|
28
|
+
|
|
29
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
30
|
+
|
|
31
|
+
var index = require('./node_modules/uuid/index.js');
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Cancellable promise. Extends the functionality of the native Promise to include the cancel method.
|
|
35
|
+
*
|
|
36
|
+
* Example:
|
|
37
|
+
*
|
|
38
|
+
* ```ts
|
|
39
|
+
*
|
|
40
|
+
* const cancellableFetchPromise = new CancellablePromise(async (resolve, reject, onCancel) => {
|
|
41
|
+
* const request = fetch("https://example.com/");
|
|
42
|
+
*
|
|
43
|
+
* onCancel(() => request.cancel());
|
|
44
|
+
*
|
|
45
|
+
* try {
|
|
46
|
+
* const response = await request;
|
|
47
|
+
* resolve(response);
|
|
48
|
+
* } catch (err) {
|
|
49
|
+
* reject(err);
|
|
50
|
+
* }
|
|
51
|
+
* });
|
|
52
|
+
*
|
|
53
|
+
* cancellableFetchPromise.cancel();
|
|
54
|
+
* ```
|
|
55
|
+
*/
|
|
56
|
+
class CancellablePromise extends Promise {
|
|
57
|
+
/**
|
|
58
|
+
* Creates a new CancellablePromise.
|
|
59
|
+
* @param executor A callback used to initialize the promise. This callback is passed three arguments:
|
|
60
|
+
* a resolve callback used to resolve the promise with a value or the result of another promise,
|
|
61
|
+
* a reject callback used to reject the promise with a provided reason or error,
|
|
62
|
+
* and an onCancel callback used to define behavior of cancellation.
|
|
63
|
+
*/
|
|
64
|
+
constructor(executor) {
|
|
65
|
+
const outerId = index["default"].v4();
|
|
66
|
+
let outerRejectPromise;
|
|
67
|
+
super((resolve, reject) => {
|
|
68
|
+
outerRejectPromise = reject;
|
|
69
|
+
return executor((value) => {
|
|
70
|
+
CancellablePromise.cancellationMap.delete(outerId);
|
|
71
|
+
resolve(value);
|
|
72
|
+
}, (reason) => {
|
|
73
|
+
CancellablePromise.cancellationMap.delete(outerId);
|
|
74
|
+
reject(reason);
|
|
75
|
+
}, (cancellationFunction) => {
|
|
76
|
+
CancellablePromise.cancellationMap.set(outerId, cancellationFunction);
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
this.id = outerId;
|
|
80
|
+
this.rejectPromise = outerRejectPromise;
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Cancels the promise and invokes the cancellation callback if it was defined during instantiation. Cancellation will result in the promise being rejected.
|
|
84
|
+
*/
|
|
85
|
+
cancel() {
|
|
86
|
+
const onCancel = CancellablePromise.cancellationMap.get(this.id);
|
|
87
|
+
onCancel === null || onCancel === void 0 ? void 0 : onCancel();
|
|
88
|
+
if (this.rejectPromise) {
|
|
89
|
+
this.catch(() => void 0);
|
|
90
|
+
this.rejectPromise(new Error("Promise was cancelled"));
|
|
91
|
+
}
|
|
92
|
+
return this;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
CancellablePromise.cancellationMap = new Map();
|
|
96
|
+
|
|
97
|
+
exports.CancellablePromise = CancellablePromise;
|
|
98
|
+
//# sourceMappingURL=cancellable-promise.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cancellable-promise.js","sources":["../src/cancellable-promise.ts"],"sourcesContent":["import { v4 as uuidv4 } from \"uuid\";\n\n/**\n * Cancellable promise. Extends the functionality of the native Promise to include the cancel method.\n *\n * Example:\n *\n * ```ts\n *\n * const cancellableFetchPromise = new CancellablePromise(async (resolve, reject, onCancel) => {\n * const request = fetch(\"https://example.com/\");\n *\n * onCancel(() => request.cancel());\n *\n * try {\n * const response = await request;\n * resolve(response);\n * } catch (err) {\n * reject(err);\n * }\n * });\n *\n * cancellableFetchPromise.cancel();\n * ```\n */\nclass CancellablePromise<T> extends Promise<T> {\n private readonly id: string;\n private rejectPromise?: (reason?: any) => void;\n\n private static readonly cancellationMap: Map<string, () => void> = new Map();\n\n /**\n * Creates a new CancellablePromise.\n * @param executor A callback used to initialize the promise. This callback is passed three arguments:\n * a resolve callback used to resolve the promise with a value or the result of another promise,\n * a reject callback used to reject the promise with a provided reason or error,\n * and an onCancel callback used to define behavior of cancellation.\n */\n constructor(\n executor: (\n resolve: (value: T | PromiseLike<T>) => void,\n reject: (reason?: string | Error) => void,\n onCancel: (cancellationFunction: () => void) => void\n ) => void\n ) {\n const outerId = uuidv4();\n let outerRejectPromise!: (reason?: any) => void;\n\n super((resolve, reject) => {\n outerRejectPromise = reject;\n return executor(\n (value: T | PromiseLike<T>) => {\n CancellablePromise.cancellationMap.delete(outerId);\n resolve(value);\n },\n (reason?: string | Error) => {\n CancellablePromise.cancellationMap.delete(outerId);\n reject(reason);\n },\n (cancellationFunction: () => void) => {\n CancellablePromise.cancellationMap.set(outerId, cancellationFunction);\n }\n );\n });\n\n this.id = outerId;\n this.rejectPromise = outerRejectPromise;\n }\n\n /**\n * Cancels the promise and invokes the cancellation callback if it was defined during instantiation. Cancellation will result in the promise being rejected.\n */\n cancel(): this {\n const onCancel = CancellablePromise.cancellationMap.get(this.id);\n\n onCancel?.();\n\n if (this.rejectPromise) {\n this.catch(() => void 0);\n this.rejectPromise(new Error(\"Promise was cancelled\"));\n }\n\n return this;\n }\n}\n\nexport { CancellablePromise };\n"],"names":["uuidv4"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA;;;;;;;;;;;;;;;;;;;;;;AAsBG;AACH,MAAM,kBAAsB,SAAQ,OAAU,CAAA;AAM5C;;;;;;AAMG;AACH,IAAA,WAAA,CACE,QAIS,EAAA;AAET,QAAA,MAAM,OAAO,GAAGA,mBAAM,EAAE,CAAC;AACzB,QAAA,IAAI,kBAA2C,CAAC;AAEhD,QAAA,KAAK,CAAC,CAAC,OAAO,EAAE,MAAM,KAAI;YACxB,kBAAkB,GAAG,MAAM,CAAC;AAC5B,YAAA,OAAO,QAAQ,CACb,CAAC,KAAyB,KAAI;AAC5B,gBAAA,kBAAkB,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACnD,OAAO,CAAC,KAAK,CAAC,CAAC;AACjB,aAAC,EACD,CAAC,MAAuB,KAAI;AAC1B,gBAAA,kBAAkB,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACnD,MAAM,CAAC,MAAM,CAAC,CAAC;AACjB,aAAC,EACD,CAAC,oBAAgC,KAAI;gBACnC,kBAAkB,CAAC,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;AACxE,aAAC,CACF,CAAC;AACJ,SAAC,CAAC,CAAC;AAEH,QAAA,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC;AAClB,QAAA,IAAI,CAAC,aAAa,GAAG,kBAAkB,CAAC;KACzC;AAED;;AAEG;IACH,MAAM,GAAA;AACJ,QAAA,MAAM,QAAQ,GAAG,kBAAkB,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;AAEjE,QAAA,QAAQ,KAAR,IAAA,IAAA,QAAQ,KAAR,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,QAAQ,EAAI,CAAC;QAEb,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;YACzB,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC,CAAC;AACxD,SAAA;AAED,QAAA,OAAO,IAAI,CAAC;KACb;;AAtDuB,kBAAA,CAAA,eAAe,GAA4B,IAAI,GAAG,EAAE;;;;"}
|
package/dist/client.js
CHANGED
|
@@ -36,6 +36,7 @@ var transport = require('./services/transport.js');
|
|
|
36
36
|
var network = require('./services/network.js');
|
|
37
37
|
var _package = require('./packages/mcs-client/package.json.js');
|
|
38
38
|
var declarativeTypeValidator = require('@twilio/declarative-type-validator');
|
|
39
|
+
var cancellablePromise = require('./cancellable-promise.js');
|
|
39
40
|
|
|
40
41
|
const log = logger.Logger.scope("");
|
|
41
42
|
/**
|
|
@@ -79,22 +80,38 @@ exports.Client = class Client {
|
|
|
79
80
|
/**
|
|
80
81
|
* Gets media from media service
|
|
81
82
|
* @param {String} sid - Media's SID
|
|
82
|
-
* @returns {Promise<Media>}
|
|
83
83
|
*/
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
84
|
+
get(sid) {
|
|
85
|
+
return new cancellablePromise.CancellablePromise(async (resolve, reject, onCancel) => {
|
|
86
|
+
const request = this.network.get(`${this.config.mediaUrl}/${sid}`);
|
|
87
|
+
onCancel(() => request.cancel());
|
|
88
|
+
try {
|
|
89
|
+
const response = await request;
|
|
90
|
+
resolve(new media.Media(this.config, this.network, response.body));
|
|
91
|
+
}
|
|
92
|
+
catch (e) {
|
|
93
|
+
reject(e);
|
|
94
|
+
}
|
|
95
|
+
});
|
|
87
96
|
}
|
|
88
97
|
/**
|
|
89
98
|
* Posts raw content to media service
|
|
90
99
|
* @param {String} contentType - content type of media
|
|
91
100
|
* @param {String|Buffer|Blob} media - content to post
|
|
92
101
|
* @param {MediaCategory|null} category - category for the media
|
|
93
|
-
* @returns {Promise<Media>}
|
|
94
102
|
*/
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
103
|
+
post(contentType, media$1, category, filename) {
|
|
104
|
+
return new cancellablePromise.CancellablePromise(async (resolve, reject, onCancel) => {
|
|
105
|
+
const request = this.network.post(this.config.mediaUrl, category !== null && category !== void 0 ? category : "media", media$1, contentType, filename);
|
|
106
|
+
onCancel(() => request.cancel());
|
|
107
|
+
try {
|
|
108
|
+
const response = await request;
|
|
109
|
+
resolve(new media.Media(this.config, this.network, response.body));
|
|
110
|
+
}
|
|
111
|
+
catch (e) {
|
|
112
|
+
reject(e);
|
|
113
|
+
}
|
|
114
|
+
});
|
|
98
115
|
}
|
|
99
116
|
/**
|
|
100
117
|
* Posts FormData to media service. Can be used only with browser engine's FormData.
|
|
@@ -102,27 +119,75 @@ exports.Client = class Client {
|
|
|
102
119
|
* new TypeError("Posting FormData supported only with browser engine's FormData")
|
|
103
120
|
* @param {FormData} formData - form data to post
|
|
104
121
|
* @param {MediaCategory|null} category - category for the media
|
|
105
|
-
* @returns {Promise<Media>}
|
|
106
122
|
*/
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
123
|
+
postFormData(formData, category) {
|
|
124
|
+
return new cancellablePromise.CancellablePromise(async (resolve, reject, onCancel) => {
|
|
125
|
+
const request = this.network.post(this.config.mediaUrl, category !== null && category !== void 0 ? category : "media", formData);
|
|
126
|
+
onCancel(() => request.cancel());
|
|
127
|
+
try {
|
|
128
|
+
const response = await request;
|
|
129
|
+
resolve(new media.Media(this.config, this.network, response.body));
|
|
130
|
+
}
|
|
131
|
+
catch (e) {
|
|
132
|
+
reject(e);
|
|
133
|
+
}
|
|
134
|
+
});
|
|
110
135
|
}
|
|
111
136
|
/**
|
|
112
137
|
* Retrieve information about multiple media SIDs at the same time.
|
|
113
138
|
* @param mediaSids Array of Media SIDs to get information from.
|
|
114
139
|
*/
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
140
|
+
mediaSetGet(mediaSids) {
|
|
141
|
+
return new cancellablePromise.CancellablePromise(async (resolve, reject, onCancel) => {
|
|
142
|
+
const query = {
|
|
143
|
+
command: "get",
|
|
144
|
+
list: mediaSids.map((sid) => ({ media_sid: sid })),
|
|
145
|
+
};
|
|
146
|
+
const request = this.network.post(`${this.config.mediaSetUrl}`, null, query, "application/json");
|
|
147
|
+
onCancel(() => request.cancel());
|
|
148
|
+
try {
|
|
149
|
+
const response = await request;
|
|
150
|
+
const media$1 = response.body.map((item) => {
|
|
151
|
+
if (item.code !== 200) {
|
|
152
|
+
reject(`Failed to obtain detailed information about Media items (failed SID ${item.media_record.sid})`);
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
return new media.Media(this.config, this.network, item.media_record);
|
|
156
|
+
});
|
|
157
|
+
resolve(media$1);
|
|
158
|
+
}
|
|
159
|
+
catch (e) {
|
|
160
|
+
reject(e);
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Retrieve temporary URLs for a set of media SIDs.
|
|
166
|
+
* @param mediaSids array of the media SIDs to get URLs from.
|
|
167
|
+
*/
|
|
168
|
+
mediaSetGetContentUrls(mediaSids) {
|
|
169
|
+
return new cancellablePromise.CancellablePromise(async (resolve, reject, onCancel) => {
|
|
170
|
+
const query = {
|
|
171
|
+
command: "get",
|
|
172
|
+
list: mediaSids.map((sid) => ({ media_sid: sid })),
|
|
173
|
+
};
|
|
174
|
+
const request = this.network.post(`${this.config.mediaSetUrl}`, null, query, "application/json");
|
|
175
|
+
onCancel(() => request.cancel());
|
|
176
|
+
try {
|
|
177
|
+
const response = await request;
|
|
178
|
+
const urls = new Map();
|
|
179
|
+
response.body.forEach((item) => {
|
|
180
|
+
if (item.code !== 200) {
|
|
181
|
+
reject(`Failed to obtain detailed information about Media items (failed SID ${item.media_record.sid})`);
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
urls.set(item.media_record.sid, item.media_record.links.content_direct_temporary);
|
|
185
|
+
});
|
|
186
|
+
resolve(urls);
|
|
187
|
+
}
|
|
188
|
+
catch (e) {
|
|
189
|
+
reject(e);
|
|
124
190
|
}
|
|
125
|
-
return new media.Media(this.config, this.network, item.media_record);
|
|
126
191
|
});
|
|
127
192
|
}
|
|
128
193
|
};
|
|
@@ -137,7 +202,7 @@ tslib_es6.__decorate([
|
|
|
137
202
|
declarativeTypeValidator.validateTypesAsync(declarativeTypeValidator.nonEmptyString),
|
|
138
203
|
tslib_es6.__metadata("design:type", Function),
|
|
139
204
|
tslib_es6.__metadata("design:paramtypes", [String]),
|
|
140
|
-
tslib_es6.__metadata("design:returntype",
|
|
205
|
+
tslib_es6.__metadata("design:returntype", cancellablePromise.CancellablePromise)
|
|
141
206
|
], exports.Client.prototype, "get", null);
|
|
142
207
|
exports.Client = tslib_es6.__decorate([
|
|
143
208
|
declarativeTypeValidator.validateConstructorTypes(declarativeTypeValidator.nonEmptyString, declarativeTypeValidator.nonEmptyString, [declarativeTypeValidator.nonEmptyString, declarativeTypeValidator.literal(null)], [declarativeTypeValidator.pureObject, "undefined"]),
|
package/dist/client.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.js","sources":["../src/client.ts"],"sourcesContent":["import { Logger } from \"./logger\";\nimport { Configuration } from \"./configuration\";\nimport { Media, MediaCategory, MediaResponse } from \"./media\";\nimport { Transport } from \"./services/transport\";\nimport { Network } from \"./services/network\";\nimport { version } from \"../package.json\";\nimport * as loglevel from \"loglevel\";\nimport {\n validateTypesAsync,\n validateTypes,\n nonEmptyString,\n literal,\n pureObject,\n validateConstructorTypes,\n} from \"@twilio/declarative-type-validator\";\n\nconst log = Logger.scope(\"\");\n//log.setLevel('trace');\n\nexport type LogLevel = loglevel.LogLevelDesc | null;\n\nexport interface Options {\n region?: string;\n logLevel?: loglevel.LogLevelDesc;\n transport?: Transport;\n}\n\n/**\n * @classdesc A Client provides an interface for Media Content Service\n */\n@validateConstructorTypes(\n nonEmptyString,\n nonEmptyString,\n [nonEmptyString, literal(null)],\n [pureObject, \"undefined\"]\n)\nclass Client {\n // eslint-disable-next-line\n private readonly transport: any;\n private options: Options;\n private network: Network;\n private config: Configuration;\n public static readonly version: string = version;\n\n /**\n * Base URLs must be full URLs with host. If host is not provided it will be generated from a default configuration\n * template using options.region.\n *\n * @param {String} token - Access token\n * @param {String} baseUrl - Base URL for Media Content Service Media resource, i.e. /v1/Services/{serviceSid}/Media\n * @param {String} baseSetUrl - Base URL for Media Content Service MediaSet resource, i.e. /v1/Services/{serviceSid}/MediaSet\n * @param {Client#ClientOptions} [options] - Options to customize the Client\n */\n constructor(\n token: string,\n baseUrl: string,\n baseSetUrl: string | null,\n options: Options = {}\n ) {\n this.options = options;\n this.options.logLevel = this.options.logLevel ?? \"silent\";\n this.config = new Configuration(token, baseUrl, baseSetUrl, this.options);\n\n log.setLevel(this.options.logLevel);\n\n this.options.transport = this.options.transport ?? new Transport();\n\n this.transport = this.options.transport;\n this.network = new Network(this.config, this.transport);\n }\n\n /**\n * These options can be passed to Client constructor\n * @typedef {Object} Client#ClientOptions\n * @property {String} [logLevel='silent'] - The level of logging to enable. Valid options\n * (from strictest to broadest): ['silent', 'error', 'warn', 'info', 'debug', 'trace']\n */\n\n /**\n * Update the token used for Client operations\n * @param {String} token - The JWT string of the new token\n * @returns {void}\n */\n @validateTypes(nonEmptyString)\n public updateToken(token: string): void {\n log.info(\"updateToken\");\n this.config.updateToken(token);\n }\n\n /**\n * Gets media from media service\n * @param {String} sid - Media's SID\n * @returns {Promise<Media>}\n */\n @validateTypesAsync(nonEmptyString)\n public async get(sid: string): Promise<Media> {\n const response = await this.network.get(`${this.config.mediaUrl}/${sid}`);\n return new Media(this.config, this.network, response.body);\n }\n\n /**\n * Posts raw content to media service\n * @param {String} contentType - content type of media\n * @param {String|Buffer|Blob} media - content to post\n * @param {MediaCategory|null} category - category for the media\n * @returns {Promise<Media>}\n */\n public async post(\n contentType: string,\n media: string | Buffer | Blob,\n category: MediaCategory | null,\n filename?: string\n ): Promise<Media> {\n const response = await this.network.post(\n this.config.mediaUrl,\n category ?? \"media\",\n media,\n contentType,\n filename\n );\n return new Media(this.config, this.network, response.body);\n }\n\n /**\n * Posts FormData to media service. Can be used only with browser engine's FormData.\n * In non-browser FormData case the method will do promise reject with\n * new TypeError(\"Posting FormData supported only with browser engine's FormData\")\n * @param {FormData} formData - form data to post\n * @param {MediaCategory|null} category - category for the media\n * @returns {Promise<Media>}\n */\n public async postFormData(\n formData: FormData,\n category?: MediaCategory | null\n ): Promise<Media> {\n const response = await this.network.post(\n this.config.mediaUrl,\n category ?? \"media\",\n formData\n );\n return new Media(this.config, this.network, response.body);\n }\n\n /**\n * Retrieve information about multiple media SIDs at the same time.\n * @param mediaSids Array of Media SIDs to get information from.\n */\n public async mediaSetGet(mediaSids: string[]): Promise<Media[]> {\n const query = {\n command: \"get\",\n list: mediaSids.map((sid) => ({ media_sid: sid })),\n };\n const response = await this.network.post(\n `${this.config.mediaSetUrl}`,\n null,\n query,\n \"application/json\"\n );\n return response.body.map((item) => {\n if (item.code !== 200) {\n throw new Error(\n `Failed to obtain detailed information about Media items (failed SID ${item.media_record.sid})`\n );\n }\n return new Media(this.config, this.network, item.media_record);\n });\n }\n}\n\n// Proper renames should happen in index.ts,\n// otherwise it might screw up exported TS types information.\nexport { Client, Media, MediaCategory };\n"],"names":["Logger","Client","Configuration","Transport","Network","Media","media","version","__decorate","validateTypes","nonEmptyString","validateTypesAsync","validateConstructorTypes","literal","pureObject"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"client.js","sources":["../src/client.ts"],"sourcesContent":["import { Logger } from \"./logger\";\nimport { Configuration } from \"./configuration\";\nimport { Media, MediaCategory } from \"./media\";\nimport { Transport } from \"./services/transport\";\nimport { Network } from \"./services/network\";\nimport { version } from \"../package.json\";\nimport * as loglevel from \"loglevel\";\nimport {\n validateTypesAsync,\n validateTypes,\n nonEmptyString,\n literal,\n pureObject,\n validateConstructorTypes,\n} from \"@twilio/declarative-type-validator\";\nimport { CancellablePromise } from \"./cancellable-promise\";\n\nconst log = Logger.scope(\"\");\n//log.setLevel('trace');\n\nexport type LogLevel = loglevel.LogLevelDesc | null;\n\nexport interface Options {\n region?: string;\n logLevel?: loglevel.LogLevelDesc;\n transport?: Transport;\n}\n\n/**\n * @classdesc A Client provides an interface for Media Content Service\n */\n@validateConstructorTypes(\n nonEmptyString,\n nonEmptyString,\n [nonEmptyString, literal(null)],\n [pureObject, \"undefined\"]\n)\nclass Client {\n // eslint-disable-next-line\n private readonly transport: any;\n private options: Options;\n private network: Network;\n private config: Configuration;\n public static readonly version: string = version;\n\n /**\n * Base URLs must be full URLs with host. If host is not provided it will be generated from a default configuration\n * template using options.region.\n *\n * @param {String} token - Access token\n * @param {String} baseUrl - Base URL for Media Content Service Media resource, i.e. /v1/Services/{serviceSid}/Media\n * @param {String} baseSetUrl - Base URL for Media Content Service MediaSet resource, i.e. /v1/Services/{serviceSid}/MediaSet\n * @param {Client#ClientOptions} [options] - Options to customize the Client\n */\n constructor(\n token: string,\n baseUrl: string,\n baseSetUrl: string | null,\n options: Options = {}\n ) {\n this.options = options;\n this.options.logLevel = this.options.logLevel ?? \"silent\";\n this.config = new Configuration(token, baseUrl, baseSetUrl, this.options);\n\n log.setLevel(this.options.logLevel);\n\n this.options.transport = this.options.transport ?? new Transport();\n\n this.transport = this.options.transport;\n this.network = new Network(this.config, this.transport);\n }\n\n /**\n * These options can be passed to Client constructor\n * @typedef {Object} Client#ClientOptions\n * @property {String} [logLevel='silent'] - The level of logging to enable. Valid options\n * (from strictest to broadest): ['silent', 'error', 'warn', 'info', 'debug', 'trace']\n */\n\n /**\n * Update the token used for Client operations\n * @param {String} token - The JWT string of the new token\n * @returns {void}\n */\n @validateTypes(nonEmptyString)\n public updateToken(token: string): void {\n log.info(\"updateToken\");\n this.config.updateToken(token);\n }\n\n /**\n * Gets media from media service\n * @param {String} sid - Media's SID\n */\n @validateTypesAsync(nonEmptyString)\n public get(sid: string): CancellablePromise<Media> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n const request = this.network.get(`${this.config.mediaUrl}/${sid}`);\n\n onCancel(() => request.cancel());\n\n try {\n const response = await request;\n resolve(new Media(this.config, this.network, response.body));\n } catch (e) {\n reject(e);\n }\n });\n }\n\n /**\n * Posts raw content to media service\n * @param {String} contentType - content type of media\n * @param {String|Buffer|Blob} media - content to post\n * @param {MediaCategory|null} category - category for the media\n */\n public post(\n contentType: string,\n media: string | Buffer | Blob,\n category: MediaCategory | null,\n filename?: string\n ): CancellablePromise<Media> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n const request = this.network.post(\n this.config.mediaUrl,\n category ?? \"media\",\n media,\n contentType,\n filename\n );\n\n onCancel(() => request.cancel());\n\n try {\n const response = await request;\n resolve(new Media(this.config, this.network, response.body));\n } catch (e) {\n reject(e);\n }\n });\n }\n\n /**\n * Posts FormData to media service. Can be used only with browser engine's FormData.\n * In non-browser FormData case the method will do promise reject with\n * new TypeError(\"Posting FormData supported only with browser engine's FormData\")\n * @param {FormData} formData - form data to post\n * @param {MediaCategory|null} category - category for the media\n */\n public postFormData(\n formData: FormData,\n category?: MediaCategory | null\n ): CancellablePromise<Media> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n const request = this.network.post(\n this.config.mediaUrl,\n category ?? \"media\",\n formData\n );\n\n onCancel(() => request.cancel());\n\n try {\n const response = await request;\n resolve(new Media(this.config, this.network, response.body));\n } catch (e) {\n reject(e);\n }\n });\n }\n\n /**\n * Retrieve information about multiple media SIDs at the same time.\n * @param mediaSids Array of Media SIDs to get information from.\n */\n public mediaSetGet(mediaSids: string[]): CancellablePromise<Media[]> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n const query = {\n command: \"get\",\n list: mediaSids.map((sid) => ({ media_sid: sid })),\n };\n const request = this.network.post(\n `${this.config.mediaSetUrl}`,\n null,\n query,\n \"application/json\"\n );\n\n onCancel(() => request.cancel());\n\n try {\n const response = await request;\n const media = response.body.map((item) => {\n if (item.code !== 200) {\n reject(\n `Failed to obtain detailed information about Media items (failed SID ${item.media_record.sid})`\n );\n return;\n }\n return new Media(this.config, this.network, item.media_record);\n });\n\n resolve(media);\n } catch (e) {\n reject(e);\n }\n });\n }\n\n /**\n * Retrieve temporary URLs for a set of media SIDs.\n * @param mediaSids array of the media SIDs to get URLs from.\n */\n public mediaSetGetContentUrls(\n mediaSids: string[]\n ): CancellablePromise<Map<string, string>> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n const query = {\n command: \"get\",\n list: mediaSids.map((sid) => ({ media_sid: sid })),\n };\n const request = this.network.post(\n `${this.config.mediaSetUrl}`,\n null,\n query,\n \"application/json\"\n );\n\n onCancel(() => request.cancel());\n\n try {\n const response = await request;\n const urls = new Map();\n response.body.forEach((item) => {\n if (item.code !== 200) {\n reject(\n `Failed to obtain detailed information about Media items (failed SID ${item.media_record.sid})`\n );\n return;\n }\n urls.set(\n item.media_record.sid,\n item.media_record.links.content_direct_temporary\n );\n });\n\n resolve(urls);\n } catch (e) {\n reject(e);\n }\n });\n }\n}\n\n// Proper renames should happen in index.ts,\n// otherwise it might screw up exported TS types information.\nexport { Client, Media, MediaCategory };\n"],"names":["Logger","Client","Configuration","Transport","Network","CancellablePromise","Media","media","version","__decorate","validateTypes","nonEmptyString","validateTypesAsync","validateConstructorTypes","literal","pureObject"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"configuration.js","sources":["../src/configuration.ts"],"sourcesContent":["import * as log from \"loglevel\";\nimport { Transport } from \"./services/transport\";\n\nconst MINIMUM_RETRY_DELAY = 1000;\nconst MAXIMUM_RETRY_DELAY = 4000;\nconst MAXIMUM_ATTEMPTS_COUNT = 3;\nconst RETRY_WHEN_THROTTLED = true;\n\nconst regionalMcsHost = (region?: string): string =>\n `https://mcs.${region ?? \"us1\"}.twilio.com`;\n\nconst isFullUrl = (url: string): boolean => url.startsWith(\"http\");\n\nconst fullUrl = (partUrl: string, region?: string): string =>\n `${!isFullUrl(partUrl) ? regionalMcsHost(region) : \"\"}${partUrl}`;\n\nexport interface BackoffOverride {\n max: number;\n min: number;\n maxAttemptsCount?: number;\n}\n\nexport interface McsOptions {\n region?: string;\n retryWhenThrottledOverride?: boolean;\n backoffConfigOverride?: BackoffOverride;\n}\n\nexport interface Options {\n region?: string;\n logLevel?: log.LogLevelDesc;\n transport?: Transport;\n retryWhenThrottledOverride?: boolean;\n backoffConfigOverride?: BackoffOverride;\n MCS?: McsOptions;\n}\n\nclass Configuration {\n token: string;\n public readonly retryWhenThrottledOverride: boolean;\n public readonly backoffConfigOverride: BackoffOverride;\n public readonly mediaUrl: string;\n public readonly mediaSetUrl: string;\n private readonly region: string;\n\n constructor(\n token: string,\n baseUrl: string,\n baseSetUrl: string | null,\n options: Options\n ) {\n const constructorOptions = options.MCS ?? options ?? {};\n this.region = constructorOptions.region ?? options.region ?? 'us1';\n this.mediaUrl = fullUrl(baseUrl, this.region);\n this.mediaSetUrl = baseSetUrl ? fullUrl(baseSetUrl) : `${this.mediaUrl}Set`;\n this.token = token;\n this.retryWhenThrottledOverride =\n constructorOptions.retryWhenThrottledOverride ?? RETRY_WHEN_THROTTLED;\n this.backoffConfigOverride = constructorOptions.backoffConfigOverride ?? Configuration.backoffConfigDefault;\n }\n\n public static get backoffConfigDefault(): BackoffOverride {\n return {\n min: MINIMUM_RETRY_DELAY,\n max: MAXIMUM_RETRY_DELAY,\n maxAttemptsCount: MAXIMUM_ATTEMPTS_COUNT,\n };\n }\n\n public static get retryWhenThrottledDefault(): boolean {\n return RETRY_WHEN_THROTTLED;\n }\n\n public updateToken(token: string): void {\n this.token = token;\n }\n}\n\nexport { Configuration };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,MAAM,mBAAmB,GAAG,IAAI,CAAC;AACjC,MAAM,mBAAmB,GAAG,IAAI,CAAC;AACjC,MAAM,sBAAsB,GAAG,CAAC,CAAC;AACjC,MAAM,oBAAoB,GAAG,IAAI,CAAC;AAElC,MAAM,eAAe,GAAG,CAAC,MAAe,KACtC,
|
|
1
|
+
{"version":3,"file":"configuration.js","sources":["../src/configuration.ts"],"sourcesContent":["import * as log from \"loglevel\";\nimport { Transport } from \"./services/transport\";\n\nconst MINIMUM_RETRY_DELAY = 1000;\nconst MAXIMUM_RETRY_DELAY = 4000;\nconst MAXIMUM_ATTEMPTS_COUNT = 3;\nconst RETRY_WHEN_THROTTLED = true;\n\nconst regionalMcsHost = (region?: string): string =>\n `https://mcs.${region ?? \"us1\"}.twilio.com`;\n\nconst isFullUrl = (url: string): boolean => url.startsWith(\"http\");\n\nconst fullUrl = (partUrl: string, region?: string): string =>\n `${!isFullUrl(partUrl) ? regionalMcsHost(region) : \"\"}${partUrl}`;\n\nexport interface BackoffOverride {\n max: number;\n min: number;\n maxAttemptsCount?: number;\n}\n\nexport interface McsOptions {\n region?: string;\n retryWhenThrottledOverride?: boolean;\n backoffConfigOverride?: BackoffOverride;\n}\n\nexport interface Options {\n region?: string;\n logLevel?: log.LogLevelDesc;\n transport?: Transport;\n retryWhenThrottledOverride?: boolean;\n backoffConfigOverride?: BackoffOverride;\n MCS?: McsOptions;\n}\n\nclass Configuration {\n token: string;\n public readonly retryWhenThrottledOverride: boolean;\n public readonly backoffConfigOverride: BackoffOverride;\n public readonly mediaUrl: string;\n public readonly mediaSetUrl: string;\n private readonly region: string;\n\n constructor(\n token: string,\n baseUrl: string,\n baseSetUrl: string | null,\n options: Options\n ) {\n const constructorOptions = options.MCS ?? options ?? {};\n this.region = constructorOptions.region ?? options.region ?? 'us1';\n this.mediaUrl = fullUrl(baseUrl, this.region);\n this.mediaSetUrl = baseSetUrl ? fullUrl(baseSetUrl) : `${this.mediaUrl}Set`;\n this.token = token;\n this.retryWhenThrottledOverride =\n constructorOptions.retryWhenThrottledOverride ?? RETRY_WHEN_THROTTLED;\n this.backoffConfigOverride = constructorOptions.backoffConfigOverride ?? Configuration.backoffConfigDefault;\n }\n\n public static get backoffConfigDefault(): BackoffOverride {\n return {\n min: MINIMUM_RETRY_DELAY,\n max: MAXIMUM_RETRY_DELAY,\n maxAttemptsCount: MAXIMUM_ATTEMPTS_COUNT,\n };\n }\n\n public static get retryWhenThrottledDefault(): boolean {\n return RETRY_WHEN_THROTTLED;\n }\n\n public updateToken(token: string): void {\n this.token = token;\n }\n}\n\nexport { Configuration };\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,MAAM,mBAAmB,GAAG,IAAI,CAAC;AACjC,MAAM,mBAAmB,GAAG,IAAI,CAAC;AACjC,MAAM,sBAAsB,GAAG,CAAC,CAAC;AACjC,MAAM,oBAAoB,GAAG,IAAI,CAAC;AAElC,MAAM,eAAe,GAAG,CAAC,MAAe,KACtC,CAAA,YAAA,EAAe,MAAM,KAAA,IAAA,IAAN,MAAM,KAAN,KAAA,CAAA,GAAA,MAAM,GAAI,KAAK,aAAa,CAAC;AAE9C,MAAM,SAAS,GAAG,CAAC,GAAW,KAAc,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAEnE,MAAM,OAAO,GAAG,CAAC,OAAe,EAAE,MAAe,KAC/C,CAAA,EAAG,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,eAAe,CAAC,MAAM,CAAC,GAAG,EAAE,CAAG,EAAA,OAAO,EAAE,CAAC;AAuBpE,MAAM,aAAa,CAAA;AAQjB,IAAA,WAAA,CACE,KAAa,EACb,OAAe,EACf,UAAyB,EACzB,OAAgB,EAAA;;QAEhB,MAAM,kBAAkB,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,OAAO,CAAC,GAAG,MAAI,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAA,OAAO,MAAI,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAA,EAAE,CAAC;AACxD,QAAA,IAAI,CAAC,MAAM,GAAG,CAAA,EAAA,GAAA,MAAA,kBAAkB,CAAC,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,OAAO,CAAC,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,KAAK,CAAC;QACnE,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;AAC9C,QAAA,IAAI,CAAC,WAAW,GAAG,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,CAAA,EAAG,IAAI,CAAC,QAAQ,KAAK,CAAC;AAC5E,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;AACnB,QAAA,IAAI,CAAC,0BAA0B;AAC7B,YAAA,CAAA,EAAA,GAAA,kBAAkB,CAAC,0BAA0B,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,oBAAoB,CAAC;QACxE,IAAI,CAAC,qBAAqB,GAAG,CAAA,EAAA,GAAA,kBAAkB,CAAC,qBAAqB,MAAI,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAA,aAAa,CAAC,oBAAoB,CAAC;KAC7G;AAEM,IAAA,WAAW,oBAAoB,GAAA;QACpC,OAAO;AACL,YAAA,GAAG,EAAE,mBAAmB;AACxB,YAAA,GAAG,EAAE,mBAAmB;AACxB,YAAA,gBAAgB,EAAE,sBAAsB;SACzC,CAAC;KACH;AAEM,IAAA,WAAW,yBAAyB,GAAA;AACzC,QAAA,OAAO,oBAAoB,CAAC;KAC7B;AAEM,IAAA,WAAW,CAAC,KAAa,EAAA;AAC9B,QAAA,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;KACpB;AACF;;;;"}
|
package/dist/index.js
CHANGED
|
@@ -28,28 +28,24 @@ var global =
|
|
|
28
28
|
|
|
29
29
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
30
30
|
|
|
31
|
+
var cancellablePromise = require('./cancellable-promise.js');
|
|
31
32
|
var client = require('./client.js');
|
|
32
33
|
var media = require('./media.js');
|
|
33
34
|
|
|
34
35
|
|
|
35
36
|
|
|
37
|
+
exports.CancellablePromise = cancellablePromise.CancellablePromise;
|
|
36
38
|
Object.defineProperty(exports, 'Client', {
|
|
37
39
|
enumerable: true,
|
|
38
|
-
get: function () {
|
|
39
|
-
return client.Client;
|
|
40
|
-
}
|
|
40
|
+
get: function () { return client.Client; }
|
|
41
41
|
});
|
|
42
42
|
Object.defineProperty(exports, 'McsClient', {
|
|
43
43
|
enumerable: true,
|
|
44
|
-
get: function () {
|
|
45
|
-
return client.Client;
|
|
46
|
-
}
|
|
44
|
+
get: function () { return client.Client; }
|
|
47
45
|
});
|
|
48
46
|
Object.defineProperty(exports, 'default', {
|
|
49
47
|
enumerable: true,
|
|
50
|
-
get: function () {
|
|
51
|
-
return client.Client;
|
|
52
|
-
}
|
|
48
|
+
get: function () { return client.Client; }
|
|
53
49
|
});
|
|
54
50
|
exports.McsMedia = media.Media;
|
|
55
51
|
exports.Media = media.Media;
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/dist/logger.js
CHANGED
|
@@ -39,14 +39,12 @@ function _interopNamespace(e) {
|
|
|
39
39
|
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
40
40
|
Object.defineProperty(n, k, d.get ? d : {
|
|
41
41
|
enumerable: true,
|
|
42
|
-
get: function () {
|
|
43
|
-
return e[k];
|
|
44
|
-
}
|
|
42
|
+
get: function () { return e[k]; }
|
|
45
43
|
});
|
|
46
44
|
}
|
|
47
45
|
});
|
|
48
46
|
}
|
|
49
|
-
n[
|
|
47
|
+
n["default"] = e;
|
|
50
48
|
return Object.freeze(n);
|
|
51
49
|
}
|
|
52
50
|
|
package/dist/logger.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logger.js","sources":["../src/logger.ts"],"sourcesContent":["import * as log from \"loglevel\";\n\nfunction prepareLine(prefix, args) {\n return [`${new Date().toISOString()} MCS Client ${prefix}:`].concat(\n Array.from(args)\n );\n}\n\nclass Logger {\n private prefix = \"\";\n\n private constructor(prefix: string) {\n this.prefix =\n prefix !== null && prefix !== undefined && prefix.length > 0\n ? prefix + \" \"\n : \"\";\n }\n\n static scope(prefix: string): Logger {\n return new Logger(prefix);\n }\n\n setLevel(level: log.LogLevelDesc): void {\n log.setLevel(level);\n }\n\n static setLevel(level: log.LogLevelDesc): void {\n log.setLevel(level);\n }\n\n /* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n trace(...args): void {\n log.trace.apply(null, prepareLine(this.prefix + \"T\", args));\n }\n debug(...args): void {\n log.debug.apply(null, prepareLine(this.prefix + \"D\", args));\n }\n info(...args): void {\n log.info.apply(null, prepareLine(this.prefix + \"I\", args));\n }\n warn(...args): void {\n log.warn.apply(null, prepareLine(this.prefix + \"W\", args));\n }\n error(...args): void {\n log.error.apply(null, prepareLine(this.prefix + \"E\", args));\n }\n\n static trace(...args): void {\n log.trace.apply(null, prepareLine(\"T\", args));\n }\n static debug(...args): void {\n log.debug.apply(null, prepareLine(\"D\", args));\n }\n static info(...args): void {\n log.info.apply(null, prepareLine(\"I\", args));\n }\n static warn(...args): void {\n log.warn.apply(null, prepareLine(\"W\", args));\n }\n static error(...args): void {\n log.error.apply(null, prepareLine(\"E\", args));\n }\n}\n\nexport { Logger };\n"],"names":["log"],"mappings":"
|
|
1
|
+
{"version":3,"file":"logger.js","sources":["../src/logger.ts"],"sourcesContent":["import * as log from \"loglevel\";\n\nfunction prepareLine(prefix, args) {\n return [`${new Date().toISOString()} MCS Client ${prefix}:`].concat(\n Array.from(args)\n );\n}\n\nclass Logger {\n private prefix = \"\";\n\n private constructor(prefix: string) {\n this.prefix =\n prefix !== null && prefix !== undefined && prefix.length > 0\n ? prefix + \" \"\n : \"\";\n }\n\n static scope(prefix: string): Logger {\n return new Logger(prefix);\n }\n\n setLevel(level: log.LogLevelDesc): void {\n log.setLevel(level);\n }\n\n static setLevel(level: log.LogLevelDesc): void {\n log.setLevel(level);\n }\n\n /* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n trace(...args): void {\n log.trace.apply(null, prepareLine(this.prefix + \"T\", args));\n }\n debug(...args): void {\n log.debug.apply(null, prepareLine(this.prefix + \"D\", args));\n }\n info(...args): void {\n log.info.apply(null, prepareLine(this.prefix + \"I\", args));\n }\n warn(...args): void {\n log.warn.apply(null, prepareLine(this.prefix + \"W\", args));\n }\n error(...args): void {\n log.error.apply(null, prepareLine(this.prefix + \"E\", args));\n }\n\n static trace(...args): void {\n log.trace.apply(null, prepareLine(\"T\", args));\n }\n static debug(...args): void {\n log.debug.apply(null, prepareLine(\"D\", args));\n }\n static info(...args): void {\n log.info.apply(null, prepareLine(\"I\", args));\n }\n static warn(...args): void {\n log.warn.apply(null, prepareLine(\"W\", args));\n }\n static error(...args): void {\n log.error.apply(null, prepareLine(\"E\", args));\n }\n}\n\nexport { Logger };\n"],"names":["log"],"mappings":"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"}
|
package/dist/media.js
CHANGED
|
@@ -28,6 +28,8 @@ var global =
|
|
|
28
28
|
|
|
29
29
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
30
30
|
|
|
31
|
+
var cancellablePromise = require('./cancellable-promise.js');
|
|
32
|
+
|
|
31
33
|
/**
|
|
32
34
|
* @classdesc A Media represents a metadata information for the media upload
|
|
33
35
|
* @property {String} sid - The server-assigned unique identifier for Media
|
|
@@ -80,29 +82,20 @@ class Media {
|
|
|
80
82
|
*
|
|
81
83
|
* It is reasonable to build your own refresh logic upon these two functions: as soon as URL returned
|
|
82
84
|
* by getCachedContentUrl() returns 40x status you should call getContentUrl() to refresh it.
|
|
83
|
-
*
|
|
84
|
-
* @returns {Promise<string>}
|
|
85
|
-
*/
|
|
86
|
-
async getContentUrl() {
|
|
87
|
-
const response = await this.network.get(`${this.config.mediaUrl}/${this.sid}`);
|
|
88
|
-
this._update(response.body);
|
|
89
|
-
return Promise.resolve(this.state.contentDirectUrl);
|
|
90
|
-
}
|
|
91
|
-
/**
|
|
92
|
-
* Returns direct content URL to uploaded binary. This URL will expire after some time.
|
|
93
|
-
* This function does not support getting a new URL however. Once set it will remain the same.
|
|
94
|
-
* Use getContentUrl() to query a new one.
|
|
95
|
-
*
|
|
96
|
-
* It is reasonable to build your own refresh logic upon these two functions: as soon as URL returned
|
|
97
|
-
* by getCachedContentUrl() returns 40x status you should call getContentUrl() to refresh it.
|
|
98
|
-
*
|
|
99
|
-
* @returns {Promise<string>}
|
|
100
85
|
*/
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
86
|
+
getContentUrl() {
|
|
87
|
+
return new cancellablePromise.CancellablePromise(async (resolve, reject, onCancel) => {
|
|
88
|
+
const request = this.network.get(`${this.config.mediaUrl}/${this.sid}`);
|
|
89
|
+
onCancel(() => request.cancel());
|
|
90
|
+
try {
|
|
91
|
+
const response = await request;
|
|
92
|
+
this._update(response.body);
|
|
93
|
+
resolve(this.state.contentDirectUrl);
|
|
94
|
+
}
|
|
95
|
+
catch (e) {
|
|
96
|
+
reject(e);
|
|
97
|
+
}
|
|
98
|
+
});
|
|
106
99
|
}
|
|
107
100
|
_update(data) {
|
|
108
101
|
var _a, _b, _c, _d;
|
package/dist/media.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"media.js","sources":["../src/media.ts"],"sourcesContent":["import { Network } from \"./services/network\";\nimport { Configuration } from \"./configuration\";\n\ntype MediaCategory = \"media\" | \"body\" | \"history\";\n\n/**\n * Media descriptor on the MCS. Available via REST API only.\n */\ninterface MediaRecord {\n sid: string;\n serviceSid: string;\n channelSid: string | null;\n messageSid: string | null;\n dateCreated: Date | null;\n dateUploadUpdated: Date | null;\n dateUpdated: Date | null;\n size: number;\n contentType: string;\n filename: string | null;\n category: MediaCategory;\n author: string;\n isMultipartUpstream: boolean;\n\n url: string;\n contentUrl: string;\n contentDirectUrl: string | null;\n}\n\ninterface Links {\n content: string;\n content_direct_temporary?: string;\n}\n\ninterface MediaResponse {\n sid: string;\n service_sid: string;\n channel_sid: string | null;\n message_sid: string | null;\n date_created?: string;\n date_upload_updated?: string;\n date_updated?: string;\n size: number;\n content_type: string;\n filename?: string;\n category?: MediaCategory;\n author: string;\n is_multipart_upstream?: boolean;\n url: string;\n links: Links;\n}\n\n/**\n * @classdesc A Media represents a metadata information for the media upload\n * @property {String} sid - The server-assigned unique identifier for Media\n * @property {String} serviceSid - Service instance id which Media belongs/uploaded to\n * @property {Date} dateCreated - When the Media was created\n * @property {Date} dateUpdated - When the Media was updated\n * @property {Number} size - Size of media, bytes\n * @property {String} contentType - content type of media\n * @property {String} fileName - file name, if present, null otherwise\n * @property {MediaCategory} category - attachment category\n */\nclass Media {\n private state!: MediaRecord;\n private network: Network;\n private config: Configuration;\n\n constructor(config: Configuration, network: Network, data: MediaResponse) {\n this.config = config;\n this.network = network;\n this._update(data);\n }\n\n public get sid(): string {\n return this.state.sid;\n }\n\n public get serviceSid(): string {\n return this.state.serviceSid;\n }\n\n public get dateCreated(): Date | null {\n return this.state.dateCreated;\n }\n\n public get dateUpdated(): Date | null {\n return this.state.dateUpdated;\n }\n\n public get contentType(): string {\n return this.state.contentType;\n }\n\n public get size(): number {\n return this.state.size;\n }\n\n /** @deprecated Use filename instead */\n public get fileName(): string | null {\n return this.state.filename;\n }\n\n public get filename(): string | null {\n return this.state.filename;\n }\n\n public get category(): MediaCategory {\n return this.state.category;\n }\n\n /**\n * Returns direct content URL to uploaded binary. This URL will expire after some time.\n * This function gets a new URL every time, preventing it from expiring but putting additional load on backend.\n * See getCachedContentUrl() for a function that reduces the amount of network requests.\n *\n * It is reasonable to build your own refresh logic upon these two functions: as soon as URL returned\n * by getCachedContentUrl() returns 40x status you should call getContentUrl() to refresh it.\n
|
|
1
|
+
{"version":3,"file":"media.js","sources":["../src/media.ts"],"sourcesContent":["import { Network } from \"./services/network\";\nimport { Configuration } from \"./configuration\";\nimport { CancellablePromise } from \"./cancellable-promise\";\n\ntype MediaCategory = \"media\" | \"body\" | \"history\";\n\n/**\n * Media descriptor on the MCS. Available via REST API only.\n */\ninterface MediaRecord {\n sid: string;\n serviceSid: string;\n channelSid: string | null;\n messageSid: string | null;\n dateCreated: Date | null;\n dateUploadUpdated: Date | null;\n dateUpdated: Date | null;\n size: number;\n contentType: string;\n filename: string | null;\n category: MediaCategory;\n author: string;\n isMultipartUpstream: boolean;\n\n url: string;\n contentUrl: string;\n contentDirectUrl: string | null;\n}\n\ninterface Links {\n content: string;\n content_direct_temporary?: string;\n}\n\ninterface MediaResponse {\n sid: string;\n service_sid: string;\n channel_sid: string | null;\n message_sid: string | null;\n date_created?: string;\n date_upload_updated?: string;\n date_updated?: string;\n size: number;\n content_type: string;\n filename?: string;\n category?: MediaCategory;\n author: string;\n is_multipart_upstream?: boolean;\n url: string;\n links: Links;\n}\n\n/**\n * @classdesc A Media represents a metadata information for the media upload\n * @property {String} sid - The server-assigned unique identifier for Media\n * @property {String} serviceSid - Service instance id which Media belongs/uploaded to\n * @property {Date} dateCreated - When the Media was created\n * @property {Date} dateUpdated - When the Media was updated\n * @property {Number} size - Size of media, bytes\n * @property {String} contentType - content type of media\n * @property {String} fileName - file name, if present, null otherwise\n * @property {MediaCategory} category - attachment category\n */\nclass Media {\n private state!: MediaRecord;\n private network: Network;\n private config: Configuration;\n\n constructor(config: Configuration, network: Network, data: MediaResponse) {\n this.config = config;\n this.network = network;\n this._update(data);\n }\n\n public get sid(): string {\n return this.state.sid;\n }\n\n public get serviceSid(): string {\n return this.state.serviceSid;\n }\n\n public get dateCreated(): Date | null {\n return this.state.dateCreated;\n }\n\n public get dateUpdated(): Date | null {\n return this.state.dateUpdated;\n }\n\n public get contentType(): string {\n return this.state.contentType;\n }\n\n public get size(): number {\n return this.state.size;\n }\n\n /** @deprecated Use filename instead */\n public get fileName(): string | null {\n return this.state.filename;\n }\n\n public get filename(): string | null {\n return this.state.filename;\n }\n\n public get category(): MediaCategory {\n return this.state.category;\n }\n\n /**\n * Returns direct content URL to uploaded binary. This URL will expire after some time.\n * This function gets a new URL every time, preventing it from expiring but putting additional load on backend.\n * See getCachedContentUrl() for a function that reduces the amount of network requests.\n *\n * It is reasonable to build your own refresh logic upon these two functions: as soon as URL returned\n * by getCachedContentUrl() returns 40x status you should call getContentUrl() to refresh it.\n */\n public getContentUrl(): CancellablePromise<string | null> {\n return new CancellablePromise(async (resolve, reject, onCancel) => {\n const request = this.network.get(`${this.config.mediaUrl}/${this.sid}`);\n\n onCancel(() => request.cancel());\n\n try {\n const response = await request;\n this._update(response.body);\n resolve(this.state.contentDirectUrl);\n } catch (e) {\n reject(e);\n }\n });\n }\n\n private _update(data: MediaResponse): void {\n this.state = {\n sid: data.sid,\n serviceSid: data.service_sid,\n channelSid: data.channel_sid,\n messageSid: data.message_sid,\n dateCreated: data.date_created ? new Date(data.date_created) : null,\n dateUploadUpdated: data.date_upload_updated\n ? new Date(data.date_upload_updated)\n : null,\n dateUpdated: data.date_updated ? new Date(data.date_updated) : null,\n size: data.size,\n contentType: data.content_type,\n author: data.author,\n url: data.url,\n contentUrl: data.links.content,\n contentDirectUrl: data.links.content_direct_temporary ?? null,\n filename: data.filename ?? null,\n category: data.category ?? \"media\",\n isMultipartUpstream: data.is_multipart_upstream ?? false,\n };\n }\n}\n\nexport { Media, MediaCategory, MediaResponse };\n"],"names":["CancellablePromise"],"mappings":"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"}
|
|
@@ -28,7 +28,7 @@ var global =
|
|
|
28
28
|
|
|
29
29
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
30
30
|
|
|
31
|
-
|
|
31
|
+
/******************************************************************************
|
|
32
32
|
Copyright (c) Microsoft Corporation.
|
|
33
33
|
|
|
34
34
|
Permission to use, copy, modify, and/or distribute this software for any
|