@twilio/mcs-client 0.5.1 → 0.5.2-canary.1

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/dist/browser.js CHANGED
@@ -755,7 +755,7 @@ class Network {
755
755
 
756
756
  }
757
757
 
758
- var version = "0.5.1";
758
+ var version = "0.5.2-rc.2";
759
759
 
760
760
  var _class, _temp;
761
761
  var log = Logger.scope("");
@@ -0,0 +1,154 @@
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 tslib_es6 = require('./node_modules/tslib/tslib.es6.js');
32
+ var logger = require('./logger.js');
33
+ var configuration = require('./configuration.js');
34
+ var media = require('./media.js');
35
+ var transport = require('./services/transport.js');
36
+ var network = require('./services/network.js');
37
+ var _package = require('./packages/mcs-client/package.json.js');
38
+ var declarativeTypeValidator = require('@twilio/declarative-type-validator');
39
+
40
+ const log = logger.Logger.scope("");
41
+ /**
42
+ * @classdesc A Client provides an interface for Media Content Service
43
+ */
44
+ exports.Client = class Client {
45
+ /**
46
+ * Base URLs must be full URLs with host. If host is not provided it will be generated from a default configuration
47
+ * template using options.region.
48
+ *
49
+ * @param {String} token - Access token
50
+ * @param {String} baseUrl - Base URL for Media Content Service Media resource, i.e. /v1/Services/{serviceSid}/Media
51
+ * @param {String} baseSetUrl - Base URL for Media Content Service MediaSet resource, i.e. /v1/Services/{serviceSid}/MediaSet
52
+ * @param {Client#ClientOptions} [options] - Options to customize the Client
53
+ */
54
+ constructor(token, baseUrl, baseSetUrl, options = {}) {
55
+ var _a, _b;
56
+ this.options = options;
57
+ this.options.logLevel = (_a = this.options.logLevel) !== null && _a !== void 0 ? _a : "silent";
58
+ this.config = new configuration.Configuration(token, baseUrl, baseSetUrl, this.options);
59
+ log.setLevel(this.options.logLevel);
60
+ this.options.transport = (_b = this.options.transport) !== null && _b !== void 0 ? _b : new transport.Transport();
61
+ this.transport = this.options.transport;
62
+ this.network = new network.Network(this.config, this.transport);
63
+ }
64
+ /**
65
+ * These options can be passed to Client constructor
66
+ * @typedef {Object} Client#ClientOptions
67
+ * @property {String} [logLevel='silent'] - The level of logging to enable. Valid options
68
+ * (from strictest to broadest): ['silent', 'error', 'warn', 'info', 'debug', 'trace']
69
+ */
70
+ /**
71
+ * Update the token used for Client operations
72
+ * @param {String} token - The JWT string of the new token
73
+ * @returns {void}
74
+ */
75
+ updateToken(token) {
76
+ log.info("updateToken");
77
+ this.config.updateToken(token);
78
+ }
79
+ /**
80
+ * Gets media from media service
81
+ * @param {String} sid - Media's SID
82
+ * @returns {Promise<Media>}
83
+ */
84
+ async get(sid) {
85
+ const response = await this.network.get(`${this.config.mediaUrl}/${sid}`);
86
+ return new media.Media(this.config, this.network, response.body);
87
+ }
88
+ /**
89
+ * Posts raw content to media service
90
+ * @param {String} contentType - content type of media
91
+ * @param {String|Buffer|Blob} media - content to post
92
+ * @param {MediaCategory|null} category - category for the media
93
+ * @returns {Promise<Media>}
94
+ */
95
+ async post(contentType, media$1, category, filename) {
96
+ const response = await this.network.post(this.config.mediaUrl, category !== null && category !== void 0 ? category : "media", media$1, contentType, filename);
97
+ return new media.Media(this.config, this.network, response.body);
98
+ }
99
+ /**
100
+ * Posts FormData to media service. Can be used only with browser engine's FormData.
101
+ * In non-browser FormData case the method will do promise reject with
102
+ * new TypeError("Posting FormData supported only with browser engine's FormData")
103
+ * @param {FormData} formData - form data to post
104
+ * @param {MediaCategory|null} category - category for the media
105
+ * @returns {Promise<Media>}
106
+ */
107
+ async postFormData(formData, category) {
108
+ const response = await this.network.post(this.config.mediaUrl, category !== null && category !== void 0 ? category : "media", formData);
109
+ return new media.Media(this.config, this.network, response.body);
110
+ }
111
+ /**
112
+ * Retrieve information about multiple media SIDs at the same time.
113
+ * @param mediaSids Array of Media SIDs to get information from.
114
+ */
115
+ async mediaSetGet(mediaSids) {
116
+ const query = {
117
+ command: "get",
118
+ list: mediaSids.map((sid) => ({ media_sid: sid })),
119
+ };
120
+ const response = (await this.network.post(`${this.config.mediaSetUrl}`, null, JSON.stringify(query), "application/json"));
121
+ return response.map((item) => {
122
+ if (item.code !== 200) {
123
+ throw new Error(`Failed to obtain detailed information about Media items (failed SID ${item.media_record.sid})`);
124
+ }
125
+ return new media.Media(this.config, this.network, item.media_record);
126
+ });
127
+ }
128
+ };
129
+ exports.Client.version = _package.version;
130
+ tslib_es6.__decorate([
131
+ declarativeTypeValidator.validateTypes(declarativeTypeValidator.nonEmptyString),
132
+ tslib_es6.__metadata("design:type", Function),
133
+ tslib_es6.__metadata("design:paramtypes", [String]),
134
+ tslib_es6.__metadata("design:returntype", void 0)
135
+ ], exports.Client.prototype, "updateToken", null);
136
+ tslib_es6.__decorate([
137
+ declarativeTypeValidator.validateTypesAsync(declarativeTypeValidator.nonEmptyString),
138
+ tslib_es6.__metadata("design:type", Function),
139
+ tslib_es6.__metadata("design:paramtypes", [String]),
140
+ tslib_es6.__metadata("design:returntype", Promise)
141
+ ], exports.Client.prototype, "get", null);
142
+ exports.Client = tslib_es6.__decorate([
143
+ declarativeTypeValidator.validateConstructorTypes(declarativeTypeValidator.nonEmptyString, declarativeTypeValidator.nonEmptyString, [
144
+ declarativeTypeValidator.nonEmptyString,
145
+ declarativeTypeValidator.literal(null),
146
+ ], [
147
+ declarativeTypeValidator.pureObject,
148
+ 'undefined',
149
+ ]),
150
+ tslib_es6.__metadata("design:paramtypes", [String, String, Object, Object])
151
+ ], exports.Client);
152
+
153
+ exports.Media = media.Media;
154
+ //# sourceMappingURL=client.js.map
@@ -0,0 +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 [\n nonEmptyString,\n literal(null),\n ],\n [\n pureObject,\n 'undefined',\n ]\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 JSON.stringify(query),\n \"application/json\"\n )) as {\n code: number;\n media_record: MediaResponse;\n }[];\n return response.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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"}
@@ -0,0 +1,66 @@
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
+ const MINIMUM_RETRY_DELAY = 1000;
32
+ const MAXIMUM_RETRY_DELAY = 4000;
33
+ const MAXIMUM_ATTEMPTS_COUNT = 3;
34
+ const RETRY_WHEN_THROTTLED = true;
35
+ const regionalMcsHost = (region) => `https://mcs.${region !== null && region !== void 0 ? region : "us1"}.twilio.com`;
36
+ const isFullUrl = (url) => url.startsWith("http");
37
+ const fullUrl = (partUrl, region) => `${!isFullUrl(partUrl) ? regionalMcsHost(region) : ""}${partUrl}`;
38
+ class Configuration {
39
+ constructor(token, baseUrl, baseSetUrl, options) {
40
+ var _a, _b, _c, _d, _e, _f;
41
+ const constructorOptions = (_b = (_a = options.MCS) !== null && _a !== void 0 ? _a : options) !== null && _b !== void 0 ? _b : {};
42
+ this.region = (_d = (_c = constructorOptions.region) !== null && _c !== void 0 ? _c : options.region) !== null && _d !== void 0 ? _d : 'us1';
43
+ this.mediaUrl = fullUrl(baseUrl, this.region);
44
+ this.mediaSetUrl = baseSetUrl ? fullUrl(baseSetUrl) : `${this.mediaUrl}Set`;
45
+ this.token = token;
46
+ this.retryWhenThrottledOverride =
47
+ (_e = constructorOptions.retryWhenThrottledOverride) !== null && _e !== void 0 ? _e : RETRY_WHEN_THROTTLED;
48
+ this.backoffConfigOverride = (_f = constructorOptions.backoffConfigOverride) !== null && _f !== void 0 ? _f : Configuration.backoffConfigDefault;
49
+ }
50
+ static get backoffConfigDefault() {
51
+ return {
52
+ min: MINIMUM_RETRY_DELAY,
53
+ max: MAXIMUM_RETRY_DELAY,
54
+ maxAttemptsCount: MAXIMUM_ATTEMPTS_COUNT,
55
+ };
56
+ }
57
+ static get retryWhenThrottledDefault() {
58
+ return RETRY_WHEN_THROTTLED;
59
+ }
60
+ updateToken(token) {
61
+ this.token = token;
62
+ }
63
+ }
64
+
65
+ exports.Configuration = Configuration;
66
+ //# sourceMappingURL=configuration.js.map
@@ -0,0 +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,eAAe,MAAM,aAAN,MAAM,cAAN,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,GAAG,CAAC,SAAS,CAAC,OAAO,CAAC,GAAG,eAAe,CAAC,MAAM,CAAC,GAAG,EAAE,GAAG,OAAO,EAAE,CAAC;AAuBpE,MAAM,aAAa;IAQjB,YACE,KAAa,EACb,OAAe,EACf,UAAyB,EACzB,OAAgB;;QAEhB,MAAM,kBAAkB,GAAG,MAAA,MAAA,OAAO,CAAC,GAAG,mCAAI,OAAO,mCAAI,EAAE,CAAC;QACxD,IAAI,CAAC,MAAM,GAAG,MAAA,MAAA,kBAAkB,CAAC,MAAM,mCAAI,OAAO,CAAC,MAAM,mCAAI,KAAK,CAAC;QACnE,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9C,IAAI,CAAC,WAAW,GAAG,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,KAAK,CAAC;QAC5E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,0BAA0B;YAC7B,MAAA,kBAAkB,CAAC,0BAA0B,mCAAI,oBAAoB,CAAC;QACxE,IAAI,CAAC,qBAAqB,GAAG,MAAA,kBAAkB,CAAC,qBAAqB,mCAAI,aAAa,CAAC,oBAAoB,CAAC;KAC7G;IAEM,WAAW,oBAAoB;QACpC,OAAO;YACL,GAAG,EAAE,mBAAmB;YACxB,GAAG,EAAE,mBAAmB;YACxB,gBAAgB,EAAE,sBAAsB;SACzC,CAAC;KACH;IAEM,WAAW,yBAAyB;QACzC,OAAO,oBAAoB,CAAC;KAC7B;IAEM,WAAW,CAAC,KAAa;QAC9B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;KACpB;;;;;"}
@@ -0,0 +1,56 @@
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 client = require('./client.js');
32
+ var media = require('./media.js');
33
+
34
+
35
+
36
+ Object.defineProperty(exports, 'Client', {
37
+ enumerable: true,
38
+ get: function () {
39
+ return client.Client;
40
+ }
41
+ });
42
+ Object.defineProperty(exports, 'McsClient', {
43
+ enumerable: true,
44
+ get: function () {
45
+ return client.Client;
46
+ }
47
+ });
48
+ Object.defineProperty(exports, 'default', {
49
+ enumerable: true,
50
+ get: function () {
51
+ return client.Client;
52
+ }
53
+ });
54
+ exports.McsMedia = media.Media;
55
+ exports.Media = media.Media;
56
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,109 @@
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 log = require('loglevel');
32
+
33
+ function _interopNamespace(e) {
34
+ if (e && e.__esModule) return e;
35
+ var n = Object.create(null);
36
+ if (e) {
37
+ Object.keys(e).forEach(function (k) {
38
+ if (k !== 'default') {
39
+ var d = Object.getOwnPropertyDescriptor(e, k);
40
+ Object.defineProperty(n, k, d.get ? d : {
41
+ enumerable: true,
42
+ get: function () {
43
+ return e[k];
44
+ }
45
+ });
46
+ }
47
+ });
48
+ }
49
+ n['default'] = e;
50
+ return Object.freeze(n);
51
+ }
52
+
53
+ var log__namespace = /*#__PURE__*/_interopNamespace(log);
54
+
55
+ function prepareLine(prefix, args) {
56
+ return [`${new Date().toISOString()} MCS Client ${prefix}:`].concat(Array.from(args));
57
+ }
58
+ class Logger {
59
+ constructor(prefix) {
60
+ this.prefix = "";
61
+ this.prefix =
62
+ prefix !== null && prefix !== undefined && prefix.length > 0
63
+ ? prefix + " "
64
+ : "";
65
+ }
66
+ static scope(prefix) {
67
+ return new Logger(prefix);
68
+ }
69
+ setLevel(level) {
70
+ log__namespace.setLevel(level);
71
+ }
72
+ static setLevel(level) {
73
+ log__namespace.setLevel(level);
74
+ }
75
+ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */
76
+ trace(...args) {
77
+ log__namespace.trace.apply(null, prepareLine(this.prefix + "T", args));
78
+ }
79
+ debug(...args) {
80
+ log__namespace.debug.apply(null, prepareLine(this.prefix + "D", args));
81
+ }
82
+ info(...args) {
83
+ log__namespace.info.apply(null, prepareLine(this.prefix + "I", args));
84
+ }
85
+ warn(...args) {
86
+ log__namespace.warn.apply(null, prepareLine(this.prefix + "W", args));
87
+ }
88
+ error(...args) {
89
+ log__namespace.error.apply(null, prepareLine(this.prefix + "E", args));
90
+ }
91
+ static trace(...args) {
92
+ log__namespace.trace.apply(null, prepareLine("T", args));
93
+ }
94
+ static debug(...args) {
95
+ log__namespace.debug.apply(null, prepareLine("D", args));
96
+ }
97
+ static info(...args) {
98
+ log__namespace.info.apply(null, prepareLine("I", args));
99
+ }
100
+ static warn(...args) {
101
+ log__namespace.warn.apply(null, prepareLine("W", args));
102
+ }
103
+ static error(...args) {
104
+ log__namespace.error.apply(null, prepareLine("E", args));
105
+ }
106
+ }
107
+
108
+ exports.Logger = Logger;
109
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,SAAS,WAAW,CAAC,MAAM,EAAE,IAAI;IAC/B,OAAO,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,eAAe,MAAM,GAAG,CAAC,CAAC,MAAM,CACjE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CACjB,CAAC;AACJ,CAAC;AAED,MAAM,MAAM;IAGV,YAAoB,MAAc;QAF1B,WAAM,GAAG,EAAE,CAAC;QAGlB,IAAI,CAAC,MAAM;YACT,MAAM,KAAK,IAAI,IAAI,MAAM,KAAK,SAAS,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC;kBACxD,MAAM,GAAG,GAAG;kBACZ,EAAE,CAAC;KACV;IAED,OAAO,KAAK,CAAC,MAAc;QACzB,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC;KAC3B;IAED,QAAQ,CAAC,KAAuB;QAC9BA,cAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;KACrB;IAED,OAAO,QAAQ,CAAC,KAAuB;QACrCA,cAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;KACrB;;IAGD,KAAK,CAAC,GAAG,IAAI;QACXA,cAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC7D;IACD,KAAK,CAAC,GAAG,IAAI;QACXA,cAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC7D;IACD,IAAI,CAAC,GAAG,IAAI;QACVA,cAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC5D;IACD,IAAI,CAAC,GAAG,IAAI;QACVA,cAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC5D;IACD,KAAK,CAAC,GAAG,IAAI;QACXA,cAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC7D;IAED,OAAO,KAAK,CAAC,GAAG,IAAI;QAClBA,cAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC/C;IACD,OAAO,KAAK,CAAC,GAAG,IAAI;QAClBA,cAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC/C;IACD,OAAO,IAAI,CAAC,GAAG,IAAI;QACjBA,cAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC9C;IACD,OAAO,IAAI,CAAC,GAAG,IAAI;QACjBA,cAAG,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC9C;IACD,OAAO,KAAK,CAAC,GAAG,IAAI;QAClBA,cAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,WAAW,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;KAC/C;;;;;"}
@@ -0,0 +1,133 @@
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
+ /**
32
+ * @classdesc A Media represents a metadata information for the media upload
33
+ * @property {String} sid - The server-assigned unique identifier for Media
34
+ * @property {String} serviceSid - Service instance id which Media belongs/uploaded to
35
+ * @property {Date} dateCreated - When the Media was created
36
+ * @property {Date} dateUpdated - When the Media was updated
37
+ * @property {Number} size - Size of media, bytes
38
+ * @property {String} contentType - content type of media
39
+ * @property {String} fileName - file name, if present, null otherwise
40
+ * @property {MediaCategory} category - attachment category
41
+ */
42
+ class Media {
43
+ constructor(config, network, data) {
44
+ this.config = config;
45
+ this.network = network;
46
+ this._update(data);
47
+ }
48
+ get sid() {
49
+ return this.state.sid;
50
+ }
51
+ get serviceSid() {
52
+ return this.state.serviceSid;
53
+ }
54
+ get dateCreated() {
55
+ return this.state.dateCreated;
56
+ }
57
+ get dateUpdated() {
58
+ return this.state.dateUpdated;
59
+ }
60
+ get contentType() {
61
+ return this.state.contentType;
62
+ }
63
+ get size() {
64
+ return this.state.size;
65
+ }
66
+ /** @deprecated Use filename instead */
67
+ get fileName() {
68
+ return this.state.filename;
69
+ }
70
+ get filename() {
71
+ return this.state.filename;
72
+ }
73
+ get category() {
74
+ return this.state.category;
75
+ }
76
+ /**
77
+ * Returns direct content URL to uploaded binary. This URL will expire after some time.
78
+ * This function gets a new URL every time, preventing it from expiring but putting additional load on backend.
79
+ * See getCachedContentUrl() for a function that reduces the amount of network requests.
80
+ *
81
+ * It is reasonable to build your own refresh logic upon these two functions: as soon as URL returned
82
+ * 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
+ */
101
+ async getCachedContentUrl() {
102
+ if (this.state.contentDirectUrl) {
103
+ return Promise.resolve(this.state.contentDirectUrl);
104
+ }
105
+ return await this.getContentUrl();
106
+ }
107
+ _update(data) {
108
+ var _a, _b, _c, _d;
109
+ this.state = {
110
+ sid: data.sid,
111
+ serviceSid: data.service_sid,
112
+ channelSid: data.channel_sid,
113
+ messageSid: data.message_sid,
114
+ dateCreated: data.date_created ? new Date(data.date_created) : null,
115
+ dateUploadUpdated: data.date_upload_updated
116
+ ? new Date(data.date_upload_updated)
117
+ : null,
118
+ dateUpdated: data.date_updated ? new Date(data.date_updated) : null,
119
+ size: data.size,
120
+ contentType: data.content_type,
121
+ author: data.author,
122
+ url: data.url,
123
+ contentUrl: data.links.content,
124
+ contentDirectUrl: (_a = data.links.content_direct_temporary) !== null && _a !== void 0 ? _a : null,
125
+ filename: (_b = data.filename) !== null && _b !== void 0 ? _b : null,
126
+ category: (_c = data.category) !== null && _c !== void 0 ? _c : "media",
127
+ isMultipartUpstream: (_d = data.is_multipart_upstream) !== null && _d !== void 0 ? _d : false,
128
+ };
129
+ }
130
+ }
131
+
132
+ exports.Media = Media;
133
+ //# sourceMappingURL=media.js.map
@@ -0,0 +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 *\n * @returns {Promise<string>}\n */\n public async getContentUrl(): Promise<string | null> {\n const response = await this.network.get(\n `${this.config.mediaUrl}/${this.sid}`\n );\n this._update(response.body);\n return Promise.resolve(this.state.contentDirectUrl);\n }\n\n /**\n * Returns direct content URL to uploaded binary. This URL will expire after some time.\n * This function does not support getting a new URL however. Once set it will remain the same.\n * Use getContentUrl() to query a new one.\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 * @returns {Promise<string>}\n */\n public async getCachedContentUrl(): Promise<string | null> {\n if (this.state.contentDirectUrl) {\n return Promise.resolve(this.state.contentDirectUrl);\n }\n return await this.getContentUrl();\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":[],"mappings":"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"}
@@ -0,0 +1,59 @@
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
+ /*! *****************************************************************************
32
+ Copyright (c) Microsoft Corporation.
33
+
34
+ Permission to use, copy, modify, and/or distribute this software for any
35
+ purpose with or without fee is hereby granted.
36
+
37
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
38
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
39
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
40
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
41
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
42
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
43
+ PERFORMANCE OF THIS SOFTWARE.
44
+ ***************************************************************************** */
45
+
46
+ function __decorate(decorators, target, key, desc) {
47
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
48
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
49
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
50
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
51
+ }
52
+
53
+ function __metadata(metadataKey, metadataValue) {
54
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
55
+ }
56
+
57
+ exports.__decorate = __decorate;
58
+ exports.__metadata = __metadata;
59
+ //# sourceMappingURL=tslib.es6.js.map