@twilio/mcs-client 0.5.2-rc.1 → 0.5.2
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 +34 -0
- package/{dist → builds}/browser.js +1 -1
- package/{dist → builds}/browser.js.map +0 -0
- package/{dist → builds}/lib.d.ts +0 -0
- package/{dist → builds}/lib.js +1 -1
- package/{dist → builds}/lib.js.map +0 -0
- package/{dist → builds}/twilio-mcs-client.js +1 -1
- package/{dist → builds}/twilio-mcs-client.min.js +1 -1
- package/dist/client.js +154 -0
- package/dist/client.js.map +1 -0
- package/dist/configuration.js +66 -0
- package/dist/configuration.js.map +1 -0
- package/dist/index.js +56 -0
- package/dist/index.js.map +1 -0
- package/dist/logger.js +109 -0
- package/dist/logger.js.map +1 -0
- package/dist/media.js +133 -0
- package/dist/media.js.map +1 -0
- package/dist/node_modules/tslib/tslib.es6.js +59 -0
- package/dist/node_modules/tslib/tslib.es6.js.map +1 -0
- package/dist/packages/mcs-client/package.json.js +34 -0
- package/dist/packages/mcs-client/package.json.js.map +1 -0
- package/dist/services/network.js +134 -0
- package/dist/services/network.js.map +1 -0
- package/dist/services/transport.js +119 -0
- package/dist/services/transport.js.map +1 -0
- package/dist/services/transporterror.js +42 -0
- package/dist/services/transporterror.js.map +1 -0
- package/package.json +18 -19
- package/dist/post-install.js +0 -29
- package/dist/react-native.js +0 -584
- package/dist/react-native.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,40 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
### [0.5.2](https://github.com/twilio/rtd-sdk-monorepo-js/compare/@twilio/mcs-client@0.5.2-rc.4...@twilio/mcs-client@0.5.2) (2021-11-25)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @twilio/mcs-client
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
### [0.5.2-rc.4](https://github.com/twilio/rtd-sdk-monorepo-js/compare/@twilio/mcs-client@0.5.2-rc.3...@twilio/mcs-client@0.5.2-rc.4) (2021-11-12)
|
|
15
|
+
|
|
16
|
+
**Note:** Version bump only for package @twilio/mcs-client
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
### [0.5.2-rc.3](https://github.com/twilio/rtd-sdk-monorepo-js/compare/@twilio/mcs-client@0.5.2-rc.2...@twilio/mcs-client@0.5.2-rc.3) (2021-11-11)
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
### Bug Fixes
|
|
26
|
+
|
|
27
|
+
* Remove the post-install script in favour of the "react-native" option ([0fe352d](https://github.com/twilio/rtd-sdk-monorepo-js/commit/0fe352d45e50cec78e880affee589009055d5338))
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
### [0.5.2-rc.2](https://github.com/twilio/rtd-sdk-monorepo-js/compare/@twilio/mcs-client@0.5.2-rc.1...@twilio/mcs-client@0.5.2-rc.2) (2021-11-10)
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+
### Bug Fixes
|
|
35
|
+
|
|
36
|
+
* Fix the post-install script (yet again) ([c8cb1ee](https://github.com/twilio/rtd-sdk-monorepo-js/commit/c8cb1ee501d1c793497985592d2c1ae97162a219))
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
6
40
|
### [0.5.2-rc.1](https://github.com/twilio/rtd-sdk-monorepo-js/compare/@twilio/mcs-client@0.5.2-rc.0...@twilio/mcs-client@0.5.2-rc.1) (2021-11-09)
|
|
7
41
|
|
|
8
42
|
|
|
File without changes
|
package/{dist → builds}/lib.d.ts
RENAMED
|
File without changes
|
package/{dist → builds}/lib.js
RENAMED
|
File without changes
|
|
@@ -59,4 +59,4 @@ this.Twilio=this.Twilio||{},this.Twilio.McsClient=function(t){"use strict";var e
|
|
|
59
59
|
|
|
60
60
|
|
|
61
61
|
*/
|
|
62
|
-
Object.defineProperty(Md,"__esModule",{value:!0});var wm=Dg.exports,xm=sm.exports,Sm=qh.exports,km=zh.exports,Am=Vh.exports,Em=Yh.exports;function Om(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var jm=Om(Hh.exports),Tm=Om(wm),Lm=Om(xm),_m=Om(Sm),Rm=Om(km),Im=Om(Am),Pm=Om(Em),Cm=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return{checks:e}};function Dm(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return Mm(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Mm(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function Mm(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var Um=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return Cm((function(t){var r,n=!1,o=[],i=Dm(e);try{for(i.s();!(r=i.n()).done;){var a=r.value;"string"!=typeof a?(n=n||t instanceof a,o.push("an instance of ".concat(a.name))):(n=n||jm.default(t)===a,o.push("of type ".concat(a)))}}catch(t){i.e(t)}finally{i.f()}return[n,o]}))};function Nm(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return Fm(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Fm(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function Fm(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var Bm=Cm((function(t){return["string"==typeof t&&t.length>0,"a non-empty string"]})),qm=Cm((function(t){return["number"==typeof t&&Number.isInteger(t)&&t>=0,"a non-negative integer"]})),Gm=Cm((function(t){return["object"===jm.default(t)&&null!==t&&!Array.isArray(t),"a pure object (non-null and non-array)"]}));function Wm(t){var e=function(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(t){return!1}}();return function(){var r,n=Pm.default(t);if(e){var o=Pm.default(this).constructor;r=Reflect.construct(n,arguments,o)}else r=n.apply(this,arguments);return Im.default(this,r)}}function zm(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return $m(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return $m(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function $m(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var Vm=function(t,e){if(e.length>t.length)throw new Error("Expected at most ".concat(t.length," argument(s), but got ").concat(e.length));for(;e.length<t.length;)e.push(void 0);var r,n=zm(e.entries());try{for(n.s();!(r=n.n()).done;){var o=Tm.default(r.value,2),i=o[0],a=o[1],u=Xm(t[i],a),c=Tm.default(u,4),s=c[0],f=c[1],l=c[2],p=c[3];if(!s)throw new Error("Argument ".concat(i+1," is expected to be ").concat(l).concat(p," but got ").concat(f))}}catch(t){n.e(t)}finally{n.f()}},Hm=function(t){var e,r,n;(["undefined","boolean","number","bigint","string"].includes(jm.default(t))&&(r="string"==typeof t?'"'.concat(t,'"'):"".concat(t)),"object"===jm.default(t)&&"Object"!==(null==t||null===(e=t.constructor)||void 0===e?void 0:e.name))&&(r=null===t?"null":"instance of ".concat(null==t||null===(n=t.constructor)||void 0===n?void 0:n.name));return r||(r=jm.default(t)),r},Ym=function(t){var e,r=[],n=zm(t);try{for(n.s();!(e=n.n()).done;){var o=e.value;r.push(Jm(o))}}catch(t){n.e(t)}finally{n.f()}return r},Jm=function(t){var e,r=[],n=zm(Array.isArray(t)?t:[t]);try{for(n.s();!(e=n.n()).done;){var o=e.value;"string"!=typeof o&&"function"!=typeof o?r.push(o):r.push(Um(o))}}catch(t){n.e(t)}finally{n.f()}return r},Xm=function(t,e){var r,n,o=[],i=!1,a=zm(t);try{for(a.s();!(n=a.n()).done;){var u,c=zm(n.value.checks);try{for(c.s();!(u=c.n()).done;){var s=(0,u.value)(e),f=Tm.default(s,3),l=f[0],p=f[1],h=f[2];i=i||l,!r&&h&&(r=h),p&&(o=[].concat(Lm.default(o),"string"==typeof p?[p]:Lm.default(p)))}}catch(t){c.e(t)}finally{c.f()}}}catch(t){a.e(t)}finally{a.f()}if(i)return[!0];var d=r||Hm(e),v=o.length-1;return[!1,d,v>0?"".concat(o.slice(0,v).join(", ")," or ").concat(o[v]):o.join(", "),v>1?";":","]};function Km(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return Zm(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Zm(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function Zm(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}Md.array=function(t,e){return Cm((function(r){if(!Array.isArray(r))return[!1,"an array of ".concat(t)];var n,o=Km(r.entries());try{for(o.s();!(n=o.n()).done;){var i=Tm.default(n.value,2),a=i[0],u=i[1],c=Xm(Jm(e),u),s=Tm.default(c,3),f=s[0],l=s[1],p=s[2];if(!f)return[!1,"a valid array of ".concat(t," (index ").concat(a," should be ").concat(p,")"),"malformed array of ".concat(t," (index ").concat(a," is ").concat(l,")")]}}catch(t){o.e(t)}finally{o.f()}return[!0]}))},Md.custom=Cm;var Qm=Md.literal=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return Cm((function(t){var r,n=!1,o=[],i=Nm(e);try{for(i.s();!(r=i.n()).done;){var a=r.value;n=n||t===a,o.push("string"==typeof a?'"'.concat(a,'"'):"".concat(a))}}catch(t){i.e(t)}finally{i.f()}return[n,o]}))},tb=Md.nonEmptyString=Bm;Md.nonNegativeInteger=qm,Md.objectSchema=function(t,e){return Cm((function(r){if("object"!==jm.default(r)||null===r||Array.isArray(r))return[!1,"valid ".concat(t," (should be a pure object)")];for(var n=0,o=Object.entries(e);n<o.length;n++){var i=Tm.default(o[n],2),a=i[0],u=i[1],c=Xm(Jm(u),r[a]),s=Tm.default(c,3),f=s[0],l=s[1],p=s[2];if(!f)return[!1,"valid ".concat(t,' (key "').concat(a,'" should be ').concat(p,")"),"malformed ".concat(t,' (key "').concat(a,'" is ').concat(l,")")]}return[!0]}))};var eb=Md.pureObject=Gm;Md.runtimeTypeValidation=Vm,Md.stringifyReceivedType=Hm,Md.type=Um;var rb,nb,ob=Md.validateConstructorTypes=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];var n=Ym(e);return function(t){return function(t){Rm.default(r,t);var e=Wm(r);function r(){_m.default(this,r);for(var t=arguments.length,o=new Array(t),i=0;i<t;i++)o[i]=arguments[i];return Vm(n,o),e.call.apply(e,[this].concat(o))}return r}(t)}},ib=Md.validateTypes=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];var n=Ym(e);return function(t,e,r){if("function"!=typeof r.value)throw new Error("The validateTypes decorator can only be applied to methods");var o=r.value;r.value=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return Vm(n,e),o.apply(this,e)}}},ab=Md.validateTypesAsync=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];var n=Ym(e);return function(t,e,r){if("function"!=typeof r.value)throw new Error("The validateTypesAsync decorator can only be applied to methods");var o=r.value;r.value=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];try{Vm(n,e)}catch(t){return Promise.reject(t)}return o.apply(this,e)}}},ub=Va.scope("");return t.default=(nb=rb=class{constructor(t,e,r){var n,o,i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};this.options=i,this.options.logLevel=null!==(n=this.options.logLevel)&&void 0!==n?n:"silent",this.config=new hu(t,e,r,this.options),ub.setLevel(this.options.logLevel),this.options.transport=null!==(o=this.options.transport)&&void 0!==o?o:new Zc,this.transport=this.options.transport,this.network=new Dd(this.config,this.transport)}updateToken(t){ub.info("updateToken"),this.config.updateToken(t)}get(t){var e=this;return n(Sa.mark((function r(){var n;return Sa.wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return r.next=2,e.network.get("".concat(e.config.mediaUrl,"/").concat(t));case 2:return n=r.sent,r.abrupt("return",new du(e.config,e.network,n.body));case 4:case"end":return r.stop()}}),r)})))()}post(t,e,r,o){var i=this;return n(Sa.mark((function n(){var a;return Sa.wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,i.network.post(i.config.mediaUrl,null!=r?r:"media",e,t,o);case 2:return a=n.sent,n.abrupt("return",new du(i.config,i.network,a.body));case 4:case"end":return n.stop()}}),n)})))()}postFormData(t,e){var r=this;return n(Sa.mark((function n(){var o;return Sa.wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,r.network.post(r.config.mediaUrl,null!=e?e:"media",t);case 2:return o=n.sent,n.abrupt("return",new du(r.config,r.network,o.body));case 4:case"end":return n.stop()}}),n)})))()}mediaSetGet(t){var e=this;return n(Sa.mark((function r(){var n,o;return Sa.wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return n={command:"get",list:t.map((t=>({media_sid:t})))},r.next=3,e.network.post("".concat(e.config.mediaSetUrl),null,JSON.stringify(n),"application/json");case 3:return o=r.sent,r.abrupt("return",o.map((t=>{if(200!==t.code)throw new Error("Failed to obtain detailed information about Media items (failed SID ".concat(t.media_record.sid,")"));return new du(e.config,e.network,t.media_record)})));case 5:case"end":return r.stop()}}),r)})))()}},o(rb,"version","0.5.2-rc.1"),nb),ka([ib(tb),Aa("design:type",Function),Aa("design:paramtypes",[String]),Aa("design:returntype",void 0)],t.default.prototype,"updateToken",null),ka([ab(tb),Aa("design:type",Function),Aa("design:paramtypes",[String]),Aa("design:returntype",Promise)],t.default.prototype,"get",null),t.default=ka([ob(tb,tb,[tb,Qm(null)],[eb,"undefined"]),Aa("design:paramtypes",[String,String,Object,Object])],t.default),t.Client=t.default,t.McsClient=t.default,t.McsMedia=du,t.Media=du,t.default=t.default,Object.defineProperty(t,"__esModule",{value:!0}),t}({});
|
|
62
|
+
Object.defineProperty(Md,"__esModule",{value:!0});var wm=Dg.exports,xm=sm.exports,Sm=qh.exports,km=zh.exports,Am=Vh.exports,Em=Yh.exports;function Om(t){return t&&"object"==typeof t&&"default"in t?t:{default:t}}var jm=Om(Hh.exports),Tm=Om(wm),Lm=Om(xm),_m=Om(Sm),Rm=Om(km),Im=Om(Am),Pm=Om(Em),Cm=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return{checks:e}};function Dm(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return Mm(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Mm(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function Mm(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var Um=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return Cm((function(t){var r,n=!1,o=[],i=Dm(e);try{for(i.s();!(r=i.n()).done;){var a=r.value;"string"!=typeof a?(n=n||t instanceof a,o.push("an instance of ".concat(a.name))):(n=n||jm.default(t)===a,o.push("of type ".concat(a)))}}catch(t){i.e(t)}finally{i.f()}return[n,o]}))};function Nm(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return Fm(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Fm(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function Fm(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var Bm=Cm((function(t){return["string"==typeof t&&t.length>0,"a non-empty string"]})),qm=Cm((function(t){return["number"==typeof t&&Number.isInteger(t)&&t>=0,"a non-negative integer"]})),Gm=Cm((function(t){return["object"===jm.default(t)&&null!==t&&!Array.isArray(t),"a pure object (non-null and non-array)"]}));function Wm(t){var e=function(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(t){return!1}}();return function(){var r,n=Pm.default(t);if(e){var o=Pm.default(this).constructor;r=Reflect.construct(n,arguments,o)}else r=n.apply(this,arguments);return Im.default(this,r)}}function zm(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return $m(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return $m(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function $m(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}var Vm=function(t,e){if(e.length>t.length)throw new Error("Expected at most ".concat(t.length," argument(s), but got ").concat(e.length));for(;e.length<t.length;)e.push(void 0);var r,n=zm(e.entries());try{for(n.s();!(r=n.n()).done;){var o=Tm.default(r.value,2),i=o[0],a=o[1],u=Xm(t[i],a),c=Tm.default(u,4),s=c[0],f=c[1],l=c[2],p=c[3];if(!s)throw new Error("Argument ".concat(i+1," is expected to be ").concat(l).concat(p," but got ").concat(f))}}catch(t){n.e(t)}finally{n.f()}},Hm=function(t){var e,r,n;(["undefined","boolean","number","bigint","string"].includes(jm.default(t))&&(r="string"==typeof t?'"'.concat(t,'"'):"".concat(t)),"object"===jm.default(t)&&"Object"!==(null==t||null===(e=t.constructor)||void 0===e?void 0:e.name))&&(r=null===t?"null":"instance of ".concat(null==t||null===(n=t.constructor)||void 0===n?void 0:n.name));return r||(r=jm.default(t)),r},Ym=function(t){var e,r=[],n=zm(t);try{for(n.s();!(e=n.n()).done;){var o=e.value;r.push(Jm(o))}}catch(t){n.e(t)}finally{n.f()}return r},Jm=function(t){var e,r=[],n=zm(Array.isArray(t)?t:[t]);try{for(n.s();!(e=n.n()).done;){var o=e.value;"string"!=typeof o&&"function"!=typeof o?r.push(o):r.push(Um(o))}}catch(t){n.e(t)}finally{n.f()}return r},Xm=function(t,e){var r,n,o=[],i=!1,a=zm(t);try{for(a.s();!(n=a.n()).done;){var u,c=zm(n.value.checks);try{for(c.s();!(u=c.n()).done;){var s=(0,u.value)(e),f=Tm.default(s,3),l=f[0],p=f[1],h=f[2];i=i||l,!r&&h&&(r=h),p&&(o=[].concat(Lm.default(o),"string"==typeof p?[p]:Lm.default(p)))}}catch(t){c.e(t)}finally{c.f()}}}catch(t){a.e(t)}finally{a.f()}if(i)return[!0];var d=r||Hm(e),v=o.length-1;return[!1,d,v>0?"".concat(o.slice(0,v).join(", ")," or ").concat(o[v]):o.join(", "),v>1?";":","]};function Km(t,e){var r="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!r){if(Array.isArray(t)||(r=function(t,e){if(!t)return;if("string"==typeof t)return Zm(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);"Object"===r&&t.constructor&&(r=t.constructor.name);if("Map"===r||"Set"===r)return Array.from(t);if("Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r))return Zm(t,e)}(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,o=function(){};return{s:o,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,u=!1;return{s:function(){r=r.call(t)},n:function(){var t=r.next();return a=t.done,t},e:function(t){u=!0,i=t},f:function(){try{a||null==r.return||r.return()}finally{if(u)throw i}}}}function Zm(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}Md.array=function(t,e){return Cm((function(r){if(!Array.isArray(r))return[!1,"an array of ".concat(t)];var n,o=Km(r.entries());try{for(o.s();!(n=o.n()).done;){var i=Tm.default(n.value,2),a=i[0],u=i[1],c=Xm(Jm(e),u),s=Tm.default(c,3),f=s[0],l=s[1],p=s[2];if(!f)return[!1,"a valid array of ".concat(t," (index ").concat(a," should be ").concat(p,")"),"malformed array of ".concat(t," (index ").concat(a," is ").concat(l,")")]}}catch(t){o.e(t)}finally{o.f()}return[!0]}))},Md.custom=Cm;var Qm=Md.literal=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return Cm((function(t){var r,n=!1,o=[],i=Nm(e);try{for(i.s();!(r=i.n()).done;){var a=r.value;n=n||t===a,o.push("string"==typeof a?'"'.concat(a,'"'):"".concat(a))}}catch(t){i.e(t)}finally{i.f()}return[n,o]}))},tb=Md.nonEmptyString=Bm;Md.nonNegativeInteger=qm,Md.objectSchema=function(t,e){return Cm((function(r){if("object"!==jm.default(r)||null===r||Array.isArray(r))return[!1,"valid ".concat(t," (should be a pure object)")];for(var n=0,o=Object.entries(e);n<o.length;n++){var i=Tm.default(o[n],2),a=i[0],u=i[1],c=Xm(Jm(u),r[a]),s=Tm.default(c,3),f=s[0],l=s[1],p=s[2];if(!f)return[!1,"valid ".concat(t,' (key "').concat(a,'" should be ').concat(p,")"),"malformed ".concat(t,' (key "').concat(a,'" is ').concat(l,")")]}return[!0]}))};var eb=Md.pureObject=Gm;Md.runtimeTypeValidation=Vm,Md.stringifyReceivedType=Hm,Md.type=Um;var rb,nb,ob=Md.validateConstructorTypes=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];var n=Ym(e);return function(t){return function(t){Rm.default(r,t);var e=Wm(r);function r(){_m.default(this,r);for(var t=arguments.length,o=new Array(t),i=0;i<t;i++)o[i]=arguments[i];return Vm(n,o),e.call.apply(e,[this].concat(o))}return r}(t)}},ib=Md.validateTypes=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];var n=Ym(e);return function(t,e,r){if("function"!=typeof r.value)throw new Error("The validateTypes decorator can only be applied to methods");var o=r.value;r.value=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];return Vm(n,e),o.apply(this,e)}}},ab=Md.validateTypesAsync=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];var n=Ym(e);return function(t,e,r){if("function"!=typeof r.value)throw new Error("The validateTypesAsync decorator can only be applied to methods");var o=r.value;r.value=function(){for(var t=arguments.length,e=new Array(t),r=0;r<t;r++)e[r]=arguments[r];try{Vm(n,e)}catch(t){return Promise.reject(t)}return o.apply(this,e)}}},ub=Va.scope("");return t.default=(nb=rb=class{constructor(t,e,r){var n,o,i=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};this.options=i,this.options.logLevel=null!==(n=this.options.logLevel)&&void 0!==n?n:"silent",this.config=new hu(t,e,r,this.options),ub.setLevel(this.options.logLevel),this.options.transport=null!==(o=this.options.transport)&&void 0!==o?o:new Zc,this.transport=this.options.transport,this.network=new Dd(this.config,this.transport)}updateToken(t){ub.info("updateToken"),this.config.updateToken(t)}get(t){var e=this;return n(Sa.mark((function r(){var n;return Sa.wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return r.next=2,e.network.get("".concat(e.config.mediaUrl,"/").concat(t));case 2:return n=r.sent,r.abrupt("return",new du(e.config,e.network,n.body));case 4:case"end":return r.stop()}}),r)})))()}post(t,e,r,o){var i=this;return n(Sa.mark((function n(){var a;return Sa.wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,i.network.post(i.config.mediaUrl,null!=r?r:"media",e,t,o);case 2:return a=n.sent,n.abrupt("return",new du(i.config,i.network,a.body));case 4:case"end":return n.stop()}}),n)})))()}postFormData(t,e){var r=this;return n(Sa.mark((function n(){var o;return Sa.wrap((function(n){for(;;)switch(n.prev=n.next){case 0:return n.next=2,r.network.post(r.config.mediaUrl,null!=e?e:"media",t);case 2:return o=n.sent,n.abrupt("return",new du(r.config,r.network,o.body));case 4:case"end":return n.stop()}}),n)})))()}mediaSetGet(t){var e=this;return n(Sa.mark((function r(){var n,o;return Sa.wrap((function(r){for(;;)switch(r.prev=r.next){case 0:return n={command:"get",list:t.map((t=>({media_sid:t})))},r.next=3,e.network.post("".concat(e.config.mediaSetUrl),null,JSON.stringify(n),"application/json");case 3:return o=r.sent,r.abrupt("return",o.map((t=>{if(200!==t.code)throw new Error("Failed to obtain detailed information about Media items (failed SID ".concat(t.media_record.sid,")"));return new du(e.config,e.network,t.media_record)})));case 5:case"end":return r.stop()}}),r)})))()}},o(rb,"version","0.5.2"),nb),ka([ib(tb),Aa("design:type",Function),Aa("design:paramtypes",[String]),Aa("design:returntype",void 0)],t.default.prototype,"updateToken",null),ka([ab(tb),Aa("design:type",Function),Aa("design:paramtypes",[String]),Aa("design:returntype",Promise)],t.default.prototype,"get",null),t.default=ka([ob(tb,tb,[tb,Qm(null)],[eb,"undefined"]),Aa("design:paramtypes",[String,String,Object,Object])],t.default),t.Client=t.default,t.McsClient=t.default,t.McsMedia=du,t.Media=du,t.default=t.default,Object.defineProperty(t,"__esModule",{value:!0}),t}({});
|
package/dist/client.js
ADDED
|
@@ -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;;;;;"}
|
package/dist/index.js
ADDED
|
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/dist/logger.js
ADDED
|
@@ -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;;;;;"}
|