Comparing version 7.81.2 to 7.82.0
@@ -1,2 +0,2 @@ | ||
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@tsed/core"),require("@tsed/schema")):"function"==typeof define&&define.amd?define(["@tsed/core","@tsed/schema"],t):"object"==typeof exports?exports["@tsed/di"]=t(require("@tsed/core"),require("@tsed/schema")):e["@tsed/di"]=t(e["@tsed/core"],e["@tsed/schema"])}(self,((e,t)=>(()=>{"use strict";var r={803:t=>{t.exports=e},953:e=>{e.exports=t}},s={};function o(e){var t=s[e];if(void 0!==t)return t.exports;var n=s[e]={exports:{}};return r[e](n,n.exports,o),n.exports}o.d=(e,t)=>{for(var r in t)o.o(t,r)&&!o.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},o.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),o.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var n={};return(()=>{o.r(n),o.d(n,{Configuration:()=>p,Constant:()=>d,Container:()=>_,Controller:()=>P,ControllerProvider:()=>x,DIConfiguration:()=>K,DI_PARAMS:()=>t,DI_PARAM_OPTIONS:()=>r,GlobalProviderRegistry:()=>m,GlobalProviders:()=>O,INJECTABLE_PROP:()=>e,Inject:()=>l,Injectable:()=>T,InjectablePropertyType:()=>s,InjectionError:()=>U,InjectorService:()=>Y,Intercept:()=>C,Interceptor:()=>R,InvalidPropertyTokenError:()=>a,LOGGER:()=>W,LazyInject:()=>I,LocalsContainer:()=>V,Module:()=>w,OptionalLazyInject:()=>S,Opts:()=>j,OverrideProvider:()=>N,Provider:()=>v,ProviderScope:()=>g,ProviderType:()=>f,Scope:()=>A,Service:()=>D,UndefinedTokenError:()=>G,UseOpts:()=>M,Value:()=>L,colors:()=>$,createContainer:()=>H,getConfiguration:()=>Z,getConstructorDependencies:()=>c,getTokens:()=>z,injectProperty:()=>h,mergeMount:()=>X,registerController:()=>b,registerProvider:()=>E,registerValue:()=>k,resolveControllers:()=>J,setConstructorDependencies:()=>u});const e="DI:INJECTABLE_PROP",t="DI:PARAMS",r="DI:PARAM:OPTIONS";var s,i=o(803);class a extends Error{name="INVALID_TOKEN_ERROR";constructor(e,t){super(`Object isn't a valid token. Please check the token set on ${(0,i.nameOf)((0,i.classOf)(e))}.${t}.\n- Check that it is not a circular reference.\n- Check that the token (class or symbol) exists`)}}function c(e,t){return i.Metadata.getOwn("override:ctor:design:paramtypes",e,t)||[...i.Metadata.getParamTypes(e,t)]||[]}function u(e,t){i.Metadata.set("override:ctor:design:paramtypes",t,e)}function h(t,r,s){i.Store.from(t).merge(e,{[r]:{bindingType:i.DecoratorTypes.PROP,propertyKey:r,...s}})}function l(e,t=(e=>e)){return(s,o,n)=>{switch((0,i.decoratorTypeOf)([s,o,n])){case i.DecoratorTypes.PARAM_CTOR:if(e){const t=c(s,o),r=t[n];t[n]=r===Array?[e]:e,i.Metadata.setParamTypes(s,o,t),u(s,t)}break;case i.DecoratorTypes.PROP:const p=e||i.Metadata.getType(s,o);if(p===Object)throw new a(s,String(o));h(s,String(o),{resolver(n,a,{options:c,...u}){const h=i.Metadata.getType(s,o);if(a.set(r,{...c}),h===Array){let s;return s||(s=n.getMany(e,a,u),a.delete(r)),s.forEach(((e,t)=>{(0,i.isPromise)(s)&&e.then((e=>{s[t]=e}))})),()=>t(s)}let l;return l||(l=n.invoke(p,a,u),a.delete(r)),(0,i.isPromise)(l)&&l.then((e=>{l=e})),()=>t(l)}});break;default:throw new i.UnsupportedDecoratorType(l,[s,o,n])}}}function p(e={}){return(...t)=>{switch((0,i.decoratorTypeOf)(t)){case i.DecoratorTypes.CLASS:(0,i.StoreSet)("configuration",e)(t[0]);break;default:case i.DecoratorTypes.PARAM_CTOR:return l(p)(t[0],t[1],t[2])}}}function d(t,r){return(o,n)=>{i.Store.from(o).merge(e,{[n]:{bindingType:s.CONSTANT,propertyKey:n,expression:t,defaultValue:r}})}}!function(e){e.METHOD="method",e.PROPERTY="property",e.CONSTANT="constant",e.VALUE="value",e.INTERCEPTOR="interceptor"}(s||(s={}));var g,f,y=o(953);!function(e){e.SINGLETON="singleton",e.REQUEST="request",e.INSTANCE="instance"}(g||(g={})),function(e){e.VALUE="value",e.FACTORY="factory",e.SERVICE="service",e.PROVIDER="provider",e.MODULE="module",e.CONTROLLER="controller",e.INTERCEPTOR="interceptor",e.MIDDLEWARE="middleware"}(f||(f={}));class v{type=f.PROVIDER;deps;imports;alias;useFactory;useAsyncFactory;useValue;hooks;_useClass;_provide;_store;_tokenStore;constructor(e,t={}){this.provide=e,this.useClass=e,Object.assign(this,t)}get token(){return this._provide}get provide(){return this._provide}set provide(e){e&&(this._provide=(0,i.getClassOrSymbol)(e),this._tokenStore=this._store=i.Store.from(e))}get useClass(){return this._useClass}set useClass(e){(0,i.isClass)(e)&&(this._useClass=(0,i.classOf)(e),this._store=i.Store.from(e),this.hooks=(0,i.methodsOf)(this._useClass).reduce(((e,{propertyKey:t})=>String(t).startsWith("$")?{...e,[t]:(e,...r)=>e[t](...r)}:e),{}))}get className(){return this.name}get name(){return(0,i.nameOf)(this.provide)}get store(){return this._store}get path(){return this.store.get("path","/")}set path(e){this.store.set("path",e)}get scope(){return this.isAsync()?g.SINGLETON:this.get("scope")}set scope(e){this.store.set("scope",e)}get configuration(){return this.get("configuration")}set configuration(e){this.store.set("configuration",e)}get children(){return this.store.get("childrenControllers",[])}get(e){return this.store.get(e)||this._tokenStore.get(e)}isAsync(){return!!this.useAsyncFactory}clone(){return new((0,i.classOf)(this))(this._provide,this)}hasChildren(){return!!this.children.length}hasParent(){return!!this.store.get("parentController")}toString(){return["Token",this.name,this.useClass&&(0,i.nameOf)(this.useClass),this.useFactory&&"Factory",this.useValue&&"Value",this.useAsyncFactory&&"AsyncFactory"].filter(Boolean).join(":")}}class m extends Map{#e=new Map;get(e){return super.get((0,i.getClassOrSymbol)(e))}has(e){return super.has((0,i.getClassOrSymbol)(e))}set(e,t){return super.set((0,i.getClassOrSymbol)(e),t),this}merge(e,t){const r=this.createIfNotExists(e,t);return Object.keys(t).forEach((e=>{r[e]=t[e]})),this.set(e,r),r}delete(e){return super.delete((0,i.getClassOrSymbol)(e))}createRegistry(e,t,r={}){const s=this.getRegistrySettings(e);return r=Object.assign(s,{...r,model:t}),this.#e.set(e,r),this}onInvoke(e,t,r){const s=this.#e.get(e.type);s?.onInvoke&&s.onInvoke(e,t,r)}getRegistrySettings(e){let t="provider";if("string"==typeof e)t=e;else{const r=this.get(e);r&&(t=r.type)}return this.#e.get(t)||{model:v}}createRegisterFn(e){return(t,r)=>{t=Object.assign({instance:r},t,{type:e}),this.merge(t.provide,t)}}createIfNotExists(e,t){const r=t.type||f.PROVIDER;if(!this.has(e)){const{model:s=v}=this.#e.get(r)||{},o=new s(e,t);this.set(e,o)}return this.get(e)}}const O=new m;function E(e){if(!e.provide)throw new Error("Provider.provide is required");return O.merge(e.provide,e)}O.createRegistry(f.CONTROLLER,v);const k=(e,t)=>{e.provide||(e={provide:e}),e=Object.assign({scope:g.SINGLETON,useValue:t},e,{type:f.VALUE}),O.merge(e.provide,e)},b=O.createRegisterFn(f.CONTROLLER);function P(e){const{children:t=[],path:r,...s}=function(e){return"string"==typeof e||e instanceof RegExp||(0,i.isArrayOrArrayClass)(e)?{path:e}:e}(e);return(0,i.useDecorators)((e=>{b({provide:e,...s})}),r&&(0,y.Path)(r),(0,y.Children)(...t))}function T(e={}){return t=>{E({...e,...e.provide?{useClass:t}:{provide:t}})}}function C(t,r){return(...o)=>{const[n,a,c]=o;switch((0,i.decoratorTypeOf)(o)){case i.DecoratorTypes.CLASS:(0,i.decorateMethodsOf)(n,C(t,r));break;case i.DecoratorTypes.METHOD:return i.Store.from(n).merge(e,{[a]:{options:r,propertyKey:a,useType:t,bindingType:s.INTERCEPTOR}}),c}}}function R(){return T({type:f.INTERCEPTOR})}function I(e,t,{optional:r=!1,packageName:s=t.toString()}={}){return(o,n)=>{let a,c;h(o,n,{resolver:o=>async()=>{if(!c){const n=await(0,i.importPackage)(s,t,r);if(c=n[e],!c&&!r)throw new Error(`Unable to lazy load the "${e}". The token isn't a valid token provider.`);a=c?await o.lazyInvoke(c):{}}return a}})}}function S(e,t){return I(e,t,{optional:!0})}function w(e={}){const{scopes:t,imports:r,resolvers:s,deps:o,scope:n,...a}=e;return(0,i.useDecorators)(p(a),T({type:f.MODULE,scope:g.SINGLETON,imports:r,deps:o,injectable:!1,resolvers:s}))}function A(e=g.REQUEST){return(0,i.StoreSet)("scope",e)}function j(e,t,s){A(g.INSTANCE)((0,i.classOf)(e)),l(r)(e,t,s)}function N(e){return t=>{O.get(e).useClass=t}}function D(){return T()}function M(t){return(s,o,n)=>{switch((0,i.decoratorTypeOf)([s,o,n])){case i.DecoratorTypes.PARAM_CTOR:i.Store.from(s).merge(`${r}:${n}`,t);break;case i.DecoratorTypes.PROP:i.Store.from(s).merge(e,{[o]:{options:t}});break;default:throw new i.UnsupportedDecoratorType(M,[s,o,n])}}}function L(t,r){return(o,n)=>{i.Store.from(o).merge(e,{[n]:{bindingType:s.VALUE,propertyKey:n,expression:t,defaultValue:r}})}}class _ extends Map{add(e,t={}){const r=O.get(e)?.clone()||new v(e);return Object.assign(r,t),super.set(e,r)}addProvider(e,t={}){return this.add(e,t)}hasProvider(e){return super.has(e)}setProvider(e,t){return super.set(e,t)}getProvider(e){return super.get(e)}getProviders(e){const t=[].concat(e);return[...this].reduce(((r,[s,o])=>t.includes(o.type)||!e?[...r,o]:r),[])}addProviders(e){e.forEach((e=>{this.hasProvider(e.provide)||this.setProvider(e.provide,e.clone())}))}}class x extends v{tokenRouter;constructor(e,t={}){super(e,t),this.type=f.CONTROLLER}get middlewares(){return Object.assign({use:[],useAfter:[],useBefore:[]},this.store.get("middlewares",{}))}set middlewares(e){const t=this.middlewares;Object.keys(e).forEach((r=>{((e,t,r)=>{t[e]=t[e].concat(r[e])})(r,t,e)})),this.store.set("middlewares",t)}}class V extends Map{hooks=new i.Hooks;async destroy(){await this.hooks.asyncEmit("$onDestroy")}}const F=e=>e=>(process.env.NO_COLOR,e),$={red:F(),yellow:F(),green:F()};class U extends Error{name="INJECTION_ERROR";tokens=[];origin;constructor(e,t){super((0,i.isString)(t)?t:""),this.tokens=[e],t&&((0,i.isString)(t)?this.origin={message:t,stack:this.stack}:t.tokens?(this.tokens=this.tokens.concat(t.tokens),this.origin=t.origin):(this.origin=t,this.stack=t.stack));const r=this.origin?"\nOrigin: "+this.origin.message:"",s=this.tokens.map((e=>(0,i.nameOf)(e))).join(" > ");this.message=`Injection failed on ${s}${r}`}static throwInjectorError(e,t,r){throw t&&(0,i.isClass)(e)&&(r.message=function(e,t){let r="";const s=(0,i.getConstructorArgNames)(e).map(((e,s)=>(t.index===s&&(r=e,e=$.red(e)),`${e}: ${(0,i.nameOf)(t.deps[s])}`))).join(", "),o=(0,i.nameOf)(e)+"->constructor("+s+")",n=o.indexOf(r)-5;return"Unable to inject dependency. "+t.message+"\n\n"+o+"\n"+(n>-1?(e=>" ".repeat(e)+$.red("^"+"‾".repeat(r.length-1)))(n):"")}(e,{...t,message:r.message})),new U(e,r)}}class G extends Error{name="UNDEFINED_TOKEN_ERROR";constructor(){super("Given token is undefined. Have you enabled emitDecoratorMetadata in your tsconfig.json or decorated your class with @Injectable, @Service, ... decorator ?")}}class K{default=new Map;map=new Map;constructor(e={}){return Object.entries({scopes:{},resolvers:[],imports:[],routes:[],logger:{},...e}).forEach((([e,t])=>{this.default.set(e,t)})),(0,i.proxyDelegation)(this,{ownKeys:e=>[...e.default.keys(),...e.map.keys()]})}get version(){return this.get("version")}set version(e){this.map.set("version",e)}get rootDir(){return this.get("rootDir")}set rootDir(e){this.map.set("rootDir",e)}get env(){return this.map.get("env")}set env(e){this.map.set("env",e)}get scopes(){return this.map.get("scopes")}set scopes(e){this.map.set("scopes",e)}get resolvers(){return this.getRaw("resolvers")}set resolvers(e){this.map.set("resolvers",e)}get imports(){return this.get("imports")}set imports(e){this.map.set("imports",e)}get routes(){return this.get("routes")}set routes(e){this.map.set("routes",e)}get logger(){return this.get("logger")}set logger(e){const t={...this.logger,...e};this.map.set("logger",t)}get debug(){return"debug"===this.logger.level}set debug(e){this.logger={...this.logger,level:e?"debug":"info"}}forEach(e,t){return new Set([...Array.from(this.default.keys()),...Array.from(this.map.keys())]).forEach((t=>{e(this.getRaw(t),t,this.map)}),t)}set(e,t){return"string"==typeof e?Reflect.has(this,e)?this[e]=t:this.setRaw(e,t):Object.entries(e).forEach((([e,t])=>{this.set(e,t)})),this}setRaw(e,t){return(0,i.setValue)(this.map,e,t),this}get(e,t){return this.getRaw(e,t)}resolve(e){return e.replace("${rootDir}",this.rootDir)}getRaw(e,t){const r=(0,i.getValue)(this.map,e);return void 0!==r?r:(0,i.getValue)(this.default,e,t)}}function H(e){const t=new _(O.entries());return e&&t.delete(e),t}Object.create,Object.create,"function"==typeof SuppressedError&&SuppressedError;const q=["mount","imports"];function z(e){return e?(0,i.isArray)(e)?e.filter(i.isClass).map((e=>({token:e}))):Object.keys(e).reduce(((t,r)=>[...t,...[].concat(e[r]).filter(i.isClass).map((e=>({route:r,token:e})))]),[]):[]}function B(e){return e.map((({token:e})=>O.get(e))).filter((e=>e?.type===f.MODULE&&e.configuration)).flatMap((e=>J(e.configuration)))}function J(e){const t=q.flatMap((t=>z(e[t])));return[...B(t),...t].filter((e=>!!e.route))}var Q;let Y=Q=class extends _{settings=new K;logger=console;resolvedConfiguration=!1;#t=new V;#r=new i.Hooks;constructor(){super(),this.#t.set(Q,this)}get resolvers(){return this.settings.resolvers}get scopes(){return this.settings.scopes||{}}scopeOf(e){return e.scope||this.scopes[e.type]||g.SINGLETON}toArray(){return[...this.#t.values()]}get(e,t={}){const r=this.getInstance(e);if(void 0!==r)return r;if(!this.hasProvider(e))for(const r of this.resolvers){const s=r.get(e,t);if(void 0!==s)return s}}getMany(e,t,r){return this.getProviders(e).map((e=>this.invoke(e.token,t,r)))}has(e){return void 0!==this.#t.get(e)}alias(e,t){return this.#t.set(t,this.#t.get(e)),this}invoke(e,t,s={}){let o=t?t.get(e):void 0;if(void 0!==o)return o;if(e===p)return this.settings;if(o=s.rebuild?void 0:this.getInstance(e),null!=o)return o;if(e===r)return{};const n=this.ensureProvider(e),a=t=>{this.#t.set(e,t),n?.alias&&this.alias(e,n.alias)};if(!n||s.rebuild)return o=this.resolve(e,t,s),this.hasProvider(e)&&a(o),o;switch(o=this.resolve(e,t,s),this.scopeOf(n)){case g.SINGLETON:return n.hooks&&!s.rebuild&&this.registerHooks(n,o),n.isAsync()&&(0,i.isPromise)(o)?(a(o),o=o.then((e=>(a(e),e))),o):(a(o),o);case g.REQUEST:return t&&(t.set(e,o),n.hooks&&n.hooks.$onDestroy&&t.hooks.on("$onDestroy",((...e)=>n.hooks.$onDestroy(o,...e)))),o}return o}async loadAsync(){for(const[,e]of this)!this.has(e.token)&&e.isAsync()&&await this.invoke(e.token)}loadSync(){for(const[,e]of this)this.has(e.token)||this.scopeOf(e)!==g.SINGLETON||this.invoke(e.token)}bootstrap(e=H()){return this.addProviders(e),this.resolveConfiguration(),this.resolveImportsProviders(),this}loadModule(e){this.settings.routes=this.settings.routes.concat(J(this.settings));const t=H();return t.delete(e),t.addProvider(e,{type:"server:module",scope:g.SINGLETON}),this.load(t)}async load(e=H()){this.bootstrap(e),await this.loadAsync(),this.loadSync(),await this.emit("$beforeInit"),await this.emit("$onInit")}resolveConfiguration(){if(this.resolvedConfiguration)return;const e=new Map;super.forEach((t=>{t.configuration&&"server:module"!==t.type&&Object.entries(t.configuration).forEach((([t,r])=>{["resolvers","mount","imports"].includes(t)||(r=e.has(t)?(0,i.deepMerge)(e.get(t),r):(0,i.deepClone)(r),e.set(t,r))})),t.resolvers&&(this.settings.resolvers=this.settings.resolvers.concat(t.resolvers))})),e.forEach(((e,t)=>{this.settings.set(t,(0,i.deepMerge)(e,this.settings.get(t)))})),this.resolvedConfiguration=!0}bindInjectableProperties(t,r,o){const n=(0,i.ancestorsOf)((0,i.classOf)(t)).reduce(((t,r)=>({...t,...i.Store.from(r).get(e)||{}})),{});Object.values(n).forEach((e=>{switch(e.bindingType){case s.PROPERTY:this.bindProperty(t,e,r,o);break;case s.CONSTANT:this.bindConstant(t,e);break;case s.VALUE:this.bindValue(t,e);break;case s.INTERCEPTOR:this.bindInterceptor(t,e)}}))}bindProperty(e,{propertyKey:t,resolver:r,options:s={}},o,n){let a;a=r(this,o,{...n,options:s}),(0,i.catchError)((()=>Object.defineProperty(e,t,{get:a})))}bindValue(e,{propertyKey:t,expression:r,defaultValue:s}){const o={get:()=>this.settings.get(r)||s,set:e=>this.settings.set(r,e),enumerable:!0,configurable:!0};(0,i.catchError)((()=>Object.defineProperty(e,t,o)))}bindConstant(e,{propertyKey:t,expression:r,defaultValue:s}){let o;const n={get:()=>{if(void 0!==o)return o;const e=this.settings.get(r,s);return o=Object.freeze((0,i.deepClone)(e)),o},enumerable:!0,configurable:!0};(0,i.catchError)((()=>Object.defineProperty(e,t,n)))}bindInterceptor(e,{propertyKey:t,useType:r,options:s}){const o=(0,i.classOf)(e),n=e[t];e[t]=(...i)=>{const a=t=>{if(!t)return n.apply(e,i);throw t},c={target:o,propertyKey:t,args:i,options:s,next:a};return this.get(r).intercept({...c,options:s},a)}}async lazyInvoke(e){let t=this.getInstance(e);return t||(t=await this.invoke(e),(0,i.isFunction)(t?.$onInit)&&await t.$onInit()),t}emit(e,...t){return this.#r.asyncEmit(e,t)}alter(e,t,...r){return this.#r.alter(e,t,r)}alterAsync(e,t,...r){return this.#r.asyncAlter(e,t,r)}destroy(){return this.emit("$onDestroy")}ensureProvider(e,t=!1){return this.hasProvider(e)||!O.has(e)&&!t||this.addProvider(e),this.getProvider(e)}getInstance(e){return this.#t.get(e)}resolve(e,t=new V,s={}){const o=this.mapInvokeOptions(e,t,s);if(!o)return;const{token:n,deps:a,construct:c,imports:u,provider:h}=o;let l;h&&O.onInvoke(h,t,{...o,injector:this});let p=!1;try{const e=e=>(o,n)=>{if(p={token:o,index:n,deps:a},o!==r){const e=h?.store?.get(`${r}:${n}`);t.set(r,e||{})}return(0,i.isArray)(o)?this.getMany(o[0],t,s):(0,i.isInheritedFrom)(o,v,1)?h:this.invoke(o,t,{parent:e})};u.forEach(e());const o=a.map(e(n));p=!1,l=c(o)}catch(e){U.throwInjectorError(n,p,e)}if(void 0===l)throw new U(n,`Unable to create new instance from undefined value. Check your provider declaration for ${(0,i.nameOf)(n)}`);return l&&(0,i.isClass)((0,i.classOf)(l))&&this.bindInjectableProperties(l,t,s),l}resolveImportsProviders(){this.settings.imports=this.settings.imports?.filter((e=>e.token!==Q)).map((e=>{if("token"in e){const{token:t,...r}=e,s=this.ensureProvider(t,!0);if(s){if(s.useValue=void 0,s.useAsyncFactory=void 0,s.useFactory=void 0,"useClass"in r)return void(s.useClass=r.useClass);if("useFactory"in r)return void(s.useFactory=r.useFactory);if("useAsyncFactory"in r)return void(s.useAsyncFactory=r.useAsyncFactory);if("use"in r)return void(s.useValue=r.use)}}return e})).filter(Boolean)}mapInvokeOptions(e,t,s){let o,n,a=s.imports,u=s.deps,h=s.scope;if(!e||e===Object)throw new G;if(this.hasProvider(e)?n=this.getProvider(e):(n=new v(e),this.resolvers.forEach((s=>{const o=s.get(e,t.get(r));void 0!==o&&(n.useFactory=()=>o)}))),h=h||this.scopeOf(n),u=u||n.deps,a=a||n.imports,void 0!==n.useValue)o=()=>(0,i.isFunction)(n.useValue)?n.useValue():n.useValue;else if(n.useFactory)o=e=>n.useFactory(...e);else if(n.useAsyncFactory)o=async e=>(e=await Promise.all(e),n.useAsyncFactory(...e));else{if(!n.useClass)return!1;u=u||c(n.useClass),o=e=>new n.useClass(...e)}return{token:e,scope:h||i.Store.from(e).get("scope")||g.SINGLETON,deps:u||[],imports:a||[],construct:o,provider:n}}registerHooks(e,t){e.hooks&&Object.entries(e.hooks).forEach((([r,s])=>{this.#r.on(r,((...r)=>s(this.get(e.token)||t,...r)))}))}};Y=Q=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([T({scope:g.SINGLETON,global:!0}),function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}("design:paramtypes",[])],Y);const W=Symbol.for("LOGGER");function X(e={},t={}){return Object.entries(t).reduce(((e,[t,r])=>({...e,[t]:(e[t]||[]).concat(r)})),e)}function Z(e,t={}){const r=i.Store.from(e).get("configuration")||{};return{...r,...t,mount:X(r.mount,t.mount)}}E({provide:W,deps:[Y],useFactory:e=>e.logger})})(),n})())); | ||
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("@tsed/core"),require("@tsed/schema")):"function"==typeof define&&define.amd?define(["@tsed/core","@tsed/schema"],t):"object"==typeof exports?exports["@tsed/di"]=t(require("@tsed/core"),require("@tsed/schema")):e["@tsed/di"]=t(e["@tsed/core"],e["@tsed/schema"])}(self,((e,t)=>(()=>{"use strict";var r={803:t=>{t.exports=e},953:e=>{e.exports=t}},s={};function o(e){var t=s[e];if(void 0!==t)return t.exports;var n=s[e]={exports:{}};return r[e](n,n.exports,o),n.exports}o.d=(e,t)=>{for(var r in t)o.o(t,r)&&!o.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},o.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),o.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var n={};return(()=>{o.r(n),o.d(n,{AutoInjectable:()=>_,Configuration:()=>g,Constant:()=>V,Container:()=>k,Controller:()=>$,ControllerProvider:()=>X,DIConfiguration:()=>D,DI_PARAMS:()=>t,DI_PARAM_OPTIONS:()=>r,GlobalProviderRegistry:()=>y,GlobalProviders:()=>v,INJECTABLE_PROP:()=>e,Inject:()=>d,Injectable:()=>E,InjectablePropertyType:()=>P,InjectionError:()=>R,InjectorService:()=>x,Intercept:()=>U,Interceptor:()=>G,InvalidPropertyTokenError:()=>u,LOGGER:()=>Z,LazyInject:()=>K,LocalsContainer:()=>c,Module:()=>q,OptionalLazyInject:()=>H,Opts:()=>B,OverrideProvider:()=>J,Provider:()=>f,ProviderScope:()=>s,ProviderType:()=>i,Scope:()=>z,Service:()=>Q,UndefinedTokenError:()=>I,UseOpts:()=>Y,Value:()=>W,colors:()=>C,createContainer:()=>S,getConfiguration:()=>te,getConstructorDependencies:()=>h,getTokens:()=>A,injectProperty:()=>p,mergeMount:()=>ee,registerController:()=>b,registerProvider:()=>m,registerValue:()=>O,resolveControllers:()=>N,setConstructorDependencies:()=>l});const e="DI:INJECTABLE_PROP",t="DI:PARAMS",r="DI:PARAM:OPTIONS";var s,i,a=o(803);class c extends Map{hooks=new a.Hooks;async destroy(){await this.hooks.asyncEmit("$onDestroy")}}Object.create,Object.create,"function"==typeof SuppressedError&&SuppressedError;class u extends Error{name="INVALID_TOKEN_ERROR";constructor(e,t){super(`Object isn't a valid token. Please check the token set on ${(0,a.nameOf)((0,a.classOf)(e))}.${t}.\n- Check that it is not a circular reference.\n- Check that the token (class or symbol) exists`)}}function h(e,t){return a.Metadata.getOwn("override:ctor:design:paramtypes",e,t)||[...a.Metadata.getParamTypes(e,t)]||[]}function l(e,t){a.Metadata.set("override:ctor:design:paramtypes",t,e)}function p(t,r,s){a.Store.from(t).merge(e,{[r]:{bindingType:a.DecoratorTypes.PROP,propertyKey:r,...s}})}function d(e,t=(e=>e)){return(s,o,n)=>{switch((0,a.decoratorTypeOf)([s,o,n])){case a.DecoratorTypes.PARAM_CTOR:if(e){const t=h(s,o),r=t[n];t[n]=r===Array?[e]:e,a.Metadata.setParamTypes(s,o,t),l(s,t)}break;case a.DecoratorTypes.PROP:const i=e||a.Metadata.getType(s,o);if(i===Object)throw new u(s,String(o));p(s,String(o),{resolver(n,c,{options:u,...h}){const l=a.Metadata.getType(s,o);if(c.set(r,{...u}),l===Array){let s;return s||(s=n.getMany(e,c,h),c.delete(r)),s.forEach(((e,t)=>{(0,a.isPromise)(s)&&e.then((e=>{s[t]=e}))})),()=>t(s)}let p;return p||(p=n.invoke(i,c,h),c.delete(r)),(0,a.isPromise)(p)&&p.then((e=>{p=e})),()=>t(p)}});break;default:throw new a.UnsupportedDecoratorType(d,[s,o,n])}}}function g(e={}){return(...t)=>{switch((0,a.decoratorTypeOf)(t)){case a.DecoratorTypes.CLASS:(0,a.StoreSet)("configuration",e)(t[0]);break;default:case a.DecoratorTypes.PARAM_CTOR:return d(g)(t[0],t[1],t[2])}}}!function(e){e.SINGLETON="singleton",e.REQUEST="request",e.INSTANCE="instance"}(s||(s={})),function(e){e.VALUE="value",e.FACTORY="factory",e.SERVICE="service",e.PROVIDER="provider",e.MODULE="module",e.CONTROLLER="controller",e.INTERCEPTOR="interceptor",e.MIDDLEWARE="middleware"}(i||(i={}));class f{type=i.PROVIDER;deps;imports;alias;useFactory;useAsyncFactory;useValue;hooks;_useClass;_provide;_store;_tokenStore;constructor(e,t={}){this.provide=e,this.useClass=e,Object.assign(this,t)}get token(){return this._provide}get provide(){return this._provide}set provide(e){e&&(this._provide=(0,a.getClassOrSymbol)(e),this._tokenStore=this._store=a.Store.from(e))}get useClass(){return this._useClass}set useClass(e){(0,a.isClass)(e)&&(this._useClass=(0,a.classOf)(e),this._store=a.Store.from(e),this.hooks=(0,a.methodsOf)(this._useClass).reduce(((e,{propertyKey:t})=>String(t).startsWith("$")?{...e,[t]:(e,...r)=>e[t](...r)}:e),{}))}get className(){return this.name}get name(){return(0,a.nameOf)(this.provide)}get store(){return this._store}get path(){return this.store.get("path","/")}set path(e){this.store.set("path",e)}get scope(){return this.isAsync()?s.SINGLETON:this.get("scope")}set scope(e){this.store.set("scope",e)}get configuration(){return this.get("configuration")}set configuration(e){this.store.set("configuration",e)}get children(){return this.store.get("childrenControllers",[])}get(e){return this.store.get(e)||this._tokenStore.get(e)}isAsync(){return!!this.useAsyncFactory}clone(){return new((0,a.classOf)(this))(this._provide,this)}hasChildren(){return!!this.children.length}hasParent(){return!!this.store.get("parentController")}toString(){return["Token",this.name,this.useClass&&(0,a.nameOf)(this.useClass),this.useFactory&&"Factory",this.useValue&&"Value",this.useAsyncFactory&&"AsyncFactory"].filter(Boolean).join(":")}}class y extends Map{#e=new Map;get(e){return super.get((0,a.getClassOrSymbol)(e))}has(e){return super.has((0,a.getClassOrSymbol)(e))}set(e,t){return super.set((0,a.getClassOrSymbol)(e),t),this}merge(e,t){const r=this.createIfNotExists(e,t);return Object.keys(t).forEach((e=>{r[e]=t[e]})),this.set(e,r),r}delete(e){return super.delete((0,a.getClassOrSymbol)(e))}createRegistry(e,t,r={}){const s=this.getRegistrySettings(e);return r=Object.assign(s,{...r,model:t}),this.#e.set(e,r),this}onInvoke(e,t,r){const s=this.#e.get(e.type);s?.onInvoke&&s.onInvoke(e,t,r)}getRegistrySettings(e){let t="provider";if("string"==typeof e)t=e;else{const r=this.get(e);r&&(t=r.type)}return this.#e.get(t)||{model:f}}createRegisterFn(e){return(t,r)=>{t=Object.assign({instance:r},t,{type:e}),this.merge(t.provide,t)}}createIfNotExists(e,t){const r=t.type||i.PROVIDER;if(!this.has(e)){const{model:s=f}=this.#e.get(r)||{},o=new s(e,t);this.set(e,o)}return this.get(e)}}const v=new y;function m(e){if(!e.provide)throw new Error("Provider.provide is required");return v.merge(e.provide,e)}v.createRegistry(i.CONTROLLER,f);const O=(e,t)=>{e.provide||(e={provide:e}),e=Object.assign({scope:s.SINGLETON,useValue:t},e,{type:i.VALUE}),v.merge(e.provide,e)},b=v.createRegisterFn(i.CONTROLLER);function E(e={}){return t=>{m({...e,...e.provide?{useClass:t}:{provide:t}})}}class k extends Map{add(e,t={}){const r=v.get(e)?.clone()||new f(e);return Object.assign(r,t),super.set(e,r)}addProvider(e,t={}){return this.add(e,t)}hasProvider(e){return super.has(e)}setProvider(e,t){return super.set(e,t)}getProvider(e){return super.get(e)}getProviders(e){const t=[].concat(e);return[...this].reduce(((r,[s,o])=>t.includes(o.type)||!e?[...r,o]:r),[])}addProviders(e){e.forEach((e=>{this.hasProvider(e.provide)||this.setProvider(e.provide,e.clone())}))}}var P;!function(e){e.METHOD="method",e.PROPERTY="property",e.CONSTANT="constant",e.VALUE="value",e.INTERCEPTOR="interceptor"}(P||(P={}));const T=e=>e=>(process.env.NO_COLOR,e),C={red:T(),yellow:T(),green:T()};class R extends Error{name="INJECTION_ERROR";tokens=[];origin;constructor(e,t){super((0,a.isString)(t)?t:""),this.tokens=[e],t&&((0,a.isString)(t)?this.origin={message:t,stack:this.stack}:t.tokens?(this.tokens=this.tokens.concat(t.tokens),this.origin=t.origin):(this.origin=t,this.stack=t.stack));const r=this.origin?"\nOrigin: "+this.origin.message:"",s=this.tokens.map((e=>(0,a.nameOf)(e))).join(" > ");this.message=`Injection failed on ${s}${r}`}static throwInjectorError(e,t,r){throw t&&(0,a.isClass)(e)&&(r.message=function(e,t){let r="";const s=(0,a.getConstructorArgNames)(e).map(((e,s)=>(t.index===s&&(r=e,e=C.red(e)),`${e}: ${(0,a.nameOf)(t.deps[s])}`))).join(", "),o=(0,a.nameOf)(e)+"->constructor("+s+")",n=o.indexOf(r)-5;return"Unable to inject dependency. "+t.message+"\n\n"+o+"\n"+(n>-1?(e=>" ".repeat(e)+C.red("^"+"‾".repeat(r.length-1)))(n):"")}(e,{...t,message:r.message})),new R(e,r)}}class I extends Error{name="UNDEFINED_TOKEN_ERROR";constructor(){super("Given token is undefined. Have you enabled emitDecoratorMetadata in your tsconfig.json or decorated your class with @Injectable, @Service, ... decorator ?")}}function S(e){const t=new k(v.entries());return e&&t.delete(e),t}const w=["mount","imports"];function A(e){return e?(0,a.isArray)(e)?e.filter(a.isClass).map((e=>({token:e}))):Object.keys(e).reduce(((t,r)=>[...t,...[].concat(e[r]).filter(a.isClass).map((e=>({route:r,token:e})))]),[]):[]}function j(e){return e.map((({token:e})=>v.get(e))).filter((e=>e?.type===i.MODULE&&e.configuration)).flatMap((e=>N(e.configuration)))}function N(e){const t=w.flatMap((t=>A(e[t])));return[...j(t),...t].filter((e=>!!e.route))}class D{default=new Map;map=new Map;constructor(e={}){return Object.entries({scopes:{},resolvers:[],imports:[],routes:[],logger:{},...e}).forEach((([e,t])=>{this.default.set(e,t)})),(0,a.proxyDelegation)(this,{ownKeys:e=>[...e.default.keys(),...e.map.keys()]})}get version(){return this.get("version")}set version(e){this.map.set("version",e)}get rootDir(){return this.get("rootDir")}set rootDir(e){this.map.set("rootDir",e)}get env(){return this.map.get("env")}set env(e){this.map.set("env",e)}get scopes(){return this.map.get("scopes")}set scopes(e){this.map.set("scopes",e)}get resolvers(){return this.getRaw("resolvers")}set resolvers(e){this.map.set("resolvers",e)}get imports(){return this.get("imports")}set imports(e){this.map.set("imports",e)}get routes(){return this.get("routes")}set routes(e){this.map.set("routes",e)}get logger(){return this.get("logger")}set logger(e){const t={...this.logger,...e};this.map.set("logger",t)}get debug(){return"debug"===this.logger.level}set debug(e){this.logger={...this.logger,level:e?"debug":"info"}}forEach(e,t){return new Set([...Array.from(this.default.keys()),...Array.from(this.map.keys())]).forEach((t=>{e(this.getRaw(t),t,this.map)}),t)}set(e,t){return"string"==typeof e?Reflect.has(this,e)?this[e]=t:this.setRaw(e,t):Object.entries(e).forEach((([e,t])=>{this.set(e,t)})),this}setRaw(e,t){return(0,a.setValue)(this.map,e,t),this}get(e,t){return this.getRaw(e,t)}resolve(e){return e.replace("${rootDir}",this.rootDir)}getRaw(e,t){const r=(0,a.getValue)(this.map,e);return void 0!==r?r:(0,a.getValue)(this.default,e,t)}}var M;let L,x=M=class extends k{settings=new D;logger=console;resolvedConfiguration=!1;#t=new c;#r=new a.Hooks;constructor(){super(),this.#t.set(M,this),L=this}get resolvers(){return this.settings.resolvers}get scopes(){return this.settings.scopes||{}}static resolveAutoInjectableArgs(e,t,r){if(!L)throw new Error("InjectorService instance is not created yet.");const s=h(e),o=[],n=Math.max(s.length,r.length);for(let i=0;i<n;i++)if(void 0!==r[i])o.push(r);else{const r=s[i],n=(0,a.isArray)(r)?L.getMany(r[0],t,{parent:e}):L.invoke(r,t,{parent:e});o.push(n)}return o}static bind(e,t){L.bindInjectableProperties(e,t,{})}scopeOf(e){return e.scope||this.scopes[e.type]||s.SINGLETON}toArray(){return[...this.#t.values()]}get(e,t={}){const r=this.getInstance(e);if(void 0!==r)return r;if(!this.hasProvider(e))for(const r of this.resolvers){const s=r.get(e,t);if(void 0!==s)return s}}getMany(e,t,r){return this.getProviders(e).map((e=>this.invoke(e.token,t,r)))}has(e){return void 0!==this.#t.get(e)}alias(e,t){return this.#t.set(t,this.#t.get(e)),this}invoke(e,t,o={}){let n=t?t.get(e):void 0;if(void 0!==n)return n;if(e===g)return this.settings;if(n=o.rebuild?void 0:this.getInstance(e),null!=n)return n;if(e===r)return{};const i=this.ensureProvider(e),c=t=>{this.#t.set(e,t),i?.alias&&this.alias(e,i.alias)};if(!i||o.rebuild)return n=this.resolve(e,t,o),this.hasProvider(e)&&c(n),n;switch(n=this.resolve(e,t,o),this.scopeOf(i)){case s.SINGLETON:return i.hooks&&!o.rebuild&&this.registerHooks(i,n),i.isAsync()&&(0,a.isPromise)(n)?(c(n),n=n.then((e=>(c(e),e))),n):(c(n),n);case s.REQUEST:return t&&(t.set(e,n),i.hooks&&i.hooks.$onDestroy&&t.hooks.on("$onDestroy",((...e)=>i.hooks.$onDestroy(n,...e)))),n}return n}async loadAsync(){for(const[,e]of this)!this.has(e.token)&&e.isAsync()&&await this.invoke(e.token)}loadSync(){for(const[,e]of this)this.has(e.token)||this.scopeOf(e)!==s.SINGLETON||this.invoke(e.token)}bootstrap(e=S()){return this.addProviders(e),this.resolveConfiguration(),this.resolveImportsProviders(),this}loadModule(e){this.settings.routes=this.settings.routes.concat(N(this.settings));const t=S();return t.delete(e),t.addProvider(e,{type:"server:module",scope:s.SINGLETON}),this.load(t)}async load(e=S()){this.bootstrap(e),await this.loadAsync(),this.loadSync(),await this.emit("$beforeInit"),await this.emit("$onInit")}resolveConfiguration(){if(this.resolvedConfiguration)return;const e=new Map;super.forEach((t=>{t.configuration&&"server:module"!==t.type&&Object.entries(t.configuration).forEach((([t,r])=>{["resolvers","mount","imports"].includes(t)||(r=e.has(t)?(0,a.deepMerge)(e.get(t),r):(0,a.deepClone)(r),e.set(t,r))})),t.resolvers&&(this.settings.resolvers=this.settings.resolvers.concat(t.resolvers))})),e.forEach(((e,t)=>{this.settings.set(t,(0,a.deepMerge)(e,this.settings.get(t)))})),this.resolvedConfiguration=!0}bindInjectableProperties(t,r,s){const o=(0,a.ancestorsOf)((0,a.classOf)(t)).reduce(((t,r)=>({...t,...a.Store.from(r).get(e)||{}})),{});Object.values(o).forEach((e=>{switch(e.bindingType){case P.PROPERTY:this.bindProperty(t,e,r,s);break;case P.CONSTANT:this.bindConstant(t,e);break;case P.VALUE:this.bindValue(t,e);break;case P.INTERCEPTOR:this.bindInterceptor(t,e)}}))}bindProperty(e,{propertyKey:t,resolver:r,options:s={}},o,n){let i;i=r(this,o,{...n,options:s}),(0,a.catchError)((()=>Object.defineProperty(e,t,{get:i})))}bindValue(e,{propertyKey:t,expression:r,defaultValue:s}){const o={get:()=>this.settings.get(r)||s,set:e=>this.settings.set(r,e),enumerable:!0,configurable:!0};(0,a.catchError)((()=>Object.defineProperty(e,t,o)))}bindConstant(e,{propertyKey:t,expression:r,defaultValue:s}){let o;const n={get:()=>{if(void 0!==o)return o;const e=this.settings.get(r,s);return o=Object.freeze((0,a.deepClone)(e)),o},enumerable:!0,configurable:!0};(0,a.catchError)((()=>Object.defineProperty(e,t,n)))}bindInterceptor(e,{propertyKey:t,useType:r,options:s}){const o=(0,a.classOf)(e),n=e[t];e[t]=(...i)=>{const a=t=>{if(!t)return n.apply(e,i);throw t},c={target:o,propertyKey:t,args:i,options:s,next:a};return this.get(r).intercept({...c,options:s},a)}}async lazyInvoke(e){let t=this.getInstance(e);return t||(t=await this.invoke(e),(0,a.isFunction)(t?.$onInit)&&await t.$onInit()),t}emit(e,...t){return this.#r.asyncEmit(e,t)}alter(e,t,...r){return this.#r.alter(e,t,r)}alterAsync(e,t,...r){return this.#r.asyncAlter(e,t,r)}async destroy(){await this.emit("$onDestroy"),L=void 0}ensureProvider(e,t=!1){return this.hasProvider(e)||!v.has(e)&&!t||this.addProvider(e),this.getProvider(e)}getInstance(e){return this.#t.get(e)}resolve(e,t=new c,s={}){const o=this.mapInvokeOptions(e,t,s);if(!o)return;const{token:n,deps:i,construct:u,imports:h,provider:l}=o;let p;l&&v.onInvoke(l,t,{...o,injector:this});let d=!1;try{const e=e=>(o,n)=>{if(d={token:o,index:n,deps:i},o!==r){const e=l?.store?.get(`${r}:${n}`);t.set(r,e||{})}return(0,a.isArray)(o)?this.getMany(o[0],t,s):(0,a.isInheritedFrom)(o,f,1)?l:this.invoke(o,t,{parent:e})};h.forEach(e());const o=i.map(e(n));d=!1,p=u(o)}catch(e){R.throwInjectorError(n,d,e)}if(void 0===p)throw new R(n,`Unable to create new instance from undefined value. Check your provider declaration for ${(0,a.nameOf)(n)}`);return p&&(0,a.isClass)((0,a.classOf)(p))&&this.bindInjectableProperties(p,t,s),p}resolveImportsProviders(){this.settings.imports=this.settings.imports?.filter((e=>e.token!==M)).map((e=>{if("token"in e){const{token:t,...r}=e,s=this.ensureProvider(t,!0);if(s){if(s.useValue=void 0,s.useAsyncFactory=void 0,s.useFactory=void 0,"useClass"in r)return void(s.useClass=r.useClass);if("useFactory"in r)return void(s.useFactory=r.useFactory);if("useAsyncFactory"in r)return void(s.useAsyncFactory=r.useAsyncFactory);if("use"in r)return void(s.useValue=r.use)}}return e})).filter(Boolean)}mapInvokeOptions(e,t,o){let n,i,c=o.imports,u=o.deps,l=o.scope;if(!e||e===Object)throw new I;if(this.hasProvider(e)?i=this.getProvider(e):(i=new f(e),this.resolvers.forEach((s=>{const o=s.get(e,t.get(r));void 0!==o&&(i.useFactory=()=>o)}))),l=l||this.scopeOf(i),u=u||i.deps,c=c||i.imports,void 0!==i.useValue)n=()=>(0,a.isFunction)(i.useValue)?i.useValue():i.useValue;else if(i.useFactory)n=e=>i.useFactory(...e);else if(i.useAsyncFactory)n=async e=>(e=await Promise.all(e),i.useAsyncFactory(...e));else{if(!i.useClass)return!1;u=u||h(i.useClass),n=e=>new i.useClass(...e)}return{token:e,scope:l||a.Store.from(e).get("scope")||s.SINGLETON,deps:u||[],imports:c||[],construct:n,provider:i}}registerHooks(e,t){e.hooks&&Object.entries(e.hooks).forEach((([r,s])=>{this.#r.on(r,((...r)=>s(this.get(e.token)||t,...r)))}))}};function _(){return e=>class extends e{constructor(...t){const r=new c;super(...x.resolveAutoInjectableArgs(e,r,t)),x.bind(this,r)}}}function V(t,r){return(s,o)=>{a.Store.from(s).merge(e,{[o]:{bindingType:P.CONSTANT,propertyKey:o,expression:t,defaultValue:r}})}}x=M=function(e,t,r,s){var o,n=arguments.length,i=n<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,r):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,r,s);else for(var a=e.length-1;a>=0;a--)(o=e[a])&&(i=(n<3?o(i):n>3?o(t,r,i):o(t,r))||i);return n>3&&i&&Object.defineProperty(t,r,i),i}([E({scope:s.SINGLETON}),function(e,t){if("object"==typeof Reflect&&"function"==typeof Reflect.metadata)return Reflect.metadata(e,t)}("design:paramtypes",[])],x);var F=o(953);function $(e){const{children:t=[],path:r,...s}=function(e){return"string"==typeof e||e instanceof RegExp||(0,a.isArrayOrArrayClass)(e)?{path:e}:e}(e);return(0,a.useDecorators)((e=>{b({provide:e,...s})}),r&&(0,F.Path)(r),(0,F.Children)(...t))}function U(t,r){return(...s)=>{const[o,n,i]=s;switch((0,a.decoratorTypeOf)(s)){case a.DecoratorTypes.CLASS:(0,a.decorateMethodsOf)(o,U(t,r));break;case a.DecoratorTypes.METHOD:return a.Store.from(o).merge(e,{[n]:{options:r,propertyKey:n,useType:t,bindingType:P.INTERCEPTOR}}),i}}}function G(){return E({type:i.INTERCEPTOR})}function K(e,t,{optional:r=!1,packageName:s=t.toString()}={}){return(o,n)=>{let i,c;p(o,n,{resolver:o=>async()=>{if(!c){const n=await(0,a.importPackage)(s,t,r);if(c=n[e],!c&&!r)throw new Error(`Unable to lazy load the "${e}". The token isn't a valid token provider.`);i=c?await o.lazyInvoke(c):{}}return i}})}}function H(e,t){return K(e,t,{optional:!0})}function q(e={}){const{scopes:t,imports:r,resolvers:o,deps:n,scope:c,...u}=e;return(0,a.useDecorators)(g(u),E({type:i.MODULE,scope:s.SINGLETON,imports:r,deps:n,injectable:!1,resolvers:o}))}function z(e=s.REQUEST){return(0,a.StoreSet)("scope",e)}function B(e,t,o){z(s.INSTANCE)((0,a.classOf)(e)),d(r)(e,t,o)}function J(e){return t=>{v.get(e).useClass=t}}function Q(){return E()}function Y(t){return(s,o,n)=>{switch((0,a.decoratorTypeOf)([s,o,n])){case a.DecoratorTypes.PARAM_CTOR:a.Store.from(s).merge(`${r}:${n}`,t);break;case a.DecoratorTypes.PROP:a.Store.from(s).merge(e,{[o]:{options:t}});break;default:throw new a.UnsupportedDecoratorType(Y,[s,o,n])}}}function W(t,r){return(s,o)=>{a.Store.from(s).merge(e,{[o]:{bindingType:P.VALUE,propertyKey:o,expression:t,defaultValue:r}})}}class X extends f{tokenRouter;constructor(e,t={}){super(e,t),this.type=i.CONTROLLER}get middlewares(){return Object.assign({use:[],useAfter:[],useBefore:[]},this.store.get("middlewares",{}))}set middlewares(e){const t=this.middlewares;Object.keys(e).forEach((r=>{((e,t,r)=>{t[e]=t[e].concat(r[e])})(r,t,e)})),this.store.set("middlewares",t)}}const Z=Symbol.for("LOGGER");function ee(e={},t={}){return Object.entries(t).reduce(((e,[t,r])=>({...e,[t]:(e[t]||[]).concat(r)})),e)}function te(e,t={}){const r=a.Store.from(e).get("configuration")||{};return{...r,...t,mount:ee(r.mount,t.mount)}}m({provide:Z,deps:[x],useFactory:e=>e.logger})})(),n})())); | ||
//# sourceMappingURL=di.umd.min.js.map |
@@ -8,2 +8,3 @@ "use strict"; | ||
tslib_1.__exportStar(require("./constants/constants.js"), exports); | ||
tslib_1.__exportStar(require("./decorators/autoInjectable.js"), exports); | ||
tslib_1.__exportStar(require("./decorators/configuration.js"), exports); | ||
@@ -10,0 +11,0 @@ tslib_1.__exportStar(require("./decorators/constant.js"), exports); |
@@ -22,2 +22,3 @@ "use strict"; | ||
const DIConfiguration_js_1 = require("./DIConfiguration.js"); | ||
let globalInjector; | ||
/** | ||
@@ -53,2 +54,3 @@ * This service contain all services collected by `@Service` or services declared manually with `InjectorService.factory()` or `InjectorService.service()`. | ||
this.#cache.set(InjectorService_1, this); | ||
globalInjector = this; | ||
} | ||
@@ -61,2 +63,26 @@ get resolvers() { | ||
} | ||
static resolveAutoInjectableArgs(token, locals, args) { | ||
if (!globalInjector) { | ||
throw new Error("InjectorService instance is not created yet."); | ||
} | ||
const deps = (0, getConstructorDependencies_js_1.getConstructorDependencies)(token); | ||
const list = []; | ||
const length = Math.max(deps.length, args.length); | ||
for (let i = 0; i < length; i++) { | ||
if (args[i] !== undefined) { | ||
list.push(args); | ||
} | ||
else { | ||
const value = deps[i]; | ||
const instance = (0, core_1.isArray)(value) | ||
? globalInjector.getMany(value[0], locals, { parent: token }) | ||
: globalInjector.invoke(value, locals, { parent: token }); | ||
list.push(instance); | ||
} | ||
} | ||
return list; | ||
} | ||
static bind(instance, locals) { | ||
globalInjector.bindInjectableProperties(instance, locals, {}); | ||
} | ||
/** | ||
@@ -149,3 +175,3 @@ * Retrieve default scope for a given provider. | ||
* @param options | ||
* @returns {T} The class constructed. | ||
* @returns {Type} The class constructed. | ||
*/ | ||
@@ -445,4 +471,5 @@ invoke(token, locals, options = {}) { | ||
} | ||
destroy() { | ||
return this.emit("$onDestroy"); | ||
async destroy() { | ||
await this.emit("$onDestroy"); | ||
globalInjector = undefined; | ||
} | ||
@@ -619,4 +646,3 @@ ensureProvider(token, force = false) { | ||
(0, injectable_js_1.Injectable)({ | ||
scope: ProviderScope_js_1.ProviderScope.SINGLETON, | ||
global: true | ||
scope: ProviderScope_js_1.ProviderScope.SINGLETON | ||
}), | ||
@@ -623,0 +649,0 @@ tslib_1.__metadata("design:paramtypes", []) |
@@ -5,2 +5,3 @@ /** | ||
export * from "./constants/constants.js"; | ||
export * from "./decorators/autoInjectable.js"; | ||
export * from "./decorators/configuration.js"; | ||
@@ -7,0 +8,0 @@ export * from "./decorators/constant.js"; |
@@ -19,2 +19,3 @@ var InjectorService_1; | ||
import { DIConfiguration } from "./DIConfiguration.js"; | ||
let globalInjector; | ||
/** | ||
@@ -50,2 +51,3 @@ * This service contain all services collected by `@Service` or services declared manually with `InjectorService.factory()` or `InjectorService.service()`. | ||
this.#cache.set(InjectorService_1, this); | ||
globalInjector = this; | ||
} | ||
@@ -58,2 +60,26 @@ get resolvers() { | ||
} | ||
static resolveAutoInjectableArgs(token, locals, args) { | ||
if (!globalInjector) { | ||
throw new Error("InjectorService instance is not created yet."); | ||
} | ||
const deps = getConstructorDependencies(token); | ||
const list = []; | ||
const length = Math.max(deps.length, args.length); | ||
for (let i = 0; i < length; i++) { | ||
if (args[i] !== undefined) { | ||
list.push(args); | ||
} | ||
else { | ||
const value = deps[i]; | ||
const instance = isArray(value) | ||
? globalInjector.getMany(value[0], locals, { parent: token }) | ||
: globalInjector.invoke(value, locals, { parent: token }); | ||
list.push(instance); | ||
} | ||
} | ||
return list; | ||
} | ||
static bind(instance, locals) { | ||
globalInjector.bindInjectableProperties(instance, locals, {}); | ||
} | ||
/** | ||
@@ -146,3 +172,3 @@ * Retrieve default scope for a given provider. | ||
* @param options | ||
* @returns {T} The class constructed. | ||
* @returns {Type} The class constructed. | ||
*/ | ||
@@ -442,4 +468,5 @@ invoke(token, locals, options = {}) { | ||
} | ||
destroy() { | ||
return this.emit("$onDestroy"); | ||
async destroy() { | ||
await this.emit("$onDestroy"); | ||
globalInjector = undefined; | ||
} | ||
@@ -616,4 +643,3 @@ ensureProvider(token, force = false) { | ||
Injectable({ | ||
scope: ProviderScope.SINGLETON, | ||
global: true | ||
scope: ProviderScope.SINGLETON | ||
}), | ||
@@ -620,0 +646,0 @@ __metadata("design:paramtypes", []) |
@@ -5,2 +5,3 @@ /** | ||
export * from "./constants/constants.js"; | ||
export * from "./decorators/autoInjectable.js"; | ||
export * from "./decorators/configuration.js"; | ||
@@ -7,0 +8,0 @@ export * from "./decorators/constant.js"; |
import { ProviderScope } from "../domain/ProviderScope.js"; | ||
import { TokenProvider } from "./TokenProvider.js"; | ||
export interface InvokeOptions<T = any> { | ||
deps: any[]; | ||
imports: any[]; | ||
export interface InvokeOptions { | ||
/** | ||
* Define dependencies to build the provider and inject them in the constructor. | ||
*/ | ||
deps: unknown[]; | ||
/** | ||
* List of imports to be created before the provider. Imports list aren't injected directly in the provider constructor. | ||
*/ | ||
imports: unknown[]; | ||
/** | ||
* Parent provider. | ||
*/ | ||
parent?: TokenProvider; | ||
/** | ||
* Scope used by the injector to build the provider. | ||
*/ | ||
scope: ProviderScope; | ||
useScope: boolean; | ||
/** | ||
* If true, the injector will rebuild the instance. | ||
*/ | ||
rebuild?: boolean; | ||
} |
@@ -0,1 +1,2 @@ | ||
import { type Type } from "@tsed/core"; | ||
import { Container } from "../domain/Container.js"; | ||
@@ -39,2 +40,4 @@ import { LocalsContainer } from "../domain/LocalsContainer.js"; | ||
get scopes(): Record<string, ProviderScope>; | ||
static resolveAutoInjectableArgs(token: Type, locals: LocalsContainer, args: unknown[]): any[]; | ||
static bind(instance: any, locals: LocalsContainer): void; | ||
/** | ||
@@ -76,3 +79,3 @@ * Retrieve default scope for a given provider. | ||
*/ | ||
getMany<Type = any>(type: any, locals?: LocalsContainer, options?: Partial<InvokeOptions<Type>>): Type[]; | ||
getMany<Type = any>(type: any, locals?: LocalsContainer, options?: Partial<InvokeOptions>): Type[]; | ||
/** | ||
@@ -104,5 +107,5 @@ * The has() method returns a boolean indicating whether an element with the specified key exists or not. | ||
* @param options | ||
* @returns {T} The class constructed. | ||
* @returns {Type} The class constructed. | ||
*/ | ||
invoke<T = any>(token: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions<T>>): T; | ||
invoke<Type = any>(token: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions>): Type; | ||
/** | ||
@@ -217,3 +220,3 @@ * Build only providers which are asynchronous. | ||
*/ | ||
protected resolve<T>(target: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions<T>>): T | Promise<T>; | ||
protected resolve<T>(target: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions>): T | Promise<T>; | ||
private resolveImportsProviders; | ||
@@ -220,0 +223,0 @@ /** |
@@ -5,2 +5,3 @@ /** | ||
export * from "./constants/constants.js"; | ||
export * from "./decorators/autoInjectable.js"; | ||
export * from "./decorators/configuration.js"; | ||
@@ -7,0 +8,0 @@ export * from "./decorators/constant.js"; |
import { ProviderScope } from "../domain/ProviderScope.js"; | ||
import { TokenProvider } from "./TokenProvider.js"; | ||
export interface InvokeOptions<T = any> { | ||
deps: any[]; | ||
imports: any[]; | ||
export interface InvokeOptions { | ||
/** | ||
* Define dependencies to build the provider and inject them in the constructor. | ||
*/ | ||
deps: unknown[]; | ||
/** | ||
* List of imports to be created before the provider. Imports list aren't injected directly in the provider constructor. | ||
*/ | ||
imports: unknown[]; | ||
/** | ||
* Parent provider. | ||
*/ | ||
parent?: TokenProvider; | ||
/** | ||
* Scope used by the injector to build the provider. | ||
*/ | ||
scope: ProviderScope; | ||
useScope: boolean; | ||
/** | ||
* If true, the injector will rebuild the instance. | ||
*/ | ||
rebuild?: boolean; | ||
} |
@@ -0,1 +1,2 @@ | ||
import { type Type } from "@tsed/core"; | ||
import { Container } from "../domain/Container.js"; | ||
@@ -39,2 +40,4 @@ import { LocalsContainer } from "../domain/LocalsContainer.js"; | ||
get scopes(): Record<string, ProviderScope>; | ||
static resolveAutoInjectableArgs(token: Type, locals: LocalsContainer, args: unknown[]): any[]; | ||
static bind(instance: any, locals: LocalsContainer): void; | ||
/** | ||
@@ -76,3 +79,3 @@ * Retrieve default scope for a given provider. | ||
*/ | ||
getMany<Type = any>(type: any, locals?: LocalsContainer, options?: Partial<InvokeOptions<Type>>): Type[]; | ||
getMany<Type = any>(type: any, locals?: LocalsContainer, options?: Partial<InvokeOptions>): Type[]; | ||
/** | ||
@@ -104,5 +107,5 @@ * The has() method returns a boolean indicating whether an element with the specified key exists or not. | ||
* @param options | ||
* @returns {T} The class constructed. | ||
* @returns {Type} The class constructed. | ||
*/ | ||
invoke<T = any>(token: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions<T>>): T; | ||
invoke<Type = any>(token: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions>): Type; | ||
/** | ||
@@ -217,3 +220,3 @@ * Build only providers which are asynchronous. | ||
*/ | ||
protected resolve<T>(target: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions<T>>): T | Promise<T>; | ||
protected resolve<T>(target: TokenProvider, locals?: LocalsContainer, options?: Partial<InvokeOptions>): T | Promise<T>; | ||
private resolveImportsProviders; | ||
@@ -220,0 +223,0 @@ /** |
@@ -5,3 +5,3 @@ { | ||
"type": "commonjs", | ||
"version": "7.81.2", | ||
"version": "7.82.0", | ||
"source": "./src/index.ts", | ||
@@ -33,7 +33,7 @@ "main": "lib/esm/index.js", | ||
"devDependencies": { | ||
"@tsed/barrels": "7.81.2", | ||
"@tsed/core": "7.81.2", | ||
"@tsed/barrels": "7.82.0", | ||
"@tsed/core": "7.82.0", | ||
"@tsed/logger": ">=6.7.5", | ||
"@tsed/schema": "7.81.2", | ||
"@tsed/typescript": "7.81.2", | ||
"@tsed/schema": "7.82.0", | ||
"@tsed/typescript": "7.82.0", | ||
"cross-env": "7.0.3", | ||
@@ -46,5 +46,5 @@ "eslint": "^8.57.0", | ||
"peerDependencies": { | ||
"@tsed/core": "7.81.2", | ||
"@tsed/core": "7.82.0", | ||
"@tsed/logger": ">=6.7.5", | ||
"@tsed/schema": "7.81.2" | ||
"@tsed/schema": "7.82.0" | ||
}, | ||
@@ -51,0 +51,0 @@ "peerDependenciesMeta": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
562665
411
8329