@decaf-ts/core 0.14.4 → 0.14.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/core.js CHANGED
@@ -1,2 +1,2 @@
1
- import{InjectableRegistryImp as t,Injectables as e,inject as r,injectable as s}from"@decaf-ts/injectable-decorators";import{__decorate as i,__metadata as n}from"tslib";import{DefaultRepositoryFlags as o,OperationKeys as a,BulkCrudOperationKeys as c,Context as l,InternalError as u,ValidationError as d,Repository as h,wrapMethodWithContext as p,wrapMethodWithContextForUpdate as g,enforceDBDecorators as f,reduceErrorsToPrint as y,NotFoundError as m,DefaultSeparator as w,DBKeys as v,readonly as b,onCreate as A,generated as x,onUpdate as E,BadRequestError as O,timestamp as k,onCreateUpdate as C,ConflictError as T,version as N,afterAny as D,onDelete as _,SerializationError as I,prefixMethod as B,composed as P,transient as R,serialize as $,BaseError as F}from"@decaf-ts/db-decorators";import{Logging as L,LoggedClass as M,final as j,toCamelCase as U,LogLevel as G,style as Y}from"@decaf-ts/logging";import{Model as z,hashObj as q,required as H,sf as V,isEqual as Q,model as W,ValidationKeys as J,type as X,async as Z,list as tt,option as et,date as rt,JSONSerializer as st,ModelKeys as it,min as nt,minlength as ot,gt as at}from"@decaf-ts/decorator-validation";import{Lock as ct,MultiLock as lt,TransactionalKeys as ut}from"@decaf-ts/transactional-decorators";import{Metadata as dt,Decoration as ht,DefaultFlavour as pt,apply as gt,methodMetadata as ft,propMetadata as yt,DecorationKeys as mt,uses as wt,metadata as vt,prop as bt,method as At,description as St}from"@decaf-ts/decoration";var xt,Et,Ot,kt,Ct;(t=>{t.FIND_BY="findBy",t.PAGE_BY="pageBy",t.COUNT_BY="countBy",t.SUM_BY="sumBy",t.AVG_BY="avgBy",t.MIN_BY="minBy",t.MAX_BY="maxBy",t.DISTINCT_BY="distinctBy",t.GROUP_BY_PREFIX="groupBy",t.SELECT="Select",t.AND="And",t.OR="Or",t.GROUP_BY="GroupBy",t.ORDER_BY="OrderBy",t.THEN="Then",t.THEN_BY="ThenBy"})(xt||(xt={})),(t=>{t.EQUAL="EQUAL",t.DIFFERENT="DIFFERENT",t.BIGGER="BIGGER",t.BIGGER_EQ="BIGGER_EQ",t.SMALLER="SMALLER",t.SMALLER_EQ="SMALLER_EQ",t.BETWEEN="BETWEEN",t.NOT="NOT",t.IN="IN",t.REGEXP="REGEXP",t.STARTS_WITH="STARTS_WITH",t.ENDS_WITH="ENDS_WITH",t.GROUP_BY="group-by",t.COUNT="count",t.SUM="sum",t.MAX="v_max",t.MIN="v_min",t.DISTINCT="distinct",t.VIEW="view"})(Et||(Et={})),(t=>{t.AND="AND",t.OR="OR"})(Ot||(Ot={})),(t=>{t.LIST_BY="listBy",t.FIND_BY="findBy",t.FIND_BY_PAGINATE="findByPaginate",t.FIND_ONE_BY="findOneBy",t.PAGE_BY="paginateBy",t.FIND="find",t.PAGE="page",t.COUNT_OF="countOf",t.MAX_OF="maxOf",t.MIN_OF="minOf",t.AVG_OF="avgOf",t.SUM_OF="sumOf",t.DISTINCT_OF="distinctOf",t.GROUP_OF="groupOf"})(kt||(kt={})),(t=>{t.PERSISTENCE="persistence",t.INDEX="index",t.SEQUENCE="sequence",t.UNIQUE="unique",t.ADAPTER="adapter",t.INJECTABLE="decaf_{0}_adapter_for_{1}",t.SERVICE="service",t.TABLE="table",t.COLUMN="column",t.METADATA="__metadata",t.OWNERSHIP="ownership",t.CREATED_BY="ownership.created-by",t.UPDATED_BY="ownership.updated-by",t.RELATIONS="__relations",t.RELATION="relation",t.ONE_TO_ONE="relation.one-to-one",t.ONE_TO_MANY="relation.one-to-many",t.MANY_TO_ONE="relation.many-to-one",t.MANY_TO_MANY="relation.many-to-many",t.POPULATE="populate",t.NO_VALIDATE="no-validate",t.MIGRATION="migration",t.STATEMENT="statement",t.QUERY="query",t.UUID="uuid",t.TAG_FOR_DELETION="tag_for_deletion",t.INITIALIZATION="initialization",t.SHUTDOWN="shutdown",t.BY_KEY="by-key",t.AUTH="auth",t.AUTH_ROLE="auth-role",t.DECAF_ROUTE="DecafRoute",t.THROTTLE="throttle",t.PERSISTENT_VERSION="persistent-version",t.DEFAULT_QUERY_ATTR="default-query-attr"})(Ct||(Ct={}));const Tt=Object.assign({},{ignoreDevSafeGuards:!1}),Nt=Object.assign({},o,{enforceUpdateValidation:!0,allowRawStatements:!0,forcePrepareSimpleQueries:!1,forcePrepareComplexQueries:!1,cacheForPopulate:{},preferFromCache:!1,noEmit:!1,noEmitSingle:!1,noEmitBulk:!1,breakOnSingleFailureInBulk:!0,observeFullResult:!0,paginateByBookmark:!1,dryRun:!1,afterQueryHandlers:!1}),Dt=[a.CREATE,a.UPDATE,a.DELETE,c.CREATE_ALL,c.UPDATE_ALL,c.DELETE_ALL],_t=[a.READ,c.READ_ALL],It=[Ct.STATEMENT,kt.FIND_ONE_BY],Bt=[Ct.QUERY,kt.PAGE_BY,kt.FIND_BY_PAGINATE,kt.LIST_BY,kt.FIND_BY,kt.FIND,kt.PAGE],Pt=[kt.PAGE_BY,kt.FIND_BY_PAGINATE,kt.PAGE];class Rt extends l{constructor(t){super(t)}static{this.factory=t=>(new Rt).accumulate(Object.assign({},t,{timestamp:new Date,logger:t.logger||L.get()}))}static async from(t,e,r,...s){return this.factory(Object.assign({},e||{},{operation:t,model:r,affectedTables:r,args:s,logger:e?.logger||L.get()}))}pushPending(t,e){const r=this.pending()||{};if(r[t]=r[t]||[],r[t].includes(e))throw new u(`Trying to push a repeated pending ${t} task: ${e}`);r[t].push(e),this.accumulate({pending:r})}getFromChildren(t,e=new Set){if(e.has(this))return;e.add(this);const r=this.getOrUndefined(t);if(null!=r)return r;let s=this.getOrUndefined("childContexts");if(s&&s.length&&(s=s.filter(t=>!e.has(t)),s.length)){const r=s.map(r=>r.getFromChildren(t,e)).reduce((t,e)=>(Array.isArray(e)?t.push(...e):null!=e&&t.push(e),t),[]).filter(t=>null!=t);if(!r.length)return;return r.some(t=>"object"!=typeof t)?r[0]:r.reduce((t,e)=>Object.assign(t,e),{})}}pending(){return this.getFromChildren("pending")}getOrUndefined(t){try{return this.get(t)}catch(t){return}}override(t){return new Proxy(this,{get:(e,r,s)=>"get"===r?new Proxy(e.get,{apply:(e,r,i)=>{const n=i[0];if(!n)throw new u("Invalid property access to overridden context: "+n);return n in t?t[n]:Reflect.apply(e,s,i)}}):Reflect.get(e,r,s)})}toOverrides(){return this.cache.keys().reduce((t,e)=>(t[e]=this.get(e),t),{})}accumulate(t){return super.accumulate(t)}}class $t extends M{logCtx(t,e,r=!1,s){return $t.logCtx.call(this,e,s||{},r,...t.filter(t=>void 0!==t))}static logFrom(t,e,r,s){const i=t.context?e.clear().for(t):e.for(t);return s?i.for(s):i}static logCtx(t,e,r=!1,...s){const i=(t,e,r)=>{const s=e.log||L.get();return e.log=t.context?s.clear().for(t):s.for(t),"string"==typeof r?e.for=t=>Object.assign(e,{log:e.log.for(t)}):e.log=e.log.for(r),e};let n=s.pop();const o=n instanceof Rt||(t=>{if(!t||"object"!=typeof t)return!1;const e=t;return"function"==typeof e.get&&"function"==typeof e.accumulate&&"function"==typeof e.override&&"function"==typeof e.toOverrides&&void 0!==e.cache})(n);if(n&&!o&&(s.push(n),n=void 0),!r&&!o)throw new u("No context provided");if(o&&!r){if(!n)throw new u("Missing context. should be impossible");return i(this,{log:n.logger,ctx:n,ctxArgs:[...s,n]},t)}return async function(...r){if(!this)throw new u("No contextual provided");if(!this.context)throw new u("Invalid contextual provided");return this.context("string"==typeof t?t:t.name,e||{},...r)}.call(this,...[...s,n].filter(Boolean)).then(e=>i(this,{log:e.logger,ctx:e,ctxArgs:[...s,e]},t))}}class Ft extends $t{constructor(){super(),this._Context=Rt}get Context(){return this._Context}async context(t,e,...r){this.log.for(this.context).debug(`Creating new context for ${"string"==typeof t?t:t.name} operation with flag overrides: ${Object.keys(e)}`);let s=r.pop();return s instanceof Rt||(r.push(s),s=void 0),this.flags,!s||s instanceof this.Context?(new this.Context).accumulate(e):new this.Context(s).accumulate(e)}}class Lt{constructor(){this.observers=[]}count(){return this.observers.length}observe(t,e){if(-1!==this.observers.map(t=>t.observer).indexOf(t))throw new u("Observer already registered");return this.observers.push({observer:t,filter:e}),()=>this.unObserve(t)}unObserve(t){const e=this.observers.map(t=>t.observer).indexOf(t);if(-1===e)throw new u("Failed to find Observer");this.observers.splice(e,1)}async updateObservers(t,e,r,...s){const{log:i,ctxArgs:n}=$t.logCtx(this.updateObservers,void 0,!1,...s);(await Promise.allSettled(this.observers.filter(s=>{const{filter:o}=s;if(!o)return!0;try{return o(t,e,r,...n)}catch(t){return i.error(`Failed to filter observer ${s.observer.toString()}: ${t}`),!1}}).map(s=>{s.observer.refresh(t,e,r,...n)}))).forEach((t,e)=>{"rejected"===t.status&&i.error(`Failed to update observable ${this.observers[e].toString()}: ${t.reason}`)})}}class Mt extends u{constructor(t){super(t,Mt.name,500)}}class jt extends u{constructor(t,e=jt.name){super(t,e,500)}}class Ut extends jt{constructor(t){super(t,Ut.name)}}function Gt(t){if(!t)throw new u("No name provided");return"string"==typeof t?t.replaceAll(".","-"):dt.Symbol(dt.constr(t)).toString().replaceAll(".","-")}async function Yt(t,e=!1){if(!e){const e=[];for(const r of t)e.push(await r());return e}const r=[];for(const e of t)try{r.push({status:"fulfilled",value:await e()})}catch(t){r.push({status:"rejected",reason:t})}return r}const zt=[a.CREATE,a.READ,a.UPDATE,a.DELETE];function qt(t){return zt.includes(t)}function Ht(t,e,r){const s=dt.get(t,a.REFLECT+a.BLOCK)||{};if(!s?.handler)return!1;const i=void 0===r&&qt(e)?"crud":e,n=void 0===r&&qt(e)?e:r,o=s.args?.[0]||[];return s.handler(o,i,n)??!1}async function Vt(t){return t.then(t=>t.default||t)}function Qt(t,e,r,s){const i=async function(...t){let s;try{s=await Promise.resolve(r.call(this,...t))}catch(t){if(t instanceof Ut)return;throw t}return Promise.resolve(e.apply(this,s))}.bind(t),n=s||e.name;Object.defineProperty(i,"name",{enumerable:!0,configurable:!0,writable:!1,value:n}),t[n]=i}class Wt{generate(t){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{const e=16*Math.random()|0;return("x"==t?e:3&e|8).toString(16)})}static get instance(){return Wt._instance||(Wt._instance=new Wt),Wt._instance}}class Jt{constructor(){this.count=14}generate(t){return(""+((t=(t?parseInt(t):0)||0)+1)).padStart(this.count,"0")}static get instance(){return Jt._instance||(Jt._instance=new Jt),Jt._instance}}class Xt{constructor(t,...e){this.adapter=t}async begin(...t){}async commit(...t){}async rollback(...t){}}class Kt extends ct{constructor(t){super(),this.adapterTransaction=t,this.acquireCount=0,this.lock=new ct}async acquire(...t){await this.lock.acquire(),this.acquireCount++,1===this.acquireCount?(this.lock.release(),await this.adapterTransaction.begin(...t)):this.lock.release()}async release(...t){if(await this.lock.acquire(),this.acquireCount--,0===this.acquireCount)try{await this.adapterTransaction.commit(...t)}catch(e){await this.adapterTransaction.rollback(new u("Failed to submit transaction: "+e),...t)}finally{this.lock.release()}else 0>this.acquireCount?(this.acquireCount=0,this.lock.release()):this.lock.release()}async rollback(t,...e){await this.lock.acquire();try{await this.adapterTransaction.rollback(new u("Failed to submit transaction: "+t),...e)}catch(t){throw new u("Failed to rollback transaction: "+t)}finally{this.lock.release()}}}const Zt=ht.flavourResolver.bind(ht);ht.flavourResolver=t=>{const e=t=>{if(!t)return;const e=re._cache?.[t];return e?.flavour||t};try{const r=Zt(t);if(r&&r!==pt)return e(r);const s="function"==typeof t?t:t?.constructor,i=s&&"function"==typeof dt.registeredFlavour?dt.registeredFlavour(s):void 0;if(i&&i!==pt)return e(i);const n=re._currentFlavour;if(n){const t=re._cache?.[n];return t?.flavour?t.flavour:e(n)}}catch(t){return pt}};const te=Symbol("AdapterProxyCleanup");function ee(t,e,r,s){if(!e)return t;const i=t,n=[],o=[];for(const t of i)"fulfilled"===t.status?n.push(t.value):o.push(t.reason);if(o.length){r.warn(`Bulk ${s} encountered ${o.length} failure(s) while continuing`);const t=new AggregateError(o,`Bulk ${s} failed for ${o.length} item(s)`);throw t.results=i,t}return n}class re extends Ft{static{this._cache={}}get config(){return this._config}get alias(){return this._alias||this.flavour}repository(){if(!re._baseRepository)throw new u("This should be overridden when necessary. Otherwise it will be replaced lazily");return re._baseRepository}transactionLock(...t){return new Xt(this,...t)}async shutdownProxies(t,...e){t&&"string"!=typeof t&&(e=[t,...e],t=void 0);const{log:r}=this.logCtx(e,this.shutdownProxies);if(!this.proxies)return;if(t&&!(t in this.proxies))throw new u("No proxy found for "+t);const s=async t=>{if(!t)return;const e=t[te];"function"==typeof e&&await e()};if(t)try{await s(this.proxies[t]),delete this.proxies[t]}catch(e){r.error("Failed to cleanup proxied adapter "+t,e)}else for(const t in this.proxies){try{await s(this.proxies[t])}catch(e){r.error("Failed to cleanup proxied adapter "+t,e);continue}delete this.proxies[t]}}async shutdown(...t){const{log:e,ctxArgs:r}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.shutdown);await this.internalLock.acquire(Ct.SHUTDOWN);try{if(this.shutdownPromise)return this.shutdownPromise;this.shutdownPromise=(async()=>{const{log:e}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.shutdown);await this.shutdownProxies(...r),this.dispatch&&await this.dispatch.close(...r)})()}catch(t){throw new u("Failed to create shutdown wrapper: "+t)}finally{this.internalLock.release(Ct.SHUTDOWN)}try{await this.shutdownPromise}catch(t){e.error("Error during proxy shutdown",t)}finally{this.shutdownPromise=void 0}}constructor(t,e,r){if(super(),this._config=t,this.flavour=e,this._alias=r,this.internalLock=new ct,this.alias in re._cache)throw new u(`${this.alias} persistence adapter ${this._alias?`(${this.flavour}) `:""} already registered`);re._cache[this.alias]=this,this.alias!==this.flavour&&(this.flavour in re._cache||(re._cache[this.flavour]=this)),this.log.info(`Created ${this.alias} persistence adapter ${this._alias?`(${this.flavour}) `:""} persistence adapter`),re._currentFlavour||(this.log.verbose(`Defined ${this.alias} persistence adapter as current`),re._currentFlavour=this.alias)}Dispatch(){return new re._baseDispatch}ObserverHandler(){return new Lt}isReserved(t){return!t}async initialize(...t){}async Sequence(t,e){return new re._baseSequence(t,this,e)}async flags(t,e,r,...s){if("string"==typeof e)throw new u("Model must be a constructor or array of constructors or undefined. this should be impossible");const i=Array.isArray(e)?e.length?e[0]:void 0:e,n=i?""+z.tableName(i):"";r.correlationId=r.correlationId||`${n}|${t}|${Wt.instance.generate()}`;const o=r.logger||L.for(this),a=Object.assign({},Nt.cacheForPopulate,r.cacheForPopulate);return Object.assign({},Nt,r,{affectedTables:e?[...new Set([...(Array.isArray(e)?e:[e]).filter(Boolean),...r.affectedTables?Array.isArray(r.affectedTables)?r.affectedTables:[r.affectedTables]:[]])]:r.affectedTables,cacheForPopulate:a,args:s,writeOperation:Dt.includes(t),timestamp:new Date,operation:t,ignoredValidationProperties:e?dt.validationExceptions(Array.isArray(e)&&e[0]?e[0]:e,t):[],logger:o})}get Context(){return Rt}async context(t,e,r,...s){this.log.for(this.context).silly(`creating new context for ${t} operation on ${r?Array.isArray(r)?r.map(t=>z.tableName(t)):z.tableName(r):"no"} table ${e&&Object.keys(e)?Object.keys(e).length:"no"} with flag overrides`);let i=s.pop();void 0===i||i instanceof Rt||(s.push(i),i=void 0);const n=(()=>{if(!i)return!1;try{return!!i.get("allowGenerationOverride")}catch{return!1}})();e=i?Object.assign({},i.toOverrides(),e):e,n&&(e.allowGenerationOverride=!0);const o=await this.flags("string"==typeof t?t:t.name,r,e,...[...s,i].filter(Boolean));if(i){if(!(i instanceof this.Context)){const t=(new this.Context).accumulate({...i.cache,...o,parentContext:i});return i.accumulate({childContexts:[...i.getOrUndefined("childContexts")||[],t]}),t}const e=i.getOrUndefined("operation"),s=i.getOrUndefined("affectedTables");if(!e||e!==t||r&&r!==s){const t=(new this.Context).accumulate({...i.cache,...o,parentContext:i});return i.accumulate({childContexts:[...i.getOrUndefined("childContexts")||[],t]}),t}return i.accumulate(o)}return(new this.Context).accumulate({...o})}prepare(t,...e){const{log:r}=this.logCtx(e,this.prepare),s=t.segregate(),i=Object.entries(s.model).reduce((e,[r,s])=>{if(void 0===s)return e;const i=z.columnName(t.constructor,r);if(this.isReserved(i))throw new u(`Property name ${i} is reserved`);return e[i]=s,e},{});return t[Ct.METADATA]&&(r.silly("Passing along persistence metadata for "+t[Ct.METADATA]),Object.defineProperty(i,Ct.METADATA,{enumerable:!1,writable:!0,configurable:!0,value:t[Ct.METADATA]})),{record:i,id:t[z.pk(t.constructor)],transient:s.transient}}revert(t,e,r,s,...i){const{log:n,ctx:o}=this.logCtx(i,this.revert),a=z.pk(e),c=new e;c[a]=r,n.silly(`Rebuilding model ${c.constructor.name} id ${r}`);const l=t[Ct.METADATA],d=Object.keys(c).filter(t=>t!==a).reduce((r,s)=>(r[s]=t[z.columnName(e,s)],r),c);return o.get("rebuildWithTransient")&&s&&(n.verbose("re-adding transient properties: "+Object.keys(s).join(", ")),Object.entries(s).forEach(([t,e])=>{if(t in d&&void 0!==d[t])throw new u(`Transient property ${t} already exists on model ${c.constructor.name}. should be impossible`);d[t]=e})),l&&(n.silly(`Passing along ${this.flavour} persistence metadata for ${c.constructor.name} id ${r}: ${l}`),Object.defineProperty(d,Ct.METADATA,{enumerable:!1,configurable:!0,writable:!0,value:l})),d}async createAll(t,e,r,...s){const{log:i,ctx:n}=this.logCtx(s,this.createAll);if(!e||!r)throw new d("Ids and models cannot be null or undefined");if(e.length!==r.length)throw new d("Ids and models must have the same length");const o=z.tableName(t);i.debug(`Creating ${e.length} entries ${o} table`);const a=!(n.get("breakOnSingleFailureInBulk")??1),l=e.map((e,i)=>()=>this.create(t,e,r[i],...s,n.override({noEmitSingle:!0})));return ee(a?await Yt(l,!0):await Yt(l),a,i,c.CREATE_ALL)}async readAll(t,e,...r){const{log:s,ctx:i}=this.logCtx(r,this.readAll),n=z.tableName(t);s.debug(`Reading ${e.length} entries ${n} table`);const o=!(i.get("breakOnSingleFailureInBulk")??1),a=e.map(e=>()=>this.read(t,e,...r,i.override({noEmitSingle:!0})));return ee(o?await Yt(a,!0):await Yt(a),o,s,c.READ_ALL)}async updateAll(t,e,r,...s){const{log:i,ctx:n}=this.logCtx(s,this.updateAll);if(e.length!==r.length)throw new u("Ids and models must have the same length");const o=z.tableName(t);i.debug(`Updating ${e.length} entries ${o} table`);const a=!(n.get("breakOnSingleFailureInBulk")??1),l=e.map((e,i)=>()=>this.update(t,e,r[i],...s,n.override({noEmitSingle:!0})));return ee(a?await Yt(l,!0):await Yt(l),a,i,c.UPDATE_ALL)}async deleteAll(t,e,...r){const{log:s,ctx:i}=this.logCtx(r,this.deleteAll);s.debug(`Deleting ${e.length} entries from ${t} table`);const n=!(i.get("breakOnSingleFailureInBulk")??1),o=e.map(e=>()=>this.delete(t,e,...r,i.override({noEmitSingle:!0})));return ee(n?await Yt(o,!0):await Yt(o),n,s,c.DELETE_ALL)}observe(t,e){this.observerHandler||Object.defineProperty(this,"observerHandler",{value:this.ObserverHandler(),writable:!1}),this.observerHandler.observe(t,e);const r=this.log.for(this.observe);return r.silly("Registering new observer "+t.toString()),this.dispatch||(r.verbose("Creating dispatch for "+this.alias),this.dispatch=this.Dispatch()),this.dispatch.observe(this),()=>this.unObserve(t)}unObserve(t){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");this.observerHandler.unObserve(t),this.observerHandler.count()>0||(this.log.for(this.unObserve).debug("No active observers for adpter. Closing dispatcher and unobserving."),this.dispatch?.close([]),this.dispatch?.unObserve(this)),this.log.for(this.unObserve).debug(`Observer ${t.toString()} removed`)}async updateObservers(t,e,r,...s){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");const{ctx:i,ctxArgs:n}=this.logCtx(s,this.updateObservers);if(!i.get("noEmit")){const s=Array.isArray(r),o=!i.get("noEmitSingle"),a=!i.get("noEmitBulk");(s&&a||!s&&o)&&await this.observerHandler.updateObservers(t,e,r,...n)}}async refresh(t,e,r,...s){return this.updateObservers(t,e,r,...s)}toString(){return this.flavour+" adapter"}static flavourOf(t){return dt.flavourOf(t)}static get currentFlavour(){if(!re._currentFlavour)throw new u("No persistence flavour set. Please initialize your adapter");return re._currentFlavour}static get current(){return re.get(this.currentFlavour)}static unregister(t){if(!t)return;const e=re._cache[t];e&&(delete re._cache[t],re._currentFlavour===t&&(re._currentFlavour=void 0),e.flavour&&re._cache[e.flavour]&&re._cache[e.flavour]===e&&delete re._cache[e.flavour])}static get(t){if(!t)return re.get(this._currentFlavour);if(t in this._cache)return this._cache[t];throw new u(`No Adapter registered under ${t}.`)}static setCurrent(t){this._currentFlavour=t}static models(t){try{return dt.flavouredAs(t).filter(z.isModel)}catch(t){throw new u(t)}}static decoration(){}get client(){return this._client||(this._client=this.getClient()),this._client}for(t,...e){this.proxies||(this.proxies={});const r=`${this.alias} - ${q(t)}`;if(r in this.proxies)return this.proxies[r];let s;const i=new Proxy(this,{get:(e,r,i)=>{if("_config"===r){const s=Reflect.get(e,r,i);return Object.assign({},s,t)}return"_client"===r?s:Reflect.get(e,r,i)},set:(t,e,r,i)=>"_client"===e?(s=r,!0):Reflect.set(t,e,r,i)});return Reflect.defineProperty(i,te,{value:async()=>{if(!s)return;const t=["cancel","close","destroy","disconnect"];for(const e of t){const t=s[e];if("function"==typeof t)try{const e=t.call(s);e instanceof Promise&&await e}catch{}}s=void 0},configurable:!0,enumerable:!1}),this.proxies[r]=i,i}migrations(){return dt.migrationsFor(this)}async getQueryRunner(){return this}logCtx(t,e,r=!1,s){return super.logCtx(t,e,r,s)}}i([j(),n("design:type",Function),n("design:paramtypes",[Object,Object,Object,Rt]),n("design:returntype",Promise)],re.prototype,"context",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,Function]),n("design:returntype",Function)],re.prototype,"observe",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",void 0)],re.prototype,"unObserve",null),i([j(),n("design:type",Object),n("design:paramtypes",[])],re.prototype,"client",null);class se extends u{constructor(t){super(t,se.name,500)}}class ie extends u{constructor(t){super(t,ie.name,500)}}class ne extends z{constructor(t,e,r){super(),this.attr1=void 0,this.operator=void 0,this.comparison=void 0,e||r?(this.attr1=t,this.operator=e,this.comparison=r):z.fromModel(this,t)}and(t){return ne.and(this,t)}or(t){return ne.or(this,t)}not(t){return new ne(this,Et.NOT,t)}hasErrors(...t){const e=()=>{const t=`Invalid operator ${this.operator}}`;if("string"==typeof this.attr1){if(this.comparison instanceof ne)return{comparison:{condition:"Both sides of the comparison must be of the same type"}};if(-1===Object.values(Et).indexOf(this.operator))return{operator:{condition:t}};if(this.operator===Et.BETWEEN&&(!Array.isArray(this.comparison)||2!==this.comparison.length))return{comparison:{condition:"BETWEEN operator requires an array with exactly 2 values [min, max]"}}}if(this.attr1 instanceof ne){if(!(this.comparison instanceof ne)&&this.operator!==Et.NOT)return{comparison:{condition:t}};if(-1===Object.values(Ot).indexOf(this.operator)&&this.operator!==Et.NOT)return{operator:{condition:t}}}},r=super.hasErrors(...t);return this.isAsync()?(async()=>await Promise.resolve(r)??e())():r??e()}static and(t,e){return ne.group(t,Ot.AND,e)}static or(t,e){return ne.group(t,Ot.OR,e)}static group(t,e,r){return new ne(t,e,r)}static attribute(t){return(new ne.Builder).attribute(t)}static attr(t){return this.attribute(t)}static{this.Builder=class{constructor(){this.attr1=void 0,this.operator=void 0,this.comparison=void 0}attribute(t){return this.attr1=t,this}attr(t){return this.attribute(t)}eq(t){return this.setOp(Et.EQUAL,t)}dif(t){return this.setOp(Et.DIFFERENT,t)}gt(t){return this.setOp(Et.BIGGER,t)}lt(t){return this.setOp(Et.SMALLER,t)}gte(t){return this.setOp(Et.BIGGER_EQ,t)}lte(t){return this.setOp(Et.SMALLER_EQ,t)}in(t){return this.setOp(Et.IN,t)}regexp(t){return this.setOp(Et.REGEXP,RegExp(t).source)}startsWith(t){return this.setOp(Et.STARTS_WITH,t)}endsWith(t){return this.setOp(Et.ENDS_WITH,t)}between(t,e){return this.setOp(Et.BETWEEN,[t,e])}setOp(t,e){return this.operator=t,this.comparison=e,this.build()}build(){try{return new ne(this.attr1,this.operator,this.comparison)}catch(t){throw new se(t)}}}}static builder(){return new ne.Builder}static from(t){return new ne(t)}}var oe,ae;i([H(),n("design:type",Object)],ne.prototype,"attr1",void 0),i([H(),n("design:type",String)],ne.prototype,"operator",void 0),i([H(),n("design:type",Object)],ne.prototype,"comparison",void 0),(t=>{t.ASC="asc",t.DSC="desc"})(oe||(oe={})),(t=>{t.CASCADE="cascade",t.NONE="none"})(ae||(ae={}));const ce={update:ae.CASCADE,delete:ae.NONE},le={Equals:(t,e)=>ne.attribute(t).eq(e),Diff:(t,e)=>ne.attribute(t).dif(e),LessThan:(t,e)=>ne.attribute(t).lt(e),LessThanEqual:(t,e)=>ne.attribute(t).lte(e),GreaterThan:(t,e)=>ne.attribute(t).gt(e),GreaterThanEqual:(t,e)=>ne.attribute(t).gte(e),In:(t,e)=>ne.attribute(t).in(e),Matches:(t,e)=>ne.attribute(t).regexp(e)},ue=t=>t.charAt(0).toLowerCase()+t.slice(1);class de extends M{static get log(){return this._logger||(this._logger=L.for(de.name)),this._logger}static{this.prefixMap={[xt.FIND_BY]:"find",[xt.PAGE_BY]:"page",[xt.COUNT_BY]:"count",[xt.SUM_BY]:"sum",[xt.AVG_BY]:"avg",[xt.MIN_BY]:"min",[xt.MAX_BY]:"max",[xt.DISTINCT_BY]:"distinct",[xt.GROUP_BY_PREFIX]:"group"}}static getActionFromMethodName(t){for(const[e,r]of Object.entries(this.prefixMap))if(t.startsWith(e))return{action:r,prefix:e}}static build(t,...e){const r=this.getActionFromMethodName(t);if(!r)throw Error("Unsupported method "+t);const{action:s,prefix:i}=r;let n;["count","sum","avg","min","max","distinct","group"].includes(s)&&(n=this.extractAggregationSelector(t,i));const o=this.extractCore(t,i),a=this.extractSelect(t),c=this.extractGroupBy(t),l=this.buildWhere(o,e),{orderBy:u,limit:d,offset:h}=this.extractOrderLimitOffset(t,e,o);return{action:s,select:a,selector:n,where:l,groupBy:c,orderBy:u,limit:d,offset:h}}static extractAggregationSelector(t,e){const r=t.substring(e.length),s=r.match(/(And|Or|GroupBy|OrderBy|Select|Limit|Offset|ThenBy)/),i=s?r.substring(0,s.index):r;return i?ue(i):void 0}static extractCore(t,e=xt.FIND_BY){const r=t.substring(e.length);if(e!==xt.FIND_BY&&e!==xt.PAGE_BY){const t=r.match(/(And|Or|GroupBy|OrderBy|ThenBy|Select|Limit|Offset)/);if(!t)return"";if("And"===t[0]||"Or"===t[0]){const e=r.substring(t.index+t[0].length),s=e.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset|Select|ThenBy)/);return s?e.substring(0,s.index):e}return""}const s=r.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset|Select)/);return s?r.substring(0,s.index):r}static getFieldsFromMethodName(t){const e=this.getActionFromMethodName(t),r=e?.prefix||xt.FIND_BY,s=this.extractCore(t,r);return s?(s.split(/OrderBy|GroupBy/)[0]||"").split(/And|Or/).filter(t=>t.length>0).map(t=>{const{operator:e,field:r}=this.parseFieldAndOperator(t);return r+(e??"")}):[]}static extractSelect(t){const e=t.indexOf(xt.SELECT);if(-1===e)return;const r=t.substring(e+xt.SELECT.length),s=r.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset)/);return(s?r.substring(0,s.index):r).split(xt.AND).map(ue).filter(Boolean)}static extractGroupBy(t){const e=t.indexOf(xt.GROUP_BY);if(-1!==e)return t.substring(e+xt.GROUP_BY.length).split(xt.ORDER_BY)[0].split(xt.THEN_BY).map(ue).filter(Boolean);const r=this.getActionFromMethodName(t);if("group"===r?.action){const e=t.substring(r.prefix.length),s=e.indexOf(xt.THEN_BY);if(-1===s)return;const i=e.substring(s+xt.THEN_BY.length).split(xt.THEN_BY),n=[];for(const t of i){const e=t.match(/(OrderBy|Limit|Offset|Select)/),r=e?t.substring(0,e.index):t;r&&n.push(ue(r))}return n.length>0?n:void 0}}static buildWhere(t,e){if(!t)return;const r=t.split(/OrderBy|GroupBy/)[0]||"";if(!r)return;const s=r.split(/And|Or/).filter(t=>t.length>0);if(0===s.length)return;const i=t.match(/And|Or/g)||[];let n;return s.forEach((t,r)=>{const{field:s,operator:o}=this.parseFieldAndOperator(t),a=o?le[o]:le.Equals;if(!a)throw Error("Unsupported operator "+o);const c=e[r];if(void 0===c)throw Error("Invalid value for field "+s);const l=a(s,c);n=0===r?l:i[r-1]===xt.AND?n.and(l):n.or(l)}),n}static parseFieldAndOperator(t){for(const e of Object.keys(le))if(t.endsWith(e)){const r=t.slice(0,-e.length);return{field:ue(r),operator:e}}return{field:ue(t)}}static extractOrderByField(t){const e=t.match(/OrderBy(.+)$/);if(!e)return;const r=e[1];return r.charAt(0).toLowerCase()+r.slice(1)}static getProperlyOrderByOrThrow(t,e){const r=de.log.for(this.getProperlyOrderByOrThrow);if(e||t){if(e&&!t)throw new se("Expected OrderBy clause, but no sortable field was found in method name.");if(e||!t){if(!Object.values(oe).includes(e))throw new se(`Invalid OrderBy direction ${e}. Expected one of: ${Object.values(oe).join(", ")}.`);return[[t,e]]}r.debug("Ignoring OrderBy clause because direction is undefined.")}}static extractOrderLimitOffset(t,e,r){const s=r??this.extractCore(t),i=s?s.split(/And|Or/).filter(t=>t.length>0).length:0,n=e.slice(i)??[];let o,a,c;if(n.at(-1)instanceof l&&n.pop(),n.length>=1){const e=n[0],r=this.extractOrderByField(t);o=this.getProperlyOrderByOrThrow(r,e)}return 2>n.length||"number"!=typeof n[1]||(a=n[1]),3>n.length||"number"!=typeof n[2]||(c=n[2]),{orderBy:o,limit:a,offset:c}}}function he(){return(t,e)=>{const r=dt.key(Ct.DEFAULT_QUERY_ATTR);let s=dt.get(t.constructor,r)||[];return s=[...new Set([...s,e])],gt(yt(r,s))(t,e)}}function pe(){return ht.for(Ct.STATEMENT).define({decorator:()=>(t,e,r)=>gt(ft(dt.key(Ct.STATEMENT,e),!0))(t,e,r),args:[]}).apply()}function ge(t={}){return ht.for(Ct.QUERY).define({decorator:t=>function e(r,s,i){const n=de.getFieldsFromMethodName(s);return gt(ft(dt.key(Ct.QUERY,s),{...t,fields:n}),pe(),(t=>(r,s,i)=>{i.value=new Proxy(i.value,{async apply(r,s,i){const{action:n,select:o,selector:a,where:c,groupBy:l,orderBy:u,limit:d,offset:p}=de.build(r.name,...i);if(!(s instanceof h))throw Error("thisArg must be an instance of Repository");const g=s,{ctx:f}=(await g.logCtx(i,e.name,!0)).for(e);let y;switch(n){case"find":case"page":y=g.select(o);break;case"count":y=g.count(a);break;case"sum":y=g.sum(a);break;case"avg":y=g.avg(a);break;case"min":y=g.min(a);break;case"max":y=g.max(a);break;case"distinct":y=g.distinct(a);break;case"group":y=g.select(),a&&(y=y.groupBy(a));break;default:throw new se("Unsupported action: "+n)}if(c&&(y=y.where(c)),l&&l.length>0&&"group"!==n){y=y.groupBy(l[0]);for(let t=1;t<l.length;t++)y=y.thenBy(l[t])}else if(l&&l.length>0&&"group"===n)for(const t of l)y=y.thenBy(t);const{allowLimit:m,allowOffset:w,allowOrderBy:v,throws:b}={allowLimit:!0,allowOrderBy:!0,allowOffset:!0,throws:!0,...t},A=[{key:"orderBy",value:(u||[])[0],allowed:v},{key:"limit",value:d,allowed:m},{key:"offset",value:p,allowed:w}];for(const t of A)if(void 0!==t.value){if(!t.allowed&&b)throw new se(t.key[0].toUpperCase()+t.key.slice(1)+" is not allowed for this query");t.allowed&&(y=y[t.key](t.value))}if("page"===n){const t=i[i.length-1],e="number"==typeof t?t:t?.limit??10;return y.paginate(e,f)}return y.execute(f)}})})(t))(r,s,i)},args:[t]}).apply()}function fe(t,e,r){return(s,i)=>{const n=r?.name||((t,e,r)=>{const s=(dt.get(t.constructor,e)||{})[r]||{};return Object.keys(s).length+1+""})(s,t,i),o=dt.key(t,i,n),a={...r||{},kind:e,attribute:i};return yt(o,a)(s,i)}}function ye(t){return ht.for(Et.VIEW).define({decorator:t=>fe(Et.VIEW,"view",t),args:[t]}).apply()}function me(t){return xe(t,[a.CREATE,c.CREATE_ALL])}function we(t){return xe(t,[a.UPDATE,c.UPDATE_ALL])}function ve(t){return xe(t,[a.DELETE,c.DELETE_ALL])}function be(t){return xe(t,Dt)}function Ae(t){return xe(t,Object.values(a))}function Se(t){return xe(t,Object.values(c))}function xe(t,e){return(r,s,i,...n)=>{if("string"==typeof t)throw new u("clazz cannot be string. This should be impossible");const{log:o}=$t.prototype.logCtx(n,xe);return o.silly(`filtering ${s} event for${r?" "+(z.tableName(r)||r):""} ${i}`),("string"==typeof r?r===z.tableName(t)||r===t.constructor.name:dt.constr(t)===dt.constr(r))&&e.includes(s)}}const Ee={onlyOnCreate:me,onlyOnUpdate:we,onlyOnDelete:ve,onlyOnTransactional:be,onlyOnSingle:Ae,onlyOnBulk:Se};function Oe(t){const e=Object.assign({},Ee);return Object.entries(e).forEach(([r,s])=>{e[r]=s(t.class)}),e}var ke,Ce,Te,Ne,De,_e,Ie,Be,Pe,Re,$e;class Fe extends h{static{this._cache={}}get log(){return this.logger||(this.logger=this.adapter.log.for(this.toString())),this.logger}get adapter(){if(!this._adapter)throw new u("No adapter found for this repository. did you use the @uses decorator or pass it in the constructor?");return this._adapter}get tableName(){return this._tableName||(this._tableName=z.tableName(this.class)),this._tableName}get pkProps(){return super.pkProps}get filters(){return Oe(this)}constructor(t,e,r=!1,...s){super(e),this.observers=[],this._overrides={ignoreHandlers:!1,ignoreValidation:!1,allowGenerationOverride:!1,allowRawStatements:!0,forcePrepareSimpleQueries:!1,forcePrepareComplexQueries:!1,ignoreDevSafeGuards:!1,mergeForUpdate:!0,applyUpdateValidation:!0,afterQueryHandlers:!1},t&&(this._adapter=t),e&&(Fe.register(e,this,this.adapter.alias,r),t)&&dt.get(e,mt.FLAVOUR)===pt&&wt(t.flavour)(e);const i=this;[this.createAll,this.readAll,this.deleteAll].forEach(t=>{const e=t.name;p(i,i[e+"Prefix"],t,i[e+"Suffix"])}),g(i,i[this.updateAll.name+"Prefix"],this.updateAll,i[this.updateAll.name+"Suffix"])}logCtx(t,e,r=!1,s){const i=this.adapter.logCtx([this.class,...t],e,r,Object.assign({},s||{},this._overrides||{}));function n(t){return t.ctxArgs.shift(),t}return i instanceof Promise?i.then(n):n(i)}override(t){return new Proxy(this,{get:(e,r,s)=>{const i=Reflect.get(e,r,s);return"_overrides"!==r?i:Object.assign({},i,t)}})}for(t,...e){return new Proxy(this,{get:(r,s,i)=>"adapter"===s?this.adapter.for(t,...e):Reflect.get(r,s,i)})}ObserverHandler(){return new Lt}async createPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.CREATE,!0)).for(this.createPrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");if(i.silly(`handlerSetting: ${n}, validationSetting: ${o}`),t=new this.class(t),n||await f(this,r,t,a.CREATE,a.ON),!o){const e=r.get("ignoredValidationProperties")||[];i.silly("ignored validation properties: "+e);const s=await Promise.resolve(t.hasErrors(...e));if(s)throw new d(s.toString())}return[t,...s]}async create(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.create);s.debug(`Creating new ${this.class.name} in table ${z.tableName(this.class)}`);let{record:n,id:o,transient:a}=this.adapter.prepare(t,r);return n=await this.adapter.create(this.class,o,n,...i),this.adapter.revert(n,this.class,o,a,r)}async createAll(t,...e){if(!t.length)return t;const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.createAll);s.debug(`Creating ${t.length} new ${this.class.name} in table ${z.tableName(this.class)}`);const n=t.map(t=>this.adapter.prepare(t,r)),o=n.map(t=>t.id);let a=n.map(t=>t.record);return a=await this.adapter.createAll(this.class,o,a,...i),a.map((t,e)=>this.adapter.revert(t,this.class,o[e],r.get("rebuildWithTransient")?n[e].transient:void 0,r))}async createAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.CREATE_ALL,!0)).for(this.createAllPrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");if(i.silly(`handlerSetting: ${n}, validationSetting: ${o}`),!t.length)return[t,...s];const l=z.sequenceFor(t[0]);let h=[];if(z.generatedBySequence(this.class)?(l.name||(l.name=z.sequenceName(t[0],"pk")),h=await(await this.adapter.Sequence(l,this._overrides)).range(t.length,...s)):z.generated(this.class,this.pk)||(h=t.map((t,e)=>{if(void 0===t[this.pk])throw new u("Primary key is not defined for model in position "+e);return t[this.pk]})),t=await Promise.all(t.map(async(t,e)=>(t=new this.class(t),l.type&&(t[this.pk]="String"!==l.type||l.generated?h[e]:""+t[this.pk]),n||await f(this,r,t,a.CREATE,a.ON),t))),!o){const e=r.get("ignoredValidationProperties")||[];i.silly("ignored validation properties: "+e);const s=await Promise.all(t.map(t=>Promise.resolve(t.hasErrors(...e)))),n=y(s);if(n)throw new d(n)}return[t,...s]}async readPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.READ,!0)).for(this.readPrefix),n=r.get("ignoreHandlers");i.silly("handlerSetting: "+n);const o=new this.class;return o[this.pk]=t,n||await f(this,r,o,a.READ,a.ON),[t,...s]}async read(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.read);s.debug(`reading ${this.class.name} from table ${z.tableName(this.class)} with pk ${this.pk}`);const n=await this.adapter.read(this.class,t,...i);return this.adapter.revert(n,this.class,t,void 0,r)}async readAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.READ_ALL,!0)).for(this.readAllPrefix),n=r.get("ignoreHandlers");return i.silly("handlerSetting: "+n),n||await Promise.all(t.map(async t=>{const e=new this.class;return e[this.pk]=t,f(this,r,e,a.READ,a.ON)})),[t,...s]}async readAll(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.readAll);return s.debug(`reading ${t.length} ${this.class.name} in table ${z.tableName(this.class)}`),(await this.adapter.readAll(this.class,t,...i)).map((e,s)=>this.adapter.revert(e,this.class,t[s],void 0,r))}async update(t,...e){const{ctxArgs:r,log:s,ctx:i}=this.logCtx(e,this.update);let{record:n,id:o,transient:a}=this.adapter.prepare(t,i);return s.debug(`updating ${this.class.name} in table ${z.tableName(this.class)} with id ${o}`),n=await this.adapter.update(this.class,o,n,...r),this.adapter.revert(n,this.class,o,a,i)}async updatePrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.UPDATE,!0)).for(this.updatePrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");i.silly(`handlerSetting: ${n}, validationSetting: ${o}`);const c=t[this.pk];if(!c)throw new u("No value for the Id is defined under the property "+this.pk);let l;if(r.get("applyUpdateValidation")&&(l=await this.read(c,r),r.get("mergeForUpdate")&&(t=z.merge(l,t,this.class))),n||await f(this,r,t,a.UPDATE,a.ON,l),!o){const e=r.get("ignoredValidationProperties")||[];i.silly("ignored validation properties: "+e);const s=await Promise.resolve(t.hasErrors(l,...e));if(s)throw new d(s.toString())}return[t,...s,l]}async updateAll(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.updateAll);s.verbose(`Updating ${t.length} new ${this.class.name} in table ${z.tableName(this.class)}`);const n=t.map(t=>this.adapter.prepare(t,r));return(await this.adapter.updateAll(this.class,n.map(t=>t.id),n.map(t=>t.record),...i)).map((t,e)=>this.adapter.revert(t,this.class,n[e].id,r.get("rebuildWithTransient")?n[e].transient:void 0,r))}async updateAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.UPDATE_ALL,!0)).for(this.updateAllPrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");i.silly(`handlerSetting: ${n}, ignoredValidation: ${o}`);const l=t.map(t=>{const e=t[this.pk];if(!e)throw new u("missing id on update operation");return e});let h;if(r.get("applyUpdateValidation")&&(h=await this.readAll(l,r),r.get("mergeForUpdate")&&(t=t.map((t,e)=>z.merge(h[e],t,this.class)))),n||await Promise.all(t.map((t,e)=>f(this,r,t,a.UPDATE,a.ON,h?h[e]:void 0))),!o){const e=r.get("ignoredValidationProperties")||[];let s;i.silly("ignored validation properties: "+e),s=r.get("applyUpdateValidation")?await Promise.all(t.map((t,r)=>Promise.resolve(t.hasErrors(h[r],...e)))):await Promise.resolve(t.map(t=>t.hasErrors(...e)));const n=y(s);if(n)throw new d(n)}return[t,...s,h]}async deletePrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.DELETE,!0)).for(this.deletePrefix),n=r.get("ignoreHandlers");if(i.silly("handlerSetting: "+n),!n){const e=await this.read(t,...s);await f(this,r,e,a.DELETE,a.ON)}return[t,...s]}async delete(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.delete);s.debug(`deleting new ${this.class.name} in table ${z.tableName(this.class)} with pk ${t}`);const n=await this.adapter.delete(this.class,t,...i);return this.adapter.revert(n,this.class,t,void 0,r)}async deleteAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.DELETE_ALL,!0)).for(this.deleteAllPrefix),n=r.get("ignoreHandlers");if(i.silly("handlerSetting: "+n),!n){const e=await this.readAll(t,...s);await Promise.all(e.map(async t=>f(this,r,t,a.DELETE,a.ON)))}return[t,...s]}async deleteAll(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.create);return s.debug(`deleting ${t.length} ${this.class.name} in table ${z.tableName(this.class)}`),(await this.adapter.deleteAll(this.class,t,...i)).map((e,s)=>this.adapter.revert(e,this.class,t[s],void 0,r))}select(t){return this.adapter.Statement(this._overrides).select(t).from(this.class)}count(t){return this.adapter.Statement(this._overrides).count(t).from(this.class)}min(t){return this.adapter.Statement(this._overrides).min(t).from(this.class)}max(t){return this.adapter.Statement(this._overrides).max(t).from(this.class)}sum(t){return this.adapter.Statement(this._overrides).sum(t).from(this.class)}avg(t){return this.adapter.Statement(this._overrides).avg(t).from(this.class)}distinct(t){return this.adapter.Statement(this._overrides).distinct(t).from(this.class)}async query(t,e,r=oe.ASC,s,i,...n){const{ctxArgs:o}=(await this.logCtx(n,Ct.QUERY,!0)).for(this.query),a=[e,r],c=this.select().where(t).orderBy(a);return s&&c.limit(s),i&&c.offset(i),c.execute(...o)}async listBy(t,e,...r){const{log:s,ctxArgs:i}=(await this.logCtx(r,kt.LIST_BY,!0)).for(this.listBy);return s.verbose(`listing ${z.tableName(this.class)} by ${t} ${e}`),this.select().orderBy([t,e]).execute(...i)}async paginateBy(t,e,r={offset:1,limit:10},...s){r.offset=r.offset||1,r.limit=r.limit||10;const{offset:i,bookmark:n,limit:o}=r;if(!i&&!n)throw new se("PaginateBy needs a page or a bookmark");const{log:a,ctx:c,ctxArgs:l}=(await this.logCtx(s,kt.PAGE_BY,!0)).for(this.paginateBy);let u;if(a.verbose(`paginating ${z.tableName(this.class)} with page size ${o}`),n&&c.get("paginateByBookmark"))u=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().where((()=>e===oe.ASC?this.attr(z.pk(this.class)).gt(n):this.attr(z.pk(this.class)).lt(n))()).orderBy([t,e]).paginate(o,...l);else{if(!i)throw new se("PaginateBy needs a page or a bookmark");u=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().orderBy([t,e]).paginate(o,...l)}const d=await u.page(i,n,...l);return u.serialize(d)}async find(t,e=oe.ASC,...r){if("string"!=typeof t)throw new se("Find value must be a string");const s=this.getDefaultQueryAttributes(),{log:i,ctxArgs:n}=(await this.logCtx(r,kt.FIND,!0)).for(this.find);i.verbose(`finding ${z.tableName(this.class)} by default attributes ${s.join(", ")}`);const o=this.buildDefaultStartsWithCondition(t,s);return this.select().where(o).orderBy([s[0],e]).execute(...n)}async page(t,e=oe.ASC,r={offset:1,limit:10},...s){if("string"!=typeof t)throw new se("Page value must be a string");const i=r.offset||1,{offset:n,bookmark:o,limit:a}=r;if(!n&&!o)throw new se("PaginateBy needs a page or a bookmark");const c=this.getDefaultQueryAttributes(),l=this.buildDefaultStartsWithCondition(t,c),{log:u,ctx:d,ctxArgs:h}=(await this.logCtx(s,kt.PAGE,!0)).for(this.page);u.verbose(`paging ${z.tableName(this.class)} by default attributes ${c.join(", ")}`);const p=a??10,g=c[0],f=this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1});let y;if(o&&d.get("paginateByBookmark")){const t=z.pk(this.class),r=e===oe.ASC?this.attr(t).gt(o):this.attr(t).lt(o);y=await f.select().where(l.and(r)).orderBy([g,e]).paginate(p,...h)}else{if(!n)throw new se("PaginateBy needs a page or a bookmark");y=await f.select().where(l).orderBy([g,e]).paginate(p,...h)}const m=await y.page(i,o,...h);return y.serialize(m)}async findOneBy(t,e,...r){const{log:s,ctxArgs:i}=(await this.logCtx(r,kt.FIND_ONE_BY,!0)).for(this.findOneBy);s.verbose(`finding ${z.tableName(this.class)} with ${t} ${e}`);const n=await this.select().where(this.attr(t).eq(e)).limit(1).execute(...i);if(!n.length)throw new m("No results found");return n[0]}async findBy(t,e,...r){const{log:s,ctxArgs:i}=(await this.logCtx(r,kt.FIND_BY,!0)).for(this.findBy);return s.verbose(`finding ${z.tableName(this.class)} with ${t} ${e}`),this.select().where(this.attr(t).eq(e)).execute(...i)}async findByPaginate(t,e,r={direction:oe.DSC,offset:1,limit:10},...s){r.direction=r.direction||oe.DSC,r.offset=r.offset||1,r.limit=r.limit||10;const{direction:i,offset:n,bookmark:o,limit:a}=r;if(!n&&!o)throw new se("FindByPaginate needs a page or a bookmark");const{log:c,ctx:l,ctxArgs:u}=(await this.logCtx(s,kt.FIND_BY_PAGINATE,!0)).for(this.findByPaginate);c.verbose(`finding and paginating ${z.tableName(this.class)} with ${t} ${e}`);const d=this.attr(t).eq(e);let h;if(o&&l.get("paginateByBookmark")){const e=z.pk(this.class),r=i===oe.ASC?this.attr(e).gt(o):this.attr(e).lt(o);h=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().where(d.and(r)).orderBy([t,i]).paginate(a,...u)}else{if(!n)throw new se("FindByPaginate needs a page or a bookmark");h=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().where(d).orderBy([t,i]).paginate(a,...u)}const p=await h.page(n,o,...u);return h.serialize(p)}async countOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.COUNT_OF,!0)).for(this.countOf);return r.verbose(`counting ${z.tableName(this.class)}${t?" by "+t:""}`),this.count(t).execute(...s)}async maxOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.MAX_OF,!0)).for(this.maxOf);return r.verbose(`finding max of ${t} in ${z.tableName(this.class)}`),this.max(t).execute(...s)}async minOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.MIN_OF,!0)).for(this.minOf);return r.verbose(`finding min of ${t} in ${z.tableName(this.class)}`),this.min(t).execute(...s)}async avgOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.AVG_OF,!0)).for(this.avgOf);return r.verbose(`calculating average of ${t} in ${z.tableName(this.class)}`),this.avg(t).execute(...s)}async sumOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.SUM_OF,!0)).for(this.sumOf);return r.verbose(`calculating sum of ${t} in ${z.tableName(this.class)}`),this.sum(t).execute(...s)}async distinctOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.DISTINCT_OF,!0)).for(this.distinctOf);return r.verbose(`finding distinct values of ${t} in ${z.tableName(this.class)}`),this.distinct(t).execute(...s)}async groupOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.GROUP_OF,!0)).for(this.groupOf);return r.verbose(`grouping ${z.tableName(this.class)} by ${t}`),this.select().groupBy(t).execute(...s)}async statement(t,...e){if(!Fe.statements(this,t))throw new se("Invalid prepared statement requested "+t);const{log:r,ctxArgs:s}=(await this.logCtx(e,Ct.STATEMENT,!0)).for(this.statement);return r.verbose("Executing prepared statement "+t),this[t](...s)}getDefaultQueryAttributes(){const t=z.defaultQueryAttributes(this.class);if(!t||!t.length)throw new se("No default query attributes defined for "+z.tableName(this.class));return t}buildDefaultStartsWithCondition(t,e){if("string"!=typeof t)throw new se("Default query value must be a string");let r;for(const s of e){const e=this.attr(s).startsWith(t);r=r?r.or(e):e}if(!r)throw new se("No default query attributes available for "+z.tableName(this.class));return r}attr(t){return ne.attr(t)}observe(t,e){this.observerHandler||Object.defineProperty(this,"observerHandler",{value:this.ObserverHandler(),writable:!1});const r=this.log.for(this.observe),s=this.class.name;return this.observerHandler?.count()||this.adapter.observe(this,(t,e,r,...i)=>"string"==typeof t?t===s:dt.constr(t)===dt.constr(this.class)),r.verbose(`now observing ${this.adapter} filtering on table === ${s}`),this.observerHandler.observe(t,e),r.verbose("Registered new observer "+t.toString()),()=>this.unObserve(t)}unObserve(t){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");this.observerHandler.unObserve(t),this.log.for(this.unObserve).verbose(`Observer ${t.toString()} removed`),this.observerHandler.count()||(this.log.verbose(`No more observers registered for ${this.adapter}, unsubscribing`),this.adapter.unObserve(this),this.log.verbose("No longer observing adapter "+this.adapter.flavour))}async updateObservers(t,e,r,...s){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");const{log:i,ctxArgs:n}=this.logCtx(s,this.updateObservers);i.verbose(`Updating ${this.observerHandler.count()} observers for ${this}`),await this.observerHandler.updateObservers(t,e,Array.isArray(r)?r.map(t=>re._baseSequence.parseValue(z.sequenceFor(this.class).type,t)):re._baseSequence.parseValue(z.sequenceFor(this.class).type,r),...n)}async refresh(t,e,r,...s){return this.updateObservers(t,e,r,...s)}static forModel(t,e,...r){let s;const i=dt.registeredFlavour(t),n=i&&i!==pt?i:void 0,o=e||n||dt.flavourOf(t)||re.currentFlavour;try{s=this.get(t,o)}catch(t){s=void 0}const a="function"==typeof s?s:void 0,c=e||n||dt.flavourOf(t)||a&&dt.get(a,Ct.ADAPTER)||re.currentFlavour,l=c?re.get(c):void 0;if(!l)throw new u("No registered persistence adapter found flavour "+c);if(s instanceof Fe)return s;const d=[z.tableName(t),l.alias].join(w),h=a||l.repository();return delete this._cache[d],new h(l,t,...r)}static get(t,e){const r=z.tableName(t);let s=r;if(e&&(s=[r,e].join(w)),s in this._cache)return this._cache[s];if(r in this._cache)return this._cache[r];throw new u("Could not find repository registered under "+r)}static register(t,e,r,s=!1){let i=z.tableName(t);if(r&&(i=[i,r].join(w)),i in this._cache&&this._cache[i]instanceof Fe&&!s)throw new u(i+" already has a registered instance");this._cache[i]=e}static statements(t,e){const r=t instanceof Fe?t.constructor:t,s=dt.get(r,e?dt.key(Ct.STATEMENT,e):Ct.STATEMENT);return(e?s:Object.keys(s))||!1}static queries(t,e){const r=t instanceof Fe?t.constructor:t;return dt.get(r,e?dt.key(Ct.QUERY,e):Ct.QUERY)}}function Le(t,e){if(!(e||(e=ht.flavourResolver(t instanceof z?t.constructor:t))&&e!==pt))throw new u("Could not retrieve flavour from model "+(t instanceof z?t.constructor.name:t.name));return V(Ct.INJECTABLE,e,z.tableName(t))}i([pe(),n("design:type",Function),n("design:paramtypes",[Object,String,void 0]),n("design:returntype",Promise)],Fe.prototype,"listBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,String,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"paginateBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[String,String,void 0]),n("design:returntype",Promise)],Fe.prototype,"find",null),i([pe(),n("design:type",Function),n("design:paramtypes",[String,String,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"page",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"findOneBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"findBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,Object,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"findByPaginate",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"countOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(ke="undefined"!=typeof K&&K)?ke:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"maxOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(Ce="undefined"!=typeof K&&K)?Ce:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"minOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(Te="undefined"!=typeof K&&K)?Te:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"avgOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(Ne="undefined"!=typeof K&&K)?Ne:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"sumOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(De="undefined"!=typeof K&&K)?De:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"distinctOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(_e="undefined"!=typeof K&&K)?_e:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"groupOf",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,Function]),n("design:returntype",Function)],Fe.prototype,"observe",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",void 0)],Fe.prototype,"unObserve",null),re&&(re._baseRepository=Fe);class Me extends t{get log(){return this.logger||(this.logger=L.for(this)),this.logger}constructor(){super()}get(t,r){const s=this.log.for(this.get);let i;try{i=super.get(t)}catch{}if(!i){let n;if("function"==typeof t?n=z.get(t.name)||t:"symbol"!=typeof t&&"string"!=typeof t||(n=z.get(t.toString())),!n)return;const o=Ct.ADAPTER,a=r||dt.get(n,o)||dt.flavourOf(n);try{let t=a;try{a&&re.get(a)}catch{const e=re.current;e&&e.flavour===a&&(t=e.alias)}if(i=Fe.forModel(n,t),i instanceof Fe)return i;const r=a||dt.get(i.constructor,o)||dt.get(n,o);e.register(i,Le(n,r))}catch(t){s.debug("No registered repository or adapter found. falling back to default adapter. Error: "+(t?.message||JSON.stringify(t)));const e=Fe.get(n,a);if("function"==typeof e){const t=a?re.get(a):re.current;if(!t)return;return new e(t,n)}}}return i}}(t=>{t.PENDING="pending",t.SCHEDULED="scheduled",t.RUNNING="running",t.FAILED="failed",t.SUCCEEDED="succeeded",t.CANCELED="canceled",t.WAITING_RETRY="waiting_retry"})(Ie||(Ie={})),(t=>{t.EXPONENTIAL="exponential",t.FIXED="fixed"})(Be||(Be={})),(t=>{t.NONE="none",t.FULL="full"})(Pe||(Pe={})),(t=>{t.STATUS="status",t.UPDATE="update",t.LOG="log",t.PROGRESS="progress",t.ALL="all"})(Re||(Re={})),(t=>{t.ATOMIC="atomic",t.COMPOSITE="composite"})($e||($e={}));const je="tasks",Ue={workerId:"default-worker",concurrency:10,leaseMs:6e4,pollMsIdle:1e3,pollMsBusy:500,logTailMax:100,streamBufferSize:5,maxLoggingBuffer:300,loggingBufferTruncation:20,gracefulShutdownMsTimeout:12e4,autoShutdown:{enabled:!1,backoffStepMs:1e3,maxIdleDelayMs:6e4}};function Ge(t,e){return(i,n)=>n?r(dt.constr(t))(i,n):(dt.set(v.REPOSITORY,dt.key(e||re.currentFlavour,z.tableName(t)),i),vt(v.REPOSITORY,i.name)(t),e=e||dt.get(i.constructor,Ct.ADAPTER),Fe.register(t,i),s(dt.constr(t),{callback:e=>(Object.defineProperty(e,v.CLASS,{enumerable:!1,configurable:!1,writable:!1,value:t}),e)})(i))}dt.tasks=(()=>dt.innerGet(Symbol.for(je))).bind(dt),dt.taskFor=(t=>{const e=dt.tasks();return e?e[t]:void 0}).bind(dt),dt.validationExceptions=((t,e)=>{const r=dt.get(t,Ct.NO_VALIDATE)||[],s=Object.entries(r).filter(([,t])=>t.includes(e)).map(([t])=>t);let i=[];return e!==a.CREATE&&e!==a.UPDATE||(i=z.nestedRelations(t)),[...new Set([...s,...i])]}).bind(dt),dt.migrationsFor=(t=>{if(!(t=t??re.current))throw new u("Could not get adapter for migrations");return dt.innerGet(Symbol.for(Ct.MIGRATION),t.alias).map(t=>t.class)}).bind(dt),dt.migrations=(()=>{const t=dt.innerGet(Symbol.for([Ct.MIGRATION,Ct.BY_KEY].join("-")));return Object.values(t).flat().map(t=>[t.class.name,t.class])}).bind(dt),dt.relations=((t,e)=>{const r=dt.get(t,Ct.RELATIONS);if(r){if(!e)return Object.keys(r);if(!r[e])throw new u("No relations metadata found for property "+e);return r[e]}}).bind(dt),z.relations=(t,e)=>dt.relations(t instanceof z?t.constructor:t,e)||[],z.nestedRelations=((t,e=[])=>{let r=[];const s=dt.get(t,Ct.RELATIONS);if(!s||!Object.keys(s).length)return[...new Set([...e])];for(const t in s){const i=s[t];if(i?.class&&z.relations(i.class)){const s=z.relations(i.class).map(e=>`${t}.${e}`);e=[...e,...s],r=z.nestedRelations(i.class,e)}}return[...new Set([...e,...r])]}).bind(z),z.generatedBySequence=((t,e)=>{const r="function"!=typeof t?t.constructor:t;return!!z.sequenceFor(r).generated}).bind(z),z.fromTable=(t=>{const e=dt.innerGet(Symbol.for(Ct.TABLE));if(!e||!e[t]||!z.get(e[t].name))throw new u("No table metadata found for model. did you use @table()?");return z.get(e[t].name)}).bind(z),dt.createdBy=(t=>{const e=dt.get("function"!=typeof t?t.constructor:t,Ct.CREATED_BY);if(!e)throw new u("No createdBy metadata found for model. did you use @createdBy()?");return e}).bind(dt),dt.updatedBy=(t=>{const e=dt.get("function"!=typeof t?t.constructor:t,Ct.UPDATED_BY);if(!e)throw new u("No updatedBy metadata found for model. did you use @updatedBy()?");return e}).bind(dt),z.tableName=t=>{if(!(t instanceof z?z.get(t.constructor.name):t))throw new u("Unable to find model "+t);return dt.get(t instanceof z?t.constructor:t,Ct.TABLE)||(t instanceof z?t.constructor.name:t.name)},z.columnName=(t,e)=>dt.get(t instanceof z?t.constructor:t,dt.key(Ct.COLUMN,e))||e,z.defaultQueryAttributes=(t,e=!1)=>{const r="function"==typeof t?t:t.constructor;return dt.get(r,dt.key(Ct.DEFAULT_QUERY_ATTR))||(e?[z.pk(t)]:[])},z.sequenceName=(t,...e)=>[z.tableName(t),...e].join("_"),z.versionOf=(t=>{const e=dt.get(t.constructor),r=e?.[Ct.PERSISTENT_VERSION],s=r&&"object"==typeof r?Object.keys(r)[0]:void 0,i=e?.[v.VERSION],n=i&&"object"==typeof i?Object.keys(i)[0]:void 0,o=s??n;if(!o)throw new u("No version found for "+t.constructor.name);const a=t[o];if("number"!=typeof a||1>a)throw new u("Invalid version number: "+a);return a}).bind(z),z.sequenceFor=(t,e)=>{const r="function"!=typeof t?t.constructor:t;let s=Ct.SEQUENCE;const i=z.pk(r);e&&e+""!=i+""||(e=i,s=v.ID),s=dt.key(s,e);const n=dt.get(r,s);if(!n)throw new u(`No sequence options defined for property ${e+""}. did you use @sequence() or @pk()?`);return n},z.indexes=t=>{const e=dt.get(t instanceof z?t.constructor:t,Ct.INDEX);return Object.keys(e||{}).reduce((t,r)=>(t[r]={[Ct.INDEX]:e[r]},t),{})},e.services=()=>dt.innerGet(Symbol.for(Ct.SERVICE)),e.repositories=()=>dt.innerGet(Symbol.for(v.REPOSITORY)),z.merge=((t,e,r)=>{const s=t=>Object.entries(t).reduce((t,[e,s])=>{let i=!1;try{"relation.one-to-one"===z.relations(r,e).key&&(i=!0)}catch(t){i=!1}return(void 0!==s||i)&&(t[e]=s),t},{});return new(r=r||t.constructor)(Object.assign({},s(t),s(e)))}).bind(z);class Ye extends u{constructor(t){super(t,Ye.name,500)}}var ze;function qe(t,...e){return(r,s,i)=>{i.value=new Proxy(i.value,{async apply(r,s,i){const{ctx:n,ctxArgs:o}=await s.logCtx(i,r.name,!0);let a;try{a=t(...i,...e,n)}catch(t){throw new u("Failed to execute auth validation handler: "+t)}if(a)throw a;return r.call(s,...o)}})}}function He(t,...e){return(r,s,i)=>{i.value=new Proxy(i.value,{async apply(r,s,i){const{ctx:n,ctxArgs:o}=await s.logCtx(i,r.name,!0);let a;try{a=t(...i,...e,n)}catch(t){throw new u("Failed to execute auth validation handler: "+t)}if(a)throw a;return r.call(s,...o)}})}}(t=>{t.AUTH="auth",t.ROLES="roles",t.NAMESPACE="namespace"})(ze||(ze={}));const Ve={type:void 0,generated:!1,startWith:0,incrementBy:1,cycle:!1},Qe=Ve,We={type:Number,generated:!0,startWith:0,incrementBy:1,cycle:!1},Je=Object.assign({},We,{type:"BigInt"});function Xe(t,e,r){return ht.for(Ct.INDEX).define({decorator:(t,e,r)=>(s,i)=>("string"==typeof t&&(r=t,t=void 0,e=void 0),"string"==typeof e&&(r=e,e=void 0),!e&&t&&t.find(t=>![oe.ASC,oe.DSC].includes(t))&&(e=t,t=void 0),yt(dt.key(`${Ct.INDEX}${e&&e?.length?"."+e.join("."):""}`,i),{directions:t,compositions:e,name:r})(s,i)),args:[t,e,r]}).apply()}function Ke(t){return"function"==typeof t}function Ze(t,e,r){if(!r.type){const s=dt.type(t.constructor,e);if(![Number.name,String.name,BigInt.name].includes(s?.name||s))throw Error("Incorrrect option type");r.type=s}switch(r.type){case String.name||String.name.toLowerCase():case String:r.generated=void 0!==r.generated&&r.generated,r.type=String;break;case Number.name||String.name.toLowerCase():case Number:r.generated=void 0===r.generated||r.generated,r.type=Number;break;case BigInt.name||BigInt.name.toLowerCase():case BigInt:r.type=BigInt,r.generated=void 0===r.generated||r.generated;break;case"uuid":case"serial":r.generated=!0;break;default:throw Error("Unsupported type")}void 0===r.generated&&(r.generated=!0)}async function tr(t,e,r,s){if(!e.type||!e.generated||s[r])return;let i;e.name||(e.name=z.sequenceName(s,"pk"));try{i=await this.adapter.Sequence(e,this._overrides)}catch(t){throw new u(`Failed to instantiate Sequence ${e.name}: ${t}`)}var n,o,a;n=s,o=r,a=await i.next(t),Reflect.set(n,o,a)}async function er(t,e,r,s,i){if(!e.type||!e.generated)return;if(!e.name){const t=z.pk(s,!0);if(null==t)throw new u("Cannot generate sequence without an id for "+s.constructor.name);e.name=z.sequenceName(s,t+"",r+"")}let n;try{n=await this.adapter.Sequence(e,this._overrides)}catch(t){throw new u(`Failed to instantiate Sequence ${e.name}: ${t}`)}const o=null!=i,a=void 0!==s[r]&&null!==s[r],c=!!t.get("allowGenerationOverride")&&a;if(a&&await n.ensureAtLeast(s[r],t),o&&!e.update)return;if(c)return;const l=await n.next(t);Reflect.set(s,r,l)}function rr(t,e){return(r,s)=>{bt()(r,s),Ze(r,s,t),t.name||(t.name=((t,e)=>Ke(z.sequenceName)?z.sequenceName(t,e):[Ke(z.tableName)?z.tableName(t):t?.name??"",e].filter(Boolean).join("_"))(r.constructor,"pk"));const i=[yt(dt.key(v.ID,s),t),yt(dt.key(Ct.SEQUENCE,s),t),Xe([oe.ASC,oe.DSC]),H(),b(),A(tr,t,e)];return t.generated&&i.push(x()),gt(...i)(r,s)}}function sr(t,e={},r){return(s,i)=>{bt()(s,i),Ze(s,i,t);const n=[H(),yt(dt.key(Ct.SEQUENCE,i),t),A(er,{...t,...e},r)];return e.update&&n.push(E(er,{...t,...e},r)),t.generated&&n.push(x()),gt(...n)(s,i)}}function ir(t){const e=Object.assign({},Qe);return delete e.generated,t=Object.assign({},e,t),ht.for(v.ID).define({decorator:rr,args:[t,{priority:60}]}).apply()}function nr(t,e){const r=Object.assign({},Qe);delete r.generated,t=Object.assign({},r,t);const s="boolean"==typeof e?{update:e}:e||{};return ht.for(Ct.SEQUENCE).define({decorator:sr,args:[t,s,{priority:70}]}).apply()}async function or(t,e,r,s,i){const n=e.logger.for(or);if(!s){const e=z.get(t.constructor.name);if(!e)throw new u("Could not find model "+t.constructor.name);s=Fe.forModel(e,r),n.info("Retrieved "+s.toString())}let o;if(s=i?s.override(i):s,void 0===t[z.pk(s.class)])n.info(`No pk found in ${z.tableName(s.class)} - creating`),o=await s.create(t,e);else{n.info(`pk found in ${z.tableName(s.class)} - attempting update`);try{o=await s.update(t,e),n.info("Updated "+z.tableName(s.class))}catch(r){if(!(r instanceof m))throw r;n.info("update Failed - creating new "+z.tableName(s.class)),o=await s.create(t,e)}n.info("After create update: "+o)}return o}async function ar(t,e,r,s){const i=s[r];if(!i)return;if(gr(s,e),"object"!=typeof i){const e=Tr(s,r,this.adapter.alias),n=await e.override(this._overrides).read(i,t);return await Er(t,s,r,i,n),void(s[r]=i)}const n="function"!=typeof e.class||e.class.name?e.class:e.class();if(!n)throw new u("Could not find model "+e.class);const o=Fe.forModel(n,this.adapter.alias),a=await o.override(this._overrides).create(i,t),c=z.pk(a);await Er(t,s,r,a[c],a),s[r]=a[c]}async function cr(t,e,r,s){const i=s[r];if(!i)return;if(e.cascade.update!==ae.CASCADE)return;if("object"!=typeof i){const e=Tr(s,r,this.adapter.alias),n=await e.override(this._overrides).read(i,t);return await Er(t,s,r,i,n),void(s[r]=i)}const n=await or(s[r],t,this.adapter.alias,void 0,this._overrides),o=z.pk(n);await Er(t,s,r,n[o],n),s[r]=n[o]}async function lr(t,e,r,s){const i=s[r];if(null==i)return;if(e.cascade.delete!==ae.CASCADE)return;const n=Tr(s,r,this.adapter.alias);let o;o=i instanceof z?await n.delete(s[r][n.pk],t):await n.delete(s[r],t),await Er(t,s,r,o[n.pk],o)}async function ur(t,e,r,s,i){const n=s[r];if(!n||!n.length)return;gr(s,e);const o=t.logger.for(ur),a=Tr(s,r,this.adapter.alias),c=z.pk("function"!=typeof e.class||e.class.name?e.class:e.class()),l=new Set;for(const e of n){let i;"object"!=typeof e?(i=await a.override(this._overrides).read(e,t),o.debug("read: "+i[c])):(o.verbose("Creating or updating one-to-many model: "+e[c]),i=await or(e,t,this.adapter.alias,void 0,this._overrides)),o.debug(`caching for populate: ${JSON.stringify(i)} under ${i[c]}`),await Er(t,s,r,i[c],i),l.add(i[c])}s[r]=[...l]}async function dr(t,e,r,s,i){const{cascade:n}=e;if(n.update===ae.CASCADE)return ur.call(this,t,e,r,s,i)}async function hr(t,e,r,s){if(e.cascade.delete!==ae.CASCADE)return;const i=s[r];if(!i)return;const n=typeof i[0];if(!i.every(t=>typeof t===n))throw new u(`Invalid operation. All elements of property ${r} must match the same type.`);const o="function"!=typeof e.class||e.class.name?e.class:e.class(),a="object"===n,c=a?Fe.forModel(o,this.adapter.alias):Tr(s,r,this.adapter.alias),l=[...new Set([...a?i.map(t=>t[c.pk]):i]).values()];let d,h;try{d=await c.override(this._overrides).deleteAll(l,t)}catch(e){throw t.logger.error("Failed to delete all records",e),e}for(let e=0;e<d.length;e++){h=d[e];try{await Er(t,s,r,l[e],h)}catch(i){throw t.logger.error(`Failed to cache record ${l[e]} with key ${r} and model ${JSON.stringify(s,void 0,2)} `,i),i}}s[r]=l}async function pr(t,e,r,s){const i=s[r];if(!i)return;gr(s,e);const n=t.logger.for(pr);if("object"!=typeof i){const e=Tr(s,r,this.adapter.alias),n=await e.override(this._overrides).read(i,t);return await Er(t,s,r,i,n),void(s[r]=i)}if(!(e.class instanceof z?e.class.constructor:e.class))throw new u("Could not find model "+e.class);n.info("Creating or updating many-to-one model: "+JSON.stringify(i));const o=await or(i,t,this.adapter.alias,void 0,this._overrides),a=z.pk(o);n.info(`caching: ${JSON.stringify(o)} under ${o[a]}`),await Er(t,s,r,o[a],o),s[r]=o[a]}function gr(t,e){let r;const s="function"==typeof e.class&&e.class.name?e.class:e.class(),i=dt.get(s,Ct.RELATIONS);if(i&&(r=Object.values(i)?.find(e=>{const r="function"==typeof e.class&&e.class.name?e.class:e.class();return t instanceof r})),!0===r?.populate&&!0===e?.populate)throw new u("Bidirectional populate is not allowed. Please set populate to false on one side of the relation.");return!0}async function fr(t,e,r,s){const{cascade:i}=e;if(i.update===ae.CASCADE)return pr.call(this,t,e,r,s)}async function yr(t,e,r,s){if(e.cascade.delete!==ae.CASCADE)return;const i=s[r];if(!i)return;const n="object"==typeof i,o=n?Fe.forModel(i,this.adapter.alias):Tr(s,r,this.adapter.alias),a=n?i[o.pk]:i,c=await o.override(this._overrides).delete(a);await Er(t,s,r,a,c),s[r]=a}async function mr(t,e,r,s){const i=s[r];if(!i||!i.length)return;gr(s,e);const n=typeof i[0];if(!i.every(t=>typeof t===n))throw new u(`Invalid operation. All elements of property ${r} must match the same type.`);const o=t.logger.for(mr),a=new Set([...i]);if("object"!==n){const n=Tr(s,r,this.adapter.alias),c=await n.override(this._overrides).readAll([...a.values()],t);for(let e=0;e<c.length;e++){const s=c[e];o.info("FOUND MANY TO MANY VALUE: "+JSON.stringify(s)),await Er(t,s,r,[...a.values()][e],c)}return await wr.call(this,s,[...i],o,t,e),s[r]=[...a],void o.info("SET MANY TO MANY IDS: "+s[r])}const c=z.pk(i[0].constructor),l=new Set;for(const e of i){o.info("Creating or updating many-to-many model: "+JSON.stringify(e));const i=await or(e,t,this.adapter.alias,void 0,this._overrides);o.info(`caching: ${JSON.stringify(i)} under ${i[c]}`),await Er(t,s,r,i[c],i),o.info("Creating or updating many-to-many model: "+JSON.stringify(e)),e.id=i.id,l.add(i[c])}const d=z.pk(s.constructor);if(void 0===s[d]){const e=await(async(t,e,r)=>{const s=e[z.pk(e.constructor)];if(void 0!==s)return s;const i=z.sequenceFor(e.constructor);let n;i?.name||(i.name=z.sequenceName(e,"pk"));try{return n=await t.adapter.Sequence(i,t._overrides),await n.next(r)}catch(t){throw new u(`Failed to instantiate Sequence ${i.name}: ${t}`)}})(this,s,t);s[d]=e}const h=await wr.call(this,s,i,o,t,e);o.info("Junction model created: "+h.name),s[r]=[...l]}async function wr(t,e,r,s,i){const{JunctionModel:n,fkA:o,fkB:a}=vr(t,e[0],i),c=[];for(const i of e){r.info("Creating or updating many-to-many junction model: "+JSON.stringify(i));const e={[o]:t instanceof z?t[z.pk(t.constructor)]:t,[a]:i instanceof z?i[z.pk(i.constructor)]:i},l=await or(new n(e),s,this.adapter.alias,void 0,this._overrides);l?.id&&c.push(l.id)}if(c.length===e?.length){const t=Fe.forModel(n);await(t?.override(this._overrides).readAll(c))}return n}function vr(t,e,r){const s=z.tableName(t);let i;if(e instanceof z)i=z.tableName(e);else if(z.isModel(e)&&"function"==typeof e)i=e.name?e.name:e()?.name;else if(r?.class){const t="function"!=typeof r.class||r.class.name?r.class:r.class();i=z.tableName(t)}if(!s||!i)throw new u("Missing tablenames to create junction table");const n=r?.joinTable?.name?r?.joinTable?.name:`${s}_${i}`,o=s?.toLowerCase()+"_fk",a=i?.toLowerCase()+"_fk",c=class extends z{constructor(t){super(t)}};Object.defineProperty(c,"name",{value:n,writable:!1}),ir({type:Number})(c.prototype,"id"),H()(c.prototype,o),H()(c.prototype,a);const l=W()(c);return dt.set(c,Ct.TABLE,n),{fkA:o,fkB:a,JunctionModel:l}}async function br(t,e,r,s){const{cascade:i}=e;if(i.update===ae.CASCADE)return mr.call(this,t,e,r,s)}async function Ar(t,e,r,s){if(e.cascade.delete!==ae.CASCADE)return;const i=s[r];if(!i||!i.length)return;const n=typeof i[0];if(!i.every(t=>typeof t===n))throw new u(`Invalid operation. All elements of property ${r} must match the same type.`);const o="function"!=typeof e.class||e.class.name?e.class:e.class(),a="object"===n,c=a?Fe.forModel(o,this.adapter.alias):Tr(s,r,this.adapter.alias),l=[...new Set([...a?i.map(t=>t[c.pk]):i]).values()];let d,h;try{d=await c.override(this._overrides).deleteAll(l,t)}catch(e){throw t.logger.error("Failed to delete all records",e),e}for(let e=0;e<d.length;e++){h=d[e];try{await Er(t,s,r,l[e],h)}catch(i){throw t.logger.error(`Failed to cache record ${l[e]} with key ${r} and model ${JSON.stringify(s,void 0,2)} `,i),i}}s[r]=l}function Sr(t,e,r){return e?[Ct.POPULATE,t,e,r].join("."):[Ct.POPULATE,t,r].join(".")}function xr(t,e,r){return[Ct.TAG_FOR_DELETION,t,r].join(".")}async function Er(t,e,r,s,i){const n=Sr(e.constructor.name,r,s),o=t.logger.for(Er),a=t.get("cacheForPopulate")||{};let c=a[n],l=t.getOrUndefined("preferFromCache");if(!l)try{o.silly("retrieving from children"),l=t.getFromChildren("preferFromCache")||!1,l&&(c=(t.getFromChildren("cacheForPopulate")||{})[n])}catch(t){l=!1}return l&&o.debug("preferring previous cache: "+!!a[n]),a[n]=l&&c?c:i,t.accumulate({cacheForPopulate:a})}async function Or(t,e,r,s){if(!e.populate)return;const i=s[r],n=Array.isArray(i);if(void 0===i||n&&0===i.length)return;const o=this,l=await(async(e,r,s,i)=>{let n,l;const d=[];let h;try{h=e.get("operation")}catch(t){h=void 0}const p=h===a.READ||h===c.READ_ALL?{}:e.get("cacheForPopulate")||{};for(const e of i){n=Sr(r.constructor.name,s,e);try{if(l=p[n],!l)throw Error("Not found in cache")}catch(i){const n=Tr(r,s,o.adapter.alias);if(!n)throw new u("Could not find repo");l=await n.override(o._overrides).read(e,t)}d.push(l)}return d})(t,s,r,n?i:[i]);s[r]=n?l:l[0]}async function kr(t,e,r,s,i){if(e.cascade.update!==ae.CASCADE)return;if(!i)throw new u("No way to compare old model. do you have updateValidation and mergeModels enabled?");function n(t){return Array.isArray(t)?t.map(n):"object"!=typeof t?t:t[z.pk(t)]}const o=n(s[r]),a=n(i[r]);if(void 0===a||Q(o,a))return;if(Array.isArray(o)!==Array.isArray(a))throw new u("Cannot cascade update for different array types");const c=(Array.isArray(o)?o:[o]).filter(Boolean),l=(Array.isArray(a)?a:[a]).filter(Boolean).filter(t=>!c.includes(t)),d=Tr(s,r,this.adapter.alias);if(!d)throw new u("Could not find repo");try{const e=await d.override(this._overrides).deleteAll(l,t);t.logger.debug(`Deleted ${e.length} entries from table ${z.tableName(d.class)} due to cascade rules with `)}catch(t){throw new u("Error deleting cascade entries: "+t)}}const Cr=["array","string","number","boolean","symbol","function","object","undefined","null","bigint"];function Tr(t,e,r){if(!t)throw Error("No model was provided to get repository");let s,i=t instanceof z?t.constructor:t;if(Array.isArray(t[e])||t[e]instanceof Set){const t=dt.get(i,dt.key(J.REFLECT,e,J.LIST))?.clazz;if(!t)throw new u("Failed to find types decorators for property "+e);s=(Array.isArray(t)?[...t]:[t]).map(t=>"function"!=typeof t||t.name?t:t())}else s=z.relations(i).includes(e)?dt.allowedTypes(i,e):dt.getPropDesignTypes(t instanceof z?t.constructor:t,e)?.designTypes;i=s?.find(t=>!Cr.includes((""+t.name).toLowerCase()));const n=Fe.forModel(i,r);if(i!==n.class)throw new u("Invalid repository class for "+e);return n}class Nr extends O{constructor(t,e=Nr.name,r=401){super(t,e,r)}}class Dr extends Nr{constructor(t,e=Dr.name){super(t,e,403)}}class _r extends u{constructor(t){super(t,_r.name,503)}}function Ir(t){return ht.for(Ct.TABLE).define({decorator:t=>e=>(dt.set(Ct.TABLE,t||e.name.toLowerCase(),e),vt(Ct.TABLE,t||e.name.toLowerCase())(e)),args:[t]}).apply()}function Br(t){return ht.for(Ct.COLUMN).define({decorator:t=>(e,r)=>yt(dt.key(Ct.COLUMN,r),t||r)(e,r),args:[t]}).apply()}async function Pr(t,e,r,s){if(s[r]&&(await this.select().where(ne.attribute(r).eq(s[r])).execute()).length)throw new T(`model already exists with property ${r} equal to ${JSON.stringify(s[r],void 0,2)}`)}function Rr(){const t=Ct.UNIQUE;return ht.for(t).define(Z(),C(Pr),yt(t,{})).apply()}async function $r(t,e,r,s){throw new Nr("This adapter does not support user identification")}function Fr(){return ht.for(Ct.CREATED_BY).define({decorator:()=>(t,e)=>gt(A($r),yt(Ct.CREATED_BY,e),x(Ct.CREATED_BY))(t,e),args:[]}).apply()}function Lr(){return ht.for(Ct.UPDATED_BY).define({decorator:()=>(t,e)=>gt(E($r),yt(Ct.UPDATED_BY,e),x(Ct.UPDATED_BY))(t,e),args:[]}).apply()}function Mr(){return k([a.CREATE])}function jr(){return k()}async function Ur(t,e,r,s){if("??sequence"===z.tableName(s))return;const i=z.pk(s,!0);if(null==i)throw new u("Cannot generate persistent version without an id for "+s.constructor.name);const n={name:z.sequenceName(s,i+"",r+""),type:Number,generated:!0,startWith:0,incrementBy:1,cycle:!1},o=await this.adapter.Sequence(n,this._overrides),a=void 0!==s[r]&&null!==s[r],c=!!t.get("allowGenerationOverride")&&a;if(a&&(await o.ensureAtLeast(s[r],t),c))return;const l=await o.next(t);s[r]=l}async function Gr(t,e,r,s,i){if("??sequence"===z.tableName(s))return;if(t.get("applyUpdateValidation")&&i&&s[r]!==i[r])throw new d(`Version mismatch: ${s[r]} !== ${i[r]}`);const n=z.pk(s,!0);if(null==n)throw new u("Cannot generate persistent version without an id for "+s.constructor.name);const o={name:z.sequenceName(s,n+"",r+""),type:Number,generated:!0,startWith:0,incrementBy:1,cycle:!1},a=await this.adapter.Sequence(o,this._overrides),c=void 0!==s[r]&&null!==s[r],l=!!t.get("allowGenerationOverride")&&c;if(c&&(await a.ensureAtLeast(s[r],t),l))return;const h=await a.next(t);s[r]=h}function Yr(){const t=Ct.PERSISTENT_VERSION;return(e,r)=>ht.for(t).define(bt(),yt(dt.key(t,r),!0),x(t),X(Number),A(Ur,{},{priority:70}),E(Gr,{},{priority:70})).apply()(e,r)}function zr(t=!1){return t?Yr():N()}function qr(t){return[()=>{const e="function"==typeof t&&t.name?t:t(),r=z.pk(e);return(dt.allowedTypes(e,r)||[])[0]}]}function Hr(t,e=ce,r=!0,s,i){const n=Ct.ONE_TO_ONE;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),X([t,...a]),A(ar,o,{priority:70}),E(cr,o,{priority:70}),_(lr,o,{priority:70}),E(kr,o,{priority:80}),D(Or,o,{priority:70})];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Vr(t,e=ce,r=!0,s,i){const n=Ct.ONE_TO_MANY;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),tt([t,...a]),A(ur,o,{priority:70}),E(dr,o,{priority:70}),_(hr,o,{priority:70}),E(kr,o,{priority:80}),D(Or,o,{priority:70})];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Qr(t,e=ce,r=!0,s,i){const n=Ct.MANY_TO_ONE;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),X([t,...a]),A(pr,o),E(fr,o),_(yr,o),D(Or,o)];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Wr(t,e=ce,r=!0,s,i){const n=Ct.MANY_TO_MANY;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),tt([t,...a]),A(mr,o),E(dr,o),D(Or,o)];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Jr(...t){return(e,r)=>{const s=dt.get(e,dt.key(Ct.NO_VALIDATE,r))||[],i=[...new Set([...s,...t])];return gt(vt(dt.key(Ct.NO_VALIDATE,r),i))(e,r)}}function Xr(){return Jr(a.CREATE)}function Kr(){return Jr(a.UPDATE)}function Zr(){return Jr(a.UPDATE,a.CREATE)}function ts(t,e){return ht.for(Ct.RELATIONS).define({decorator:(t,e)=>(r,s)=>(yt(t,e)(r,s),yt(dt.key(Ct.RELATIONS,s),Object.assign({},e,{key:t}))(r,s)),args:[t,e]}).apply()}class es extends z{constructor(t){super(t)}}i([Mr(),n("design:type",Date)],es.prototype,"createdAt",void 0),i([jr(),n("design:type",Date)],es.prototype,"updatedAt",void 0);let rs=class extends es{constructor(t){super(t)}};i([ir({type:String,generated:!1}),n("design:type",String)],rs.prototype,"id",void 0),i([H(),Xe(),n("design:type",Object)],rs.prototype,"current",void 0),rs=i([Ir("??sequence"),W(),n("design:paramtypes",[Object])],rs);class ss extends M{get current(){return this._currentPage}get total(){return this._totalPages}get count(){return this._recordCount}get statement(){return this._statement||(this._statement=this.prepare(this.query)),this._statement}constructor(t,e,r,s){super(),this.adapter=t,this.query=e,this.size=r,this.clazz=s,Qt(this,this.page,this.pagePrefix,this.page.name)}isPreparedStatement(){const t=this.query;return t.method&&t.method.match(RegExp(`${kt.FIND_BY}|${kt.FIND_BY_PAGINATE}|${kt.LIST_BY}|${kt.PAGE_BY}|${kt.FIND}`,"gi"))}async pagePrefix(t,...e){const{ctxArgs:r}=(await this.adapter.logCtx([this.clazz,...e],kt.PAGE_BY,!0)).for(this.pagePrefix);return r.shift(),[t,...r]}async pagePrepared(t,e,...r){const{log:s,ctxArgs:i}=this.adapter.logCtx(!e||e instanceof Rt?[e,...r]:[...r],this.pagePrepared);s.debug(`Running paged prepared statement ${t} page${e?" - bookmark "+e:""}`),!e||e instanceof Rt||(this._bookmark=e);const n=Fe.forModel(this.clazz,this.adapter.alias),o=this.query,{method:a,args:c,params:l}=o;if(a===kt.FIND){const e=[kt.PAGE,...c],r={limit:this.size,offset:t,bookmark:this._bookmark};e.push(r);const s=await n.statement(...e,...i);return this.apply(s)}let u;if(a===kt.FIND_BY?u=kt.FIND_BY_PAGINATE:a.startsWith(kt.FIND_BY)?u=a.replace(kt.FIND_BY,kt.PAGE_BY):a===kt.LIST_BY?u=kt.PAGE_BY:a!==kt.PAGE_BY&&a!==kt.FIND_BY_PAGINATE||(u=a),!u)throw new Mt(`Method ${a} is not supported for pagination`);const d=[u,...c];let h={limit:this.size,offset:t,bookmark:this._bookmark};u!==kt.PAGE_BY||d.length>2?h={direction:l.direction,limit:this.size,offset:t,bookmark:this._bookmark}:d.push(l.direction),d.push(h);const p=await n.statement(...d,...i);return this.apply(p)}async next(...t){return this.page(this.current+1,...t)}async previous(...t){return this.page(this.current-1,...t)}validatePage(t){if(1>t||!Number.isInteger(t))throw new ie("Page number cannot be under 1 and must be an integer");if(void 0!==this._totalPages&&t>this._totalPages)throw new ie(`Only ${this._totalPages} are available. Cannot go to page ${t}`);return t}async page(t=1,e,...r){const{ctxArgs:s}=this.adapter.logCtx([e,...r],this.page);if(this.isPreparedStatement())return await this.pagePrepared(t,...s);throw new Mt("Raw support not available without subclassing this")}serialize(t,e=!1){const r={data:t,current:this.current,total:this.total,count:this.count,bookmark:this._bookmark};try{return e?JSON.stringify(r):r}catch(t){throw new I(t)}}apply(t){const e="string"==typeof t?ss.deserialize(t):t;return this._currentPage=e.current,this._totalPages=e.total||this._totalPages,this._recordCount=e.count||this._recordCount,this._bookmark=e.bookmark,e.data}static deserialize(t){try{return JSON.parse(t)}catch(t){throw new I(t)}}static isSerializedPage(t){return t&&"object"==typeof t&&Array.isArray(t.data)&&"number"==typeof t.total&&"number"==typeof t.current&&"number"==typeof t.count}}var is,ns,os,as,cs,ls,us;class ds extends $t{constructor(t,e){super(),this.adapter=t,this.overrides=e,this._inCountMode=!1,[this.execute,this.paginate].forEach(t=>{B(this,t,(...e)=>this.executionPrefix(t,...e),t.name)})}async executionPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.adapter.logCtx([this.fromSelector,...e],t.name===this.paginate.name?kt.PAGE_BY:Ct.QUERY,!0,this.overrides||{})).for(t);s.shift();const n=r.get("forcePrepareSimpleQueries"),o=r.get("forcePrepareComplexQueries");i.silly(`statement force simple ${n}, forceComplex: ${o}`);const a=this.hasAggregation()&&!this.whereCondition&&!this.selectSelector?.length&&1>=(this.groupBySelectors?.length||0);return(n&&(this.isSimpleQuery()||a)||o)&&(i.silly(`squashing ${o?"complex":"simple"} query to prepared statement`),await this.prepare(r),i.silly(`squashed ${o?"complex":"simple"} query to ${JSON.stringify(this.prepared,null,2)}`)),s}get log(){return this.adapter.log.for(ds)}select(t){return Object.defineProperty(this,"selectSelector",{value:t,writable:!1}),this}distinct(t){if(this._inCountMode)return this.countDistinctSelector=this.countSelector,this.countSelector=void 0,this._inCountMode=!1,this;if(!t)throw new se("distinct() requires a selector when not chained after count()");return this.distinctSelector=t,this}max(t){return this.maxSelector=t,this}min(t){return this.minSelector=t,this}sum(t){return this.sumSelector=t,this}avg(t){return this.avgSelector=t,this}count(t){return this.countSelector=t??null,this._inCountMode=!0,this}from(t){if(this.fromSelector="string"==typeof t?z.get(t):t,!this.fromSelector)throw new se("Could not find selector model: "+t);return this}where(t){return this.whereCondition=t,this}orderBy(t,e){return this.orderBySelectors=[this.normalizeOrderCriterion(t,e)],this}thenBy(t,e){if(Array.isArray(t)||void 0!==e){if(!this.orderBySelectors||!this.orderBySelectors.length)throw new se("thenBy requires orderBy to be called first");return this.orderBySelectors.push(this.normalizeOrderCriterion(t,e)),this}if(!this.groupBySelectors||!this.groupBySelectors.length)throw new se("groupBy must be called before chaining group selectors");return this.groupBySelectors.push(t),this}normalizeOrderCriterion(t,e){if(Array.isArray(t)){const[e,r]=t;return[e,this.normalizeOrderDirection(r)]}return[t,this.normalizeOrderDirection(e)]}normalizeOrderDirection(t){if(!t)throw new se("orderBy direction is required when specifying the attribute separately.");const e=(t+"").toLowerCase();if(e===oe.ASC)return oe.ASC;if(e===oe.DSC)return oe.DSC;throw new se(`Invalid OrderBy direction ${t}. Expected one of: ${Object.values(oe).join(", ")}.`)}groupBy(t){if(this.orderBySelectors&&this.orderBySelectors.length)throw new se("groupBy must be called before orderBy.");return this.groupBySelectors=[t],this}limit(t){return this.limitSelector=t,this}offset(t){return this.offsetSelector=t,this}async execute(...t){const{log:e,ctx:r,ctxArgs:s}=this.logCtx(t,this.execute);try{if(this.prepared)return this.executePrepared(...t);e.silly("Building raw statement...");const i=this.build();e.silly("executing raw statement");const n=await this.raw(i,...s);if(this.hasAggregation())return n;if(!this.selectSelector){const t=t=>this.processRecord(t,r);if(this.groupBySelectors?.length){const e=this.revertGroupedResults(n,t);return await this.applyAfterHandlersToResult(e,r)}if(Array.isArray(n)){const e=n.map(t);return await this.applyAfterHandlersToResult(e,r)}const e=t(n);return await this.applyAfterHandlersToResult(e,r)}return n}catch(t){throw new se(t)}}revertGroupedResults(t,e){return Array.isArray(t)?t.map(e):t&&"object"==typeof t?Object.entries(t).reduce((t,[r,s])=>(t[r]=this.revertGroupedResults(s,e),t),{}):t}async executePrepared(...t){const e=Fe.forModel(this.fromSelector,this.adapter.alias),{method:r,args:s,params:i}=this.prepared;return e.statement(r,...s,i,...t)}async raw(t,...e){const{ctx:r,ctxArgs:s}=this.logCtx(e,this.raw);if(!r.get("allowRawStatements"))throw new Mt("Raw statements are not allowed in the current configuration");const i=await this.adapter.raw(t,!0,...s);if(this.hasAggregation())return i;if(!this.selectSelector)return i;const n=t=>this.processRecord(t,r);if(Array.isArray(i)){const t=i.map(n);return await this.applyAfterHandlersToResult(t,r)}const o=n(i);return await this.applyAfterHandlersToResult(o,r)}processRecord(t,e){const r=t[z.pk(this.fromSelector)];return this.adapter.revert(t,this.fromSelector,r,void 0,e)}async applyAfterHandlersToResult(t,e){return e.getOrUndefined("afterQueryHandlers")?t instanceof z?(await f(this.getRepository(),e,t,a.READ,a.AFTER),t):Array.isArray(t)?(await Promise.all(t.map(t=>this.applyAfterHandlersToResult(t,e))),t):t&&"object"==typeof t?(await Promise.all(Object.entries(t).map(([r,s])=>this.applyAfterHandlersToResult(s,e).then(e=>{t[r]=e}))),t):t:t}getRepository(){return Fe.forModel(this.fromSelector,this.adapter.alias)}prepareCondition(t,e){let{attr1:r,operator:s,comparison:i}=t;const n={};switch(s){case Ot.AND:case Ot.OR:{let t=r,o=i;if("string"!=typeof r){const s=this.prepareCondition(r,e);t=s.method,n.args=[...n.args||[],...s.args||[]]}if(i instanceof ne){const t=this.prepareCondition(i,e);o=t.method,n.args=[...n.args||[],...t.args||[]]}n.method=`${t} ${s.toLowerCase()} ${o}`;break}case Et.EQUAL:n.method=r,n.args=[...n.args||[],i];break;case Et.DIFFERENT:n.method=r+" diff",n.args=[...n.args||[],i];break;case Et.REGEXP:n.method=r+" matches",n.args=[...n.args||[],i];break;case Et.BIGGER:n.method=r+" bigger",n.args=[...n.args||[],i];break;case Et.BIGGER_EQ:n.method=r+" bigger than equal";break;case Et.SMALLER:n.method=r+" less",n.args=[...n.args||[],i];break;case Et.SMALLER_EQ:n.method=r+" less than equal",n.args=[...n.args||[],i];break;case Et.IN:n.method=r+" in",n.args=[...n.args||[],i];break;default:throw new se("Unsupported operator "+s)}return n}squash(t){const e=this.matchDefaultQueryCondition();if(e){const t=this.getOrderDirection();return{class:this.fromSelector,method:kt.FIND,args:[e.value,t],params:{direction:t}}}if(this.whereCondition&&this.whereCondition.comparison instanceof ne)return;if(!this.whereCondition&&!this.selectSelector?.length){if(void 0!==this.countSelector&&!this.countDistinctSelector)return{class:this.fromSelector,method:kt.COUNT_OF,args:null!==this.countSelector?[this.countSelector]:[],params:{}};if(this.maxSelector)return{class:this.fromSelector,method:kt.MAX_OF,args:[this.maxSelector],params:{}};if(this.minSelector)return{class:this.fromSelector,method:kt.MIN_OF,args:[this.minSelector],params:{}};if(this.avgSelector)return{class:this.fromSelector,method:kt.AVG_OF,args:[this.avgSelector],params:{}};if(this.sumSelector)return{class:this.fromSelector,method:kt.SUM_OF,args:[this.sumSelector],params:{}};if(this.distinctSelector)return{class:this.fromSelector,method:kt.DISTINCT_OF,args:[this.distinctSelector],params:{}};if(1===this.groupBySelectors?.length)return{class:this.fromSelector,method:kt.GROUP_OF,args:[this.groupBySelectors[0]],params:{}}}if(this.selectSelector&&this.selectSelector.length)return;if(this.groupBySelectors&&this.groupBySelectors.length)return;if(void 0!==this.countSelector)return;if(this.countDistinctSelector)return;if(this.maxSelector)return;if(this.minSelector)return;if(this.sumSelector)return;if(this.avgSelector)return;let r;this.whereCondition&&(r=this.whereCondition.attr1);const s=this.orderBySelectors?.[0]?this.orderBySelectors[0]:r?[r,oe.DSC]:[z.pk(this.fromSelector),oe.DSC],[i,n]=s,o={direction:n};this.limitSelector&&(o.limit=this.limitSelector),this.offsetSelector&&(o.offset=this.offsetSelector);const a={class:this.fromSelector,method:kt.LIST_BY,args:[i],params:o};return r&&(a.method=kt.FIND_BY,a.args=[r,this.whereCondition.comparison],a.params=o),a}matchDefaultQueryCondition(){if(!this.whereCondition)return;const t=this.extractDefaultStartsWithAttributes(this.whereCondition);if(!t)return;const e=z.defaultQueryAttributes(this.fromSelector);if(!e||!e.length)return;const r=Array.from(new Set(e.map(String))),s=Array.from(new Set(t.attributes.map(String)));return r.length===s.length&&r.every(t=>s.includes(t))?{value:t.value,attributes:r}:void 0}extractDefaultStartsWithAttributes(t){const e=this.collectStartsWithAttributes(t);if(e)return{attributes:Array.from(new Set(e.attributes)),value:e.value}}collectStartsWithAttributes(t){if(!t)return;const{attr1:e,operator:r,comparison:s}=t;if(r===Et.STARTS_WITH){if("string"!=typeof e||"string"!=typeof s)return;return{attributes:[e],value:s}}if(r===Ot.OR){const t=e instanceof ne?this.collectStartsWithAttributes(e):void 0,r=s instanceof ne?this.collectStartsWithAttributes(s):void 0;return t&&r&&t.value===r.value?{attributes:[...t.attributes,...r.attributes],value:t.value}:void 0}return r===Ot.AND?(e instanceof ne?this.collectStartsWithAttributes(e):void 0)||(s instanceof ne?this.collectStartsWithAttributes(s):void 0):void 0}getOrderDirection(){return this.orderBySelectors?.[0]?.[1]??oe.ASC}async prepare(t){if(t=t||await this.adapter.context(Ct.QUERY,this.overrides||{},this.fromSelector),this.isSimpleQuery()&&t.get("forcePrepareSimpleQueries")){const e=this.squash(t);if(e)return this.prepared=e,this}if(t.get("forcePrepareSimpleQueries")||t.get("forcePrepareComplexQueries")){const e=this.squash(t);if(e)return this.prepared=e,this}const e=[],r={},s={class:this.fromSelector,args:e,params:r};let i,n=xt.FIND_BY;void 0!==this.countSelector?(n=xt.COUNT_BY,i=null!==this.countSelector?this.countSelector:void 0):this.sumSelector?(n=xt.SUM_BY,i=this.sumSelector):this.avgSelector?(n=xt.AVG_BY,i=this.avgSelector):this.minSelector?(n=xt.MIN_BY,i=this.minSelector):this.maxSelector?(n=xt.MAX_BY,i=this.maxSelector):this.distinctSelector?(n=xt.DISTINCT_BY,i=this.distinctSelector):!this.groupBySelectors?.length||this.selectSelector?.length||this.whereCondition||(n=xt.GROUP_BY_PREFIX,i=this.groupBySelectors[0]);const o=[n];if(i&&o.push(i),this.whereCondition){const r=this.prepareCondition(this.whereCondition,t);o.push(r.method),r.args&&r.args.length&&e.push(...r.args)}if(this.selectSelector&&o.push(xt.SELECT,this.selectSelector.join(` ${xt.AND.toLowerCase()} `)),this.orderBySelectors?.length){const[t,...e]=this.orderBySelectors;o.push(xt.ORDER_BY,t[0]),r.direction=t[1],e.length&&(r.order=this.orderBySelectors.map(([t,e])=>[t,e]),e.forEach(([t])=>{o.push(xt.THEN_BY,t)}))}if(this.groupBySelectors?.length&&n!==xt.GROUP_BY_PREFIX){const[t,...e]=this.groupBySelectors;o.push(xt.GROUP_BY,t),e.forEach(t=>o.push(xt.THEN_BY,t))}else this.groupBySelectors?.length&&n===xt.GROUP_BY_PREFIX&&this.groupBySelectors.slice(1).forEach(t=>o.push(xt.THEN_BY,t));return this.limitSelector&&(r.limit=this.limitSelector),this.offsetSelector&&(r.skip=this.offsetSelector),s.method=U(o.join(" ")),s.params=r,this.prepared=s,this}isSimpleQuery(){return!(this.selectSelector&&this.selectSelector.length||this.groupBySelectors&&this.groupBySelectors.length||void 0!==this.countSelector||this.countDistinctSelector||this.maxSelector||this.minSelector||this.sumSelector||this.avgSelector||this.distinctSelector)}hasAggregation(){return void 0!==this.countSelector||void 0!==this.countDistinctSelector||void 0!==this.maxSelector||void 0!==this.minSelector||void 0!==this.sumSelector||void 0!==this.avgSelector||void 0!==this.distinctSelector||(this.groupBySelectors?.length||0)>0}async paginate(t,...e){e.pop();try{return this.adapter.Paginator(this.prepared||this.build(),t,this.fromSelector)}catch(t){throw new se(t)}}toString(){return this.adapter.flavour+" statement"}}i([j(),n("design:type",Function),n("design:paramtypes",[Array]),n("design:returntype",Object)],ds.prototype,"select",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(is="undefined"!=typeof S&&S)?is:Object]),n("design:returntype",Object)],ds.prototype,"distinct",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(ns="undefined"!=typeof S&&S)?ns:Object]),n("design:returntype",Object)],ds.prototype,"max",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(os="undefined"!=typeof S&&S)?os:Object]),n("design:returntype",Object)],ds.prototype,"min",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(as="undefined"!=typeof S&&S)?as:Object]),n("design:returntype",Object)],ds.prototype,"sum",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(cs="undefined"!=typeof S&&S)?cs:Object]),n("design:returntype",Object)],ds.prototype,"avg",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(ls="undefined"!=typeof S&&S)?ls:Object]),n("design:returntype",Object)],ds.prototype,"count",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",Object)],ds.prototype,"from",null),i([j(),n("design:type",Function),n("design:paramtypes",[ne]),n("design:returntype",Object)],ds.prototype,"where",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,String]),n("design:returntype",Object)],ds.prototype,"orderBy",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,String]),n("design:returntype",Object)],ds.prototype,"thenBy",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(us="undefined"!=typeof Key&&Key)?us:Object]),n("design:returntype",Object)],ds.prototype,"groupBy",null),i([j(),n("design:type",Function),n("design:paramtypes",[Number]),n("design:returntype",Object)],ds.prototype,"limit",null),i([j(),n("design:type",Function),n("design:paramtypes",[Number]),n("design:returntype",Object)],ds.prototype,"offset",null),i([j(),n("design:type",Function),n("design:paramtypes",[void 0]),n("design:returntype",Promise)],ds.prototype,"execute",null);class hs extends $t{constructor(t){super(),this.name=t,this.observers=[],this.Context=Rt}for(t,...e){return new Proxy(this,{get(r,s,i){const n=Reflect.get(r,s,i);return"object"!=typeof n?n:n instanceof hs?n.for(t,...e):n instanceof Fe?n.override(t):n}})}override(t,...e){return new Proxy(this,{get(r,s,i){const n=Reflect.get(r,s,i);return"object"!=typeof n?n:n instanceof hs?n.override(t,...e):n instanceof Fe?n.override(t):n}})}observe(t,e){this.observerHandler||Object.defineProperty(this,"observerHandler",{value:new Lt,writable:!1});const r=this.log.for(this.observe);return this.observerHandler.observe(t,e),r.verbose("Registered new observer "+(t.constructor.name||t.toString())),()=>this.unObserve(t)}unObserve(t){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables? or are you unregistering whe you shouldn't");this.observerHandler.unObserve(t);const e=this.log.for(this.unObserve);e.verbose(`Observer ${t.toString()} removed`),this.observerHandler.count()||(delete this.observerHandler,e.verbose("No longer being observed"))}async updateObservers(t,e,r,...s){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");const{log:i,ctxArgs:n}=this.logCtx(s,this.updateObservers);i.verbose(`Updating ${this.observerHandler.count()} observers for ${this}`),await this.observerHandler.updateObservers(t,e,r,...n)}async flags(t,e,...r){e.correlationId=e.correlationId||`${t}-${Wt.instance.generate()}`;const s=e.logger||L.for(this);return s.setConfig({correlationId:e.correlationId}),Object.assign({},Tt,e,{args:r,timestamp:new Date,operation:t,logger:s})}async refresh(t,e,r,...s){return this.updateObservers(t,e,r,...s)}async context(t,e,...r){this.log.for(this.context).silly(`creating new context for ${t} operation with flag overrides: ${JSON.stringify(e)}`);let s=r.pop();void 0===s||s instanceof Rt||(r.push(s),s=void 0),e=s?Object.assign({},s.toOverrides(),e):e;const i=await this.flags("string"==typeof t?t:t.name,e,...[...r,s].filter(Boolean));if(s){if(!(s instanceof this.Context)){const t=(new this.Context).accumulate({...s.cache,...i,parentContext:s});return s.accumulate({childContexts:[...s.getOrUndefined("childContexts")||[],t]}),t}if(s.get("operation")!==t){const t=(new this.Context).accumulate({...s.cache,...i,parentContext:s});return s.accumulate({childContexts:[...s.getOrUndefined("childContexts")||[],t]}),t}return s.accumulate(i)}return(new this.Context).accumulate({...i})}logCtx(t,e,r=!1,s){return $t.logCtx.call(this,e,s||{},r,...t.filter(t=>void 0!==t))}static get(t){if(!t)throw new u("No name provided");const r=Gt(t),s=e.get(r);if(s)return s;throw new u("No Service found for "+("string"==typeof t?t:"symbol"==typeof t?t.toString():t.name))}static async boot(...t){let r=t.pop();void 0===r||r instanceof Rt||(t.push(r),r=void 0);const s=await hs.prototype.flags(Ct.INITIALIZATION,{},...t);r=r?new Rt(r).accumulate({...s,parentContext:r}):(new Rt).accumulate(s),t=[...t,r];const{log:i,ctxArgs:n}=hs.prototype.logCtx(t,this.boot),o=e.services();for(const[t,r]of Object.entries(o))try{i.verbose(`Booting ${r.name} service...`);const s=e.get(r);if(!s)throw new u("Failed to resolve injectable for "+t);s instanceof ps&&(i.verbose(`Initializing ${r.name} service...`),await s.boot(...n))}catch(t){throw new u(`Failed to boot ${r.name} service:${t}`)}}static async shutdown(...t){let r=t.pop();void 0===r||r instanceof Rt||(t.push(r),r=void 0);const s=await hs.prototype.flags(Ct.SHUTDOWN,{},...t);r=r?new Rt(r).accumulate({...s,parentContext:r}):(new Rt).accumulate(s),t=[...t,r];const{log:i,ctxArgs:n}=hs.prototype.logCtx(t,this.shutdown),o=e.services();for(const[t,r]of Object.entries(o).reverse())try{i.verbose(`Shutting down ${r.name} service...`);const s=e.get(r);if(!s)throw new u("Failed to resolve injectable for "+t);if(s instanceof ps){i.verbose(`Gracefully shutting down ${r.name} service...`);try{await s.shutdown(...n)}catch(t){i.error(`Failed to gracefully shutdown ${r.name} service`,t)}}}catch(e){throw new u(`Failed to Shutdown services ${t}: ${e}`)}}}i([j(),n("design:type",Function),n("design:paramtypes",[Object,Function]),n("design:returntype",Function)],hs.prototype,"observe",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",void 0)],hs.prototype,"unObserve",null);class ps extends hs{constructor(){super()}async boot(...t){const{config:e,client:r}=await this.initialize(...t);this._config=e,this._client=r;const{log:s}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.boot);s.verbose(this.toString()+" initialized...")}get config(){if(!this._config)throw new u("Config not initialized");return this._config}get client(){if(!this._client)throw new u("Client not initialized");return this._client}async shutdown(...t){const{log:e}=await this.logCtx(t,this.shutdown,!0);e.info("Shutting down...")}}function gs(t){return function(e,r,s){const i=s.value;return s.value=function(...e){const r=this.class;if(r&&Ht(r,t))throw Error(`Operation "${t}" is blocked by @BlockOperations for ${r?.name??"Model"}.`);return i.apply(this,e)},s}}i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",Promise)],ps.prototype,"boot",null),i([j(),n("design:type",Object),n("design:paramtypes",[])],ps.prototype,"config",null),i([j(),n("design:type",Object),n("design:paramtypes",[])],ps.prototype,"client",null);const fs=()=>gs(a.CREATE),ys=()=>gs(a.READ),ms=()=>gs(a.UPDATE),ws=()=>gs(a.DELETE);function vs(t){return(e,i,n)=>{n||i?(bt()(e,i),t=t||dt.type(e.constructor,i)):t=t||e,t=Gt(t);const o=[];if(n&&"number"==typeof n.value)o.push(r(t));else if(n||i){if(n)throw Error("Invalid decorator usage. Should be impossible");o.push(r(t))}else dt.set(Ct.SERVICE,t,e),o.push(s(t,{singleton:!0,callback:e=>Object.defineProperty(e,"name",{enumerable:!0,configurable:!1,writable:!1,value:t})}));return gt(...o)(e,i,n)}}function bs(t){const e=Ct.AUTH;return ht.for(e).define({decorator:t=>vt(e,t),args:[t]}).apply()}const As=t=>vt(Ct.AUTH_ROLE,t);function Ss(t,e){const r=Ct.DECAF_ROUTE;return ht.for(r).define({decorator:()=>(s,i,n)=>{const o={path:e,httpMethod:t,handler:n};return gt(ft(dt.key(r,i),o))(s,i,n)},args:[]}).apply()}const xs=t=>"string"==typeof t?t.endsWith("Service")?t:t+"Service":"symbol"==typeof t?t.toString():t.name+"Service";class Es extends hs{get class(){if(!this.clazz)throw new u("Class not initialized");return this.clazz}get repo(){return this._repository||(this._repository=Fe.forModel(this.clazz)),this._repository}constructor(t,e){super(e??t.name+"Service"),this.clazz=t}static getService(t){if(!t)throw new u("No name provided");const e=xs(t);try{const t=hs.get(e);if(t)return t}catch(t){}throw new u("No ModelService found for alias "+e)}async create(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.CREATE,!0)).for(this.create);return this.repo.create(t,...r)}async createAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.CREATE_ALL,!0)).for(this.createAll);return this.repo.createAll(t,...r)}async delete(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.DELETE,!0)).for(this.delete);return this.repo.delete(t,...r)}async deleteAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.DELETE_ALL,!0)).for(this.deleteAll);return this.repo.deleteAll(t,...r)}async read(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.READ,!0)).for(this.read);return this.repo.read(t,...r)}async readAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.READ_ALL,!0)).for(this.readAll);return this.repo.readAll(t,...r)}async query(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.QUERY,!0)).for(this.query),s=this.repo?.[t];if("function"!=typeof s)throw new u(`Method "${t}" is not implemented`);return s.apply(this.repo,r)}async update(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.UPDATE,!0)).for(this.update);return this.repo.update(t,...r)}async updateAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.UPDATE_ALL,!0)).for(this.updateAll);return this.repo.updateAll(t,...r)}select(t){return this.repo.select(t)}async listBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.LIST_BY,!0)).for(this.listBy);return this.repo.listBy(t,e,...s)}async paginateBy(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.PAGE_BY,!0)).for(this.paginateBy);return this.repo.paginateBy(t,e,r,...i)}async findOneBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_ONE_BY,!0)).for(this.findOneBy);return this.repo.findOneBy(t,e,...s)}async findBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_BY,!0)).for(this.findBy);return this.repo.findBy(t,e,...s)}async findByPaginate(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.FIND_BY_PAGINATE,!0)).for(this.findByPaginate);return this.repo.findByPaginate(t,e,r,...i)}async statement(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.STATEMENT,!0)).for(this.statement);return this.repo.statement(t,...r)}static forModel(t,e){let r;e=xs(e||t);try{r=Es.get(e)}catch(t){r=void 0}if(r instanceof Es)return r;const s=this;let o=class extends s{constructor(){super(t)}};return o=i([vs(e),n("design:paramtypes",[])],o),new o}refresh(t,e,r,...s){return this.repo.refresh(t,e,r,...s)}observe(t,e){return this.repo.observe(t,e)}unObserve(t){return this.repo.unObserve(t)}updateObservers(t,e,r,...s){return this.repo.updateObservers(t,e,r,...s)}logCtx(t,e,r=!1){const s=this.repo._adapter.logCtx([this.repo.class,...t],e,r,this.repo._overrides||{});function i(t){return t.ctxArgs.shift(),t}return s instanceof Promise?s.then(i):i(s)}}i([fs(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"create",null),i([fs(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],Es.prototype,"createAll",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"delete",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],Es.prototype,"deleteAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"read",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],Es.prototype,"readAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[String,Object]),n("design:returntype",Promise)],Es.prototype,"query",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"update",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Array,Object]),n("design:returntype",Promise)],Es.prototype,"updateAll",null);class Os extends $t{isSameObservedAdapter(t){if(!this.adapter)return!1;if(this.adapter===t)return!0;const e=this.adapter,r=t;return r instanceof re&&e.alias===r.alias&&e.flavour===r.flavour}constructor(){super(),this.initialized=!1}logCtx(t,e,r=!1){if(!this.adapter)throw new u("Adapter not set yet");return this.adapter.logCtx(t,e,r)}async initialize(...t){if(!this.adapter)return void this.log.for(this.initialize).verbose("No adapter observed for dispatch; skipping initialization");if(this.initialized)return void this.log.for(this.initialize).debug("Dispatcher already initialized; skipping initialization to prevent duplicate setup");const{log:e}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.initialize);e.verbose(`Initializing ${this.adapter}'s event Dispatch`),this.initialized=!0;const r=this.adapter;[a.CREATE,a.UPDATE,a.DELETE,c.CREATE_ALL,c.UPDATE_ALL,c.DELETE_ALL].forEach(t=>{if(!r[t])throw new u(`Method ${t} not found in ${r.alias} adapter to bind Observables Dispatch`);let e=Object.getOwnPropertyDescriptor(r,t),s=r;for(;!e&&s!==Object.prototype;)s=Object.getPrototypeOf(s),e=Object.getOwnPropertyDescriptor(s,t);function i(t){switch(t){case c.CREATE_ALL:return a.CREATE;case c.UPDATE_ALL:return a.UPDATE;case c.DELETE_ALL:return a.DELETE;default:return t}}e&&e.writable?r[t]=new Proxy(r[t],{apply:async(e,r,s)=>{const{log:n,ctxArgs:o,ctx:a}=r.logCtx(s.slice(3-(4-s.length),s.length),e),[c,l,u]=s,d=await e.call(r,c,l,u,...o),h=[c,i(t),l];return a.get("observeFullResult")&&h.push(Array.isArray(d)?d.map(t=>c(t)):c(d)),this.updateObservers(...h,...o).catch(e=>n.error(`Failed to dispatch observer refresh for ${t} on ${c.name||c} for ${l}: ${e}`)),d}}):this.log.error(`Could not find method ${t} to bind Observables Dispatch`)})}async close(...t){}observe(t){if(!(t instanceof re))throw new Mt("Only Adapters can be observed by dispatch");if(this.adapter){if(this.isSameObservedAdapter(t))return()=>this.unObserve(t);throw new Mt("Dispatch is already observing another adapter")}return this.adapter=t,this.models=re.models(this.adapter.alias),this.initialize().then(()=>this.log.verbose(`Dispatch initialized for ${this.adapter.alias} adapter`)),()=>this.unObserve(t)}unObserve(t){if(!this.isSameObservedAdapter(t))throw new Mt("Only the adapter that was used to observe can be unobserved");this.adapter=void 0}async updateObservers(t,e,r,...s){if(!t)throw new u("Model must be provided for observer update");const i=t&&"string"==typeof t?t:z.tableName(t);if(!this.adapter)return void this.log.for(this.updateObservers).debug(`No adapter observed for dispatch; skipping observer update for ${i}:${e}`);const{log:n,ctxArgs:o,ctx:a}=this.logCtx(s,this.updateObservers);try{n.debug(`dispatching observer refresh for ${e}:${i}: ${r}${a.get("observeFullResult")?" - including result":""}`),await this.adapter.refresh(t,e,r,...o)}catch(t){throw new u("Failed to refresh dispatch: "+t)}}toString(){return(this.adapter?this.adapter.toString():"uninitialized")+" event dispatch"}}async function ks(t,e,r,s){if(t.get("allowGenerationOverride")&&void 0!==s[r])return;let{seed:i,args:n}=e;i&&"function"==typeof i&&(i=i(s,...n||[],t)),s[r]=await Wt.instance.generate(i)}function Cs(t=!1,e,...r){"function"==typeof t&&(e=t,t=!1);const s=Ct.UUID;return ht.for(s).define({decorator:(t,e,...r)=>{const s={update:t,seed:e,args:r},i=[H(),x(Ct.UUID),A(ks,s,{priority:54})];return t&&i.push(E(ks,s,{priority:54})),t||i.push(b()),gt(...i)},args:[t,e,...r]}).apply()}re&&(re._baseDispatch=Os);class Ts extends $t{static{this.lock=new lt}constructor(t,e,r={}){super(),this.options=t,this.adapter=e,this.repo=Fe.forModel(rs,e.alias).override(r)}async current(...t){const{log:e,ctx:r}=await this.logCtx(t,a.READ,!0),{name:s,startWith:i}=this.options;try{const t=await this.repo.read(s,r);return this.parse(t.current)}catch(t){if(t instanceof m){if(e.debug(`Sequence.current missing ${s}, returning startWith=${i}`),void 0===i)throw new u("Starting value is not defined for a non existing sequence");try{return this.parse(i)}catch(t){throw new u(`Failed to parse initial value for sequence ${i}: ${t}`)}}throw new u(`Failed to retrieve current value for sequence ${s}: ${t}`)}}async increment(t,e){const{log:r,ctx:s}=this.adapter.logCtx([e],this.increment),{type:i,incrementBy:n,name:o}=this.options;if(!o)throw new u("Sequence name is required");return Ts.lock.execute(async()=>{const e=t||n;if(e%n!==0)throw new u("Value to increment does not consider the incrementBy setting: "+n);const a="function"==typeof i&&i?.name?i.name:i,c=await this.current(s),l=async t=>{try{return await this.repo.update(new rs({id:o,current:t}),s)}catch(e){if(e instanceof m)return r.debug(`Sequence create ${o} current=${c} next=${t}`),this.repo.create(new rs({id:o,current:t}),s);throw e}};if("uuid"===a)for(;;){const t=await Promise.resolve(Wt.instance.generate(c));try{const e=await l(t);return r.debug(`Sequence uuid increment ${o} current=${c} next=${t}`),e.current}catch(t){if(t instanceof T)continue;throw t}}const d=await(async t=>{switch(a){case Number.name:return this.parse(t)+e;case BigInt.name:return this.parse(t)+BigInt(e);case String.name:return this.parse(t);case"serial":return await Promise.resolve(Jt.instance.generate(t));default:throw new u("Should never happen")}})(c),h=await l(d);return r.debug(`Sequence.increment ${o} current=${c} next=${d}`),h.current},o)}async next(...t){const{ctx:e}=(await this.logCtx(t,a.UPDATE,!0)).for(this.next);return this.increment(void 0,e)}async range(t,...e){const{ctx:r,log:s}=(await this.logCtx(e,a.UPDATE,!0)).for(this.range);if("uuid"===this.options.type||"serial"===this.options.type)throw new Mt(`type ${this.options.type} is currently not suppported for this adapter`);const i="function"==typeof this.options.type&&this.options.type?.name?this.options.type.name:this.options.type,n=this.parse(this.options.incrementBy),o=await this.increment(this.parse(t)*n,r);let c=[];for(let e=0;t-1>=e;e++)c.push(o-n*this.parse(e));if(c=c.reverse(),c[c.length-1]!==o&&"String"!==i)throw new u("Miscalculation of range");return s.debug("Calculated range: "+c.join(", ")),c}async ensureAtLeast(t,...e){const{ctx:r}=(await this.logCtx(e,a.UPDATE,!0)).for(this.ensureAtLeast),{name:s}=this.options;if(!s)throw new u("Sequence name is required");const i=this.parse(t),n=(t,e)=>"bigint"==typeof t||"bigint"==typeof e?BigInt(t)>BigInt(e):"number"==typeof t||"number"==typeof e?Number(t)>Number(e):t+"">e+"";return Ts.lock.execute(async()=>{const t=async()=>{try{return await this.repo.read(s,r)}catch(t){if(t instanceof m)return;throw t}};for(;;)try{const e=await t();if(!e)return await this.repo.create(new rs({id:s,current:i}),r),i;const o=this.parse(e.current);return n(i,o)?(await this.repo.update(new rs({id:s,current:i}),r),i):o}catch(t){if(t instanceof T)continue;throw t}},s)}parse(t){return Ts.parseValue(this.options.type,t)}logCtx(t,e,r=!1){const s=this.adapter.logCtx([rs,...t],e,r);function i(t){return t.ctxArgs.shift(),t}return s instanceof Promise?s.then(i):i(s)}static pk(t){return z.sequenceName(t,"pk")}static parseValue(t,e){switch("function"==typeof t&&t?.name?t.name:t){case Number.name||Number.name.toLowerCase():return"string"==typeof e?parseInt(e):"number"==typeof e?e:BigInt(e);case BigInt.name||BigInt.name.toLowerCase():return BigInt(e);case String.name||String.name.toLowerCase():return e.toString();case void 0:case"uuid":case"serial":return e;default:throw new Mt(`Unsupported sequence type: ${t} for adapter ${this}`)}}}function Ns(t,...e){let r;if(t instanceof Es&&(r=t.repo.adapter),t instanceof Fe&&(r=t.adapter),t instanceof re&&(r=t),!r)throw new u("Could not find adapter to extract transaction");return r.transactionLock(...e)}function Ds(t,...e){return new Kt(Ns(t,...e))}re._baseSequence=Ts,ht.for(ut.TRANSACTIONAL).define({decorator:(...t)=>(e,r,s)=>{if(!s)throw new u("This decorator only applies to methods");return At()(e,r,s),dt.set(e.constructor,dt.key(ut.TRANSACTIONAL,r),{data:t}),s.value=new Proxy(s.value,{async apply(t,e,r){const{log:s,ctx:i}=(await e.logCtx(r,t.name,!0)).for(t),n=i.getOrUndefined("transactionLock")||Ds(e);let o;i.put("transactionLock",n),await n.acquire();try{o=await t.call(e,...r,i)}catch(t){try{await n.rollback(t)}catch(t){s.error("Failed to rollback transaction",t)}throw t}try{await n.release()}catch(t){throw new u("Failed to release transaction: "+t)}return o}}),s}}).apply();class _s extends ps{constructor(){super()}for(t,...e){throw new Mt("Persistence service cannot be overridden")}async initialize(...t){const e=t.shift();if(!e||!Array.isArray(e)||e instanceof Rt||!e.every(t=>Array.isArray(t)))throw new u("Missing/invalid configuration");const{log:r,ctxArgs:s}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.initialize),i=e.map(([t,e,...s])=>{try{r.silly(`Initializing ${t.name} with config: ${JSON.stringify(e)}`);const i=new t(e,...s);return r.debug(`Initialized ${i.toString()}...`),i}catch(e){throw new u(`Failed to initialize ${t.name}: ${e}`)}});for(const t of i)try{await t.initialize(...s)}catch(e){throw new u(`Failed to initialize ${t.toString()}: ${e}`)}return{client:i,config:e}}}let Is=class extends z{constructor(t){super(t),this.strategy=Be.EXPONENTIAL,this.baseMs=1e3,this.maxMs=6e4,this.jitter=Pe.FULL}};i([H(),X(String),et(Be),St("the backoff strategy"),n("design:type",String)],Is.prototype,"strategy",void 0),i([H(),St("base interval between attempts"),n("design:type",Number)],Is.prototype,"baseMs",void 0),i([H(),St("max interval"),n("design:type",Number)],Is.prototype,"maxMs",void 0),i([X(String),et(Pe),St("optional jitter strategy"),n("design:type",String)],Is.prototype,"jitter",void 0),Is=i([W(),n("design:paramtypes",[Object])],Is);let Bs=class extends z{constructor(t){super(t)}};i([H(),St("The error message"),n("design:type",String)],Bs.prototype,"message",void 0),i([bt(),St("The error stack"),n("design:type",String)],Bs.prototype,"stack",void 0),i([bt(),St("The error code"),n("design:type",String)],Bs.prototype,"code",void 0),i([bt(),St("The error details"),n("design:type",Object)],Bs.prototype,"details",void 0),Bs=i([W(),n("design:paramtypes",[Object])],Bs);let Ps=class extends z{constructor(t){if(super(t),this.ts=new Date,"string"==typeof this.payload)try{this.payload=JSON.parse(this.payload)}catch{}}};i([ir(),P(["taskId","classification","uuid"],":"),n("design:type",String)],Ps.prototype,"id",void 0),i([Br(),b(),H(),R(),Cs(!1),n("design:type",String)],Ps.prototype,"uuid",void 0),i([Br(),b(),H(),Xe([oe.ASC,oe.DSC]),n("design:type",String)],Ps.prototype,"taskId",void 0),i([rt(),Br(),H(),Xe([oe.ASC,oe.DSC]),n("design:type",Date)],Ps.prototype,"ts",void 0),i([Br(),b(),H(),et(Re),Xe([oe.ASC,oe.DSC]),n("design:type",String)],Ps.prototype,"classification",void 0),i([bt(),Br(),$(),b(),n("design:type",Object)],Ps.prototype,"payload",void 0),Ps=i([Ir("task_event"),W(),n("design:paramtypes",[Object])],Ps);class Rs extends st{constructor(){super()}preSerialize(t,...e){return this.serializeValue(t,...e)}deserialize(t,...e){const r=JSON.parse(t);return this.rebuildValue(r)}serializeValue(t,...e){if(null==t)return t;if("object"!=typeof t)return t;if(t instanceof Date)return t.toISOString();if(Array.isArray(t))return t.map(t=>this.serializeValue(t,...e));if(t instanceof ne){const r=this.serializePlain(t,...e);return r[it.ANCHOR]="??condition",r}return z.isModel(t)?this.serializeModel(t,...e):this.serializePlain(t,...e)}serializeModel(t,...e){const r=this.serializePlain(t,...e),s=this.getMetadata(t.constructor)??t.constructor?.name;return s&&(r[it.ANCHOR]=s),r}serializePlain(t,...e){const r={};for(const[s,i]of Object.entries(t))r[s]=this.serializeValue(i,...e);return r}getMetadata(t){try{return dt.modelName(t)}catch{return}}rebuildValue(t){if(null===t||"object"!=typeof t)return t;if(Array.isArray(t))return t.map(t=>this.rebuildValue(t));const e=t[it.ANCHOR],r=this.rebuildObject(t);return e?"??condition"===e?ne.from(r):z.build(r,e):r}rebuildObject(t){const e={};for(const[r,s]of Object.entries(t))r!==it.ANCHOR&&(e[r]=this.rebuildValue(s));return e}serialize(t,...e){return JSON.stringify(this.preSerialize(t))}}let $s=class extends z{constructor(t){super(t),this.ts=new Date}};i([rt(),H(),n("design:type",Date)],$s.prototype,"ts",void 0),i([H(),et(G),n("design:type",String)],$s.prototype,"level",void 0),i([nt(0),n("design:type",Number)],$s.prototype,"step",void 0),i([H(),bt(),n("design:type",String)],$s.prototype,"msg",void 0),i([bt(),n("design:type",Object)],$s.prototype,"meta",void 0),$s=i([W(),n("design:paramtypes",[Object])],$s);let Fs=class extends z{constructor(t){super(t),this.atomicity=$e.ATOMIC,this.status=Ie.PENDING,this.attempt=0,this.logTail=[]}};i([ir(),Cs(),St("the task id"),n("design:type",String)],Fs.prototype,"id",void 0),i([Br(),H(),X(String),et($e),Xe([oe.ASC,oe.DSC]),St("defines a single or composite task"),n("design:type",String)],Fs.prototype,"atomicity",void 0),i([Br(),H(),Xe([oe.ASC,oe.DSC]),St("Holds task classification - must match @task()"),n("design:type",String)],Fs.prototype,"classification",void 0),i([Br(),bt(),Xe([oe.ASC,oe.DSC]),St("optional task name for ambiguity"),n("design:type",String)],Fs.prototype,"name",void 0),i([Br(),bt(),St("Optional lock key. Tasks/steps sharing the same key cannot run concurrently"),n("design:type",String)],Fs.prototype,"lock",void 0),i([Br(),H(),X(String),et(Ie),Xe([oe.ASC,oe.DSC]),Xe([oe.ASC,oe.DSC],["nextRunAt"]),Xe([oe.ASC,oe.DSC],["leaseExpiry"]),Xe([oe.ASC,oe.DSC],["scheduledTo"]),St("Holds the task current status"),n("design:type",String)],Fs.prototype,"status",void 0),i([bt(),Br(),$(Rs),St("Holds task input"),n("design:type",Object)],Fs.prototype,"input",void 0),i([bt(),Br(),$(Rs),St("Holds the task output when successfully completed"),n("design:type",Object)],Fs.prototype,"output",void 0),i([bt(),Br(),$(),St("Holds the error for failed tasks"),n("design:type",Bs)],Fs.prototype,"error",void 0),i([Br(),H(),nt(0),Xe([oe.ASC,oe.DSC]),St("Holds the current attempt"),n("design:type",Number)],Fs.prototype,"attempt",void 0),i([Br(),nt(1),H(),St("max attempts for the task"),n("design:type",Number)],Fs.prototype,"maxAttempts",void 0),i([Br(),H(),$(),St("backoff configuration"),n("design:type",Is)],Fs.prototype,"backoff",void 0),i([rt(),Br(),St("Next execution timestamp"),n("design:type",Date)],Fs.prototype,"nextRunAt",void 0),i([rt(),Br(),St("Task scheduled timestamp"),n("design:type",Date)],Fs.prototype,"scheduledTo",void 0),i([Br(),$(),St("Task dependencies. Supports '<taskId>' or '<taskId>:<step index|step reference>'"),n("design:type",Array)],Fs.prototype,"dependencies",void 0),i([bt(),Br(),St("Task lease owner identifier"),n("design:type",String)],Fs.prototype,"leaseOwner",void 0),i([rt(),Br(),St("Task lease expiration timestamp"),n("design:type",Date)],Fs.prototype,"leaseExpiry",void 0),i([bt(),Br(),$(),St("Holds the various steps definition and inputs - only for type === 'composite'"),n("design:type",Array)],Fs.prototype,"steps",void 0),i([bt(),Br(),nt(0),Xe([oe.ASC,oe.DSC]),St("Holds the current step - only for type === 'composite'"),n("design:type",Number)],Fs.prototype,"currentStep",void 0),i([bt(),Br(),$(),St("Holds the step results - only for type === 'composite'"),n("design:type",Array)],Fs.prototype,"stepResults",void 0),i([bt(),Br(),$(),St("Holds the task log entries"),n("design:type",Array)],Fs.prototype,"logTail",void 0),i([Br(),Mr(),Xe([oe.ASC,oe.DSC]),St("timestamp of creation"),n("design:type",Date)],Fs.prototype,"createdAt",void 0),i([Br(),jr(),Xe([oe.ASC,oe.DSC]),St("timestamp of last update"),n("design:type",Date)],Fs.prototype,"updatedAt",void 0),i([Br(),Fr(),Xe([oe.ASC,oe.DSC]),St("Holds the creator of the task"),n("design:type",String)],Fs.prototype,"createdBy",void 0),i([Br(),Lr(),Xe([oe.ASC,oe.DSC]),St("Holds the creator of the task"),n("design:type",String)],Fs.prototype,"updatedBy",void 0),Fs=i([St("Holds the current step when applicable"),Ir("tasks"),W(),n("design:paramtypes",[Object])],Fs);let Ls=class extends z{constructor(t){super(t)}};i([H(),St("The status of a step"),n("design:type",String)],Ls.prototype,"status",void 0),i([bt(),St("The result of a successful step"),n("design:type",Object)],Ls.prototype,"output",void 0),i([bt(),St("the error of a failed step"),n("design:type",Bs)],Ls.prototype,"error",void 0),Ls=i([W(),n("design:paramtypes",[Object])],Ls);let Ms=class extends z{constructor(t){super(t)}};i([H(),St("task handler type"),n("design:type",String)],Ms.prototype,"classification",void 0),i([ot(1),St("optional task name for ambiguity"),n("design:type",String)],Ms.prototype,"name",void 0),i([St("optional task step input"),bt(),n("design:type",Object)],Ms.prototype,"input",void 0),i([St("Optional lock key. Tasks/steps sharing the same key cannot run concurrently"),bt(),n("design:type",String)],Ms.prototype,"lock",void 0),i([St("Task-step dependencies. Supports '<taskId>' or '<taskId>:<step index|step reference>'"),bt(),tt(()=>String),n("design:type",Array)],Ms.prototype,"dependsOn",void 0),Ms=i([W(),n("design:paramtypes",[Object])],Ms);class js extends z{constructor(t){super(t),this.baseMs=1e3,this.jitter=Pe.FULL,this.maxMs=6e4,this.strategy=Be.EXPONENTIAL,z.fromModel(this,t)}setBaseMs(t){return this.baseMs=t,this}setJitter(t){return this.jitter=t,this}setMaxMs(t){return this.maxMs=t,this}setStrategy(t){return this.strategy=t,this}build(){const t=this.hasErrors();if(t)throw new d(t);return new Is(this)}}i([H(),nt(1e3),n("design:type",Number)],js.prototype,"baseMs",void 0),i([H(),et(Pe),n("design:type",String)],js.prototype,"jitter",void 0),i([at("baseMs"),nt(1e3),H(),n("design:type",Number)],js.prototype,"maxMs",void 0),i([H(),et(Be),n("design:type",String)],js.prototype,"strategy",void 0);class Us extends z{setClassification(t){return this.classification=t,this}setName(t){return this.name=t,this}setAtomicity(t){return this.atomicity=t,this}setBackoff(t){if(t)return this.backoff=t,this;const e=new js,r=this;return e.build=new Proxy(e.build,{apply:(t,e,s)=>(r.backoff=Reflect.apply(t,e,s),r)}),e}setInput(t){return this.input=t,this}setLock(t){return this.lock=t,this}setDependencies(t){return this.dependencies=t,this}setDependsOn(t){return this.setDependencies(t)}setMaxAttempts(t){return this.maxAttempts=t,this}constructor(t){super(t),this.status=Ie.PENDING,this.atomicity=$e.ATOMIC,this.backoff=new Is,this.maxAttempts=1,z.fromModel(this,t)}build(){const t=this.hasErrors();if(t)throw new d(t);return new Fs(this)}}i([H(),n("design:type",String)],Us.prototype,"classification",void 0),i([bt(),n("design:type",String)],Us.prototype,"name",void 0),i([H(),n("design:type",String)],Us.prototype,"status",void 0),i([H(),n("design:type",String)],Us.prototype,"atomicity",void 0),i([H(),n("design:type",Is)],Us.prototype,"backoff",void 0),i([bt(),n("design:type",Object)],Us.prototype,"input",void 0),i([bt(),n("design:type",String)],Us.prototype,"lock",void 0),i([bt(),tt(()=>String),n("design:type",Array)],Us.prototype,"dependencies",void 0),i([nt(1),H(),n("design:type",Number)],Us.prototype,"maxAttempts",void 0);class Gs{constructor(t,e){this.parent=t,this.step=e}setClassification(t){return this.step.classification=t,this}setName(t){return this.step.name=t,this}setInput(t){return this.step.input=t,this}setLock(t){return this.step.lock=t,this}setDependsOn(t){return this.step.dependsOn=t,this}addStep(t,e,r){return this.parent.addStep(t,e,r)}setSteps(t){return this.parent.setSteps(t)}build(){return this.parent}}class Ys extends Us{constructor(t){super(t),this.stepResults=[],z.fromModel(this,t),this.atomicity=$e.COMPOSITE}setAtomicity(t){throw new u("Atomicity locked to "+$e.COMPOSITE)}setSteps(t){return this.steps=(t??[]).map(t=>t instanceof Ms?t:new Ms(t)),this}addStep(t,e,r){this.steps=this.steps||[];const s=new Date,i=1===arguments.length,n=arguments.length>=3,o=new Ms({classification:t,name:n&&"string"==typeof e?e:void 0,input:n?r:i?void 0:e,createdAt:s,updatedAt:s});return this.steps.push(o),i?new Gs(this,o):this}}i([tt(()=>Ms),n("design:type",Array)],Ys.prototype,"steps",void 0);class zs extends Ft{get type(){if(!this._type){const t=dt.get(this.constructor,je);"string"==typeof t?this._type=t:t&&"string"==typeof t.type&&(this._type=t.type)}if(!this._type)throw new u("No type annotation for this handler found. did you use @task()?");return this._type}constructor(){super(),p(this,this.runPrefix.bind(this),this.run.bind(this),this.runSuffix.bind(this),this.run.name)}async runPrefix(t,...e){const{log:r,ctx:s,ctxArgs:i}=this.logCtx(e,this.runPrefix);return r.info(`Running task ${s.taskId} attempt ${s.attempt}`),[t,...i]}runSuffix(t,e){const{log:r}=this.logCtx([e],this.runPrefix);return r.info(`Concluded task ${e.taskId} attempt ${e.attempt}`),t}async catch(t,e,r){}}function qs(t){return ht.for(je).define({decorator:t=>e=>{const r={type:t};return dt.set(je,t,e),vt(je,r)(e)},args:[t]}).apply()}let Hs=class extends zs{constructor(){super()}async run(t,e){const r=e.logger;try{let s;if(t instanceof ne)s=t,r.info("Starting task cleanup with custom condition");else{r.info("Starting task cleanup with expiry dates");const e=ne.attr("status").eq(Ie.SUCCEEDED).and(ne.attr("updatedAt").lte(t.successfulExpiry)),i=ne.attr("status").eq(Ie.FAILED).and(ne.attr("updatedAt").lte(t.failedExpiry)),n=ne.attr("status").eq(Ie.CANCELED).and(ne.attr("updatedAt").lte(t.cancelledExpiry));s=e.or(i).or(n)}r.info("Querying tasks for cleanup");const i=await this.tasks.select(["id"]).where(s).execute(e);if(0===i.length)return r.info("No tasks found for cleanup"),[];r.info(`Found ${i.length} tasks to delete`);const n=await this.tasks.deleteAll(i.map(t=>t.id),e);return r.info(`Successfully deleted ${n.length} tasks`),r.debug("deleted tasks:",n),n}catch(t){throw r.error("Error during task cleanup",t),t}}};i([Ge(Fs),n("design:type",Object)],Hs.prototype,"tasks",void 0),Hs=i([qs("cleanup-task"),n("design:paramtypes",[])],Hs);class Vs{constructor(t,e=150,r=300,s){this.logger=t,this.bufferSize=e,this.maxBufferSize=r,this.pipe=s,this.history=[],this.root=this.logger.root,Object.values(G).forEach(t=>{this[t]=new Proxy(this[t],{apply:(e,r,s)=>{e.apply(r,s),r.push(t,...s)}})})}push(t,e,r){this.history.length<this.maxBufferSize||this.history.splice(0,this.history.length-this.bufferSize),this.history.push([t,e,r])}flush(t){const e=this.history;return this.history=[],t&&e.length?t(e).catch(t=>this.logger.error("Failed to pipe logs",t)).finally(()=>this.history=[]):(this.history=[],e)}benchmark(t){return this.logger.benchmark(t)}clear(){return this.logger=this.logger.clear(),this}debug(t,e){this.logger.debug(t,e)}error(t,e,r){this.logger.error(t,e,r)}for(t,...e){return new Proxy(this,{get(r,s){if("logger"===s){const i=Reflect.get(r,s);try{return i.for(t,...e)}catch(t){r.error("Failed to bind task logger. received: "+(i&&i.constructor?i.constructor.name:i.name?i.name:"unknown"),t);try{r.trace(JSON.stringify(i,void 0,2))}catch(t){r.trace("unserializable output: "+(i.name||"unknown"))}throw t}}return Reflect.get(r,s)}})}info(t,e){this.logger.info(t,e)}setConfig(t){this.logger.setConfig(t)}silly(t,e){this.logger.silly(t,e)}trace(t,e){this.logger.trace(t,e)}verbose(t,e,r){this.logger.verbose(t,e,r)}warn(t,e){this.logger.warn(t,e)}}function Qs(t,e={logProgress:!0,logStatus:!0,style:!0}){return async r=>{switch(t=t.for(r.taskId,{style:!1}),r.classification){case Re.LOG:{const s=r.payload.map(t=>Array.isArray(t)?t:[t.level,t.msg,t.meta]);for(let[r,i,n]of s){e.style||(i=Y(i),i=i.clear().toString());const s=[i];r===G.verbose&&s.push(1),s.push(n);try{t[r](...s)}catch(e){t.error("Failed to pipe task logs",e)}}break}case Re.PROGRESS:if(e.logProgress){const{currentStep:e,totalSteps:s}=r.payload;t.info(`### STEP ${e}/${s}`)}break;case Re.STATUS:if(e.logStatus){const e=r.payload?.status??r.payload;let s=Y(e);switch(e){case Ie.SUCCEEDED:s=s.green.bold;break;case Ie.RUNNING:s=s.blue.bold;break;case Ie.PENDING:s=s.yellow;break;case Ie.WAITING_RETRY:s=s.yellow.bold;break;case Ie.FAILED:s=s.red.bold;break;case Ie.CANCELED:s=s.magenta.bold;break;case Ie.SCHEDULED:s=s.cyan;break;default:throw new u("Received unknown task status: "+r.payload)}t.info("### STATUS "+s)}break;default:throw new u("Unknown task event classification: "+r.classification)}}}function Ws(t,e){const r=e.strategy===Be.FIXED?e.baseMs:e.baseMs*Math.pow(2,Math.max(0,t-1)),s=Math.min(r,e.maxMs);return e.jitter===Pe.FULL?Math.floor(Math.random()*s):s}function Js(t){return new Bs({message:t?.message??t+"",stack:t?.stack,code:t?.code,details:t?.details})}function Xs(t){return new Promise(e=>setTimeout(e,t))}class Ks extends Error{constructor(t){super("Task requested state change: "+t.status),this.request=t,this.name=Ks.name,Object.setPrototypeOf(this,Ks.prototype)}}class Zs extends Rt{get taskId(){return this.get("taskId")}get logger(){return super.logger}get step(){return this.getOrUndefined("step")}setStep(t){this.cache.put("step",t)}get pipe(){return this.get("pipe").bind(this)}flush(){return this.get("flush")()}get attempt(){return this.get("attempt")}get progress(){return this.get("progress")}get heartbeat(){return this.get("heartbeat")}cacheResult(t,e){const r=this.cache.has("resultCache")&&this.cache.get("resultCache")||{};r[t]=e,this.cache.put("resultCache",r)}changeState(t,e){throw new Ks({status:t,...e})}cancel(t,e){this.changeState(Ie.CANCELED,{error:this.toTaskError(t,e)})}retry(t){this.changeState(Ie.WAITING_RETRY,{error:this.toTaskError(t)})}reschedule(t,e){const r=t instanceof Date?t:t.build();this.changeState(Ie.SCHEDULED,{error:this.toTaskError(e),scheduledTo:r})}toTaskError(t,e){if(t||e)return t instanceof Bs?t:t instanceof Error?Js(t):new Bs({message:(t??"Task requested state change")+"",details:e})}get resultCache(){return this.get("resultCache")}scheduleSteps(...t){const e=(t??[]).map(t=>t instanceof Ms?t:new Ms(t));return{afterCurrent:async()=>{const t=this.getOrUndefined("scheduleCompositeSteps");if(!t)throw new u("scheduleSteps().afterCurrent() is only available while running a composite task step");await t(e)}}}constructor(t){super(t)}}class ti{constructor(){this.handlers=new Map,this.initialize()}initialize(){const t=dt.tasks();t&&Object.entries(t).forEach(([t,e])=>{let r;try{r=new e}catch(e){throw new u(`Failed to initialize handler with key ${t}: ${e}`)}this.register(r)})}register(t){if(this.handlers.has(t.type))throw new u("Duplicate task handler: "+t.type);this.handlers.set(t.type,t)}get(t){return this.handlers.get(t)}}class ei extends Lt{constructor(){super(...arguments),this.listeners=new Set}observe(t,e){return super.observe(t,e)}unObserve(t){super.unObserve(t)}emit(t,e){this.updateObservers(Ps,t.classification,t.id,t,e)}async updateObservers(t,e,r,s,...i){const{log:n,ctxArgs:o}=re.logCtx(this.updateObservers,void 0,!1,...i);(await Promise.allSettled(this.observers.filter(s=>{const{filter:i}=s;if(!i)return!0;try{return i(t,e,r,...o)}catch(t){return n.error(`Failed to filter observer ${s.observer.toString()}: ${t}`),!1}}).map(t=>{t.observer.refresh(s,...o)}))).forEach((t,e)=>{"rejected"===t.status&&n.error(`Failed to update observable ${this.observers[e].toString()}: ${t.reason}`)})}}function ri(t,e){return t instanceof Error&&"nextAction"in t&&"string"==typeof t.nextAction&&(!e||t instanceof e)}class si extends F{constructor(t,e,r,s,i,n=500){super(t,r,n),this.taskId=e,this.details=s,this.meta=i}}class ii extends si{constructor(t,e,r){super(ii.name,t,e?.message??`Task ${t} failed`,e,r,500)}}class ni extends si{constructor(t,e,r){const s=r?.nextRunAt instanceof Date?r.nextRunAt.toISOString():r?.nextRunAt;super(ni.name,t,e?.message??`Task ${t} scheduled for retry${s?" at "+s:""}`,e,r,409)}}class oi extends si{constructor(t,e,r){super(oi.name,t,e?.message??`Task ${t} canceled`,e,r,400)}}class ai extends si{constructor(t,e,r){const s=r?.scheduledTo instanceof Date?r.scheduledTo.toISOString():r?.scheduledTo;super(ai.name,t,e?.message??`Task ${t} rescheduled${s?" to "+s:""}`,e,r,202)}}class ci{constructor(t,e){this.bus=t,this.task=e,this.resolved=!1,this.unregistration=t.observe(this,(t,e,r,...s)=>r.startsWith(this.task.id)&&(t===Ps||t===z.tableName(Ps))),this.pipe(this.track.bind(this)),this.resolveTerminalState()}resolve(){return this.awaitStatusTerminal([Ie.SUCCEEDED,Ie.FAILED,Ie.CANCELED,Ie.SCHEDULED])}wait(){return this.awaitStatusTerminal([Ie.SUCCEEDED,Ie.FAILED,Ie.CANCELED])}attach(t,e={logProgress:!0,logStatus:!0,style:!0}){this.pipe(Qs(t,e))}logs(t){this.pipe(async e=>{if(e.classification!==Re.LOG)return;const r=(e.payload??[]).map(t=>Array.isArray(t)?t:[t.level,`${t.ts} - ${t.msg}`,t.meta]);await t(r)},Re.LOG)}pipe(t,e=Re.ALL){this.pipes=this.pipes||{},this.pipes[e]=this.pipes[e]||new Set,this.pipes[e].add(t)}succeed(t){this.complete()}fail(t){this.complete()}cancel(t){t.payload&&this.fail()}retry(){}reschedule(){}onSucceed(t){return this.registerStatusHandler(Ie.SUCCEEDED,t)}onFailure(t){return this.registerStatusHandler(Ie.FAILED,t)}onCancel(t){return this.registerStatusHandler(Ie.CANCELED,t)}onUpdate(t){const e=async(e,r)=>{e.classification===Re.UPDATE&&await t(e,r)};return this.pipe(e,Re.UPDATE),()=>{this.pipes?.[Re.UPDATE]?.delete(e)}}awaitStatusTerminal(t){return new Promise((e,r)=>{const s=[];let i=!1;const n=async t=>{if(!i){(()=>{if(!i){i=!0;for(const t of s)t()}})();try{t.payload?.status===Ie.SUCCEEDED?e(this.extractOutput(t)):r(this.extractError(t))}catch(t){r(t)}}};t.forEach(t=>{const e=this.registerStatusHandler(t,n);s.push(e)})})}extractOutput(t){return void 0!==t.payload?.output?t.payload.output:this.task.output}extractError(t){const e=t.payload?.status??this.task.status,r=this.getNextAction(e),s=t.payload?.originalError;if(s instanceof Error)return this.assignNextAction(s,r);const i=this.buildMeta(e,t.payload),n=this.createTaskControlError(e,t.payload?.error??this.task.error,i);return this.assignNextAction(n,r)}complete(){this.resolved||(this.resolved=!0,this.unregistration(),this.pipes=void 0)}isTerminalStatus(t){return[Ie.SUCCEEDED,Ie.CANCELED,Ie.FAILED].includes(t)}async track(t,e){if(t.classification!==Re.STATUS)return;if(!t.payload)return;const r=t.payload.status;this.task.status=r,void 0!==t.payload.output&&(this.task.output=t.payload.output),t.payload.error&&(this.task.error=t.payload.error),void 0!==t.payload.nextRunAt&&(this.task.nextRunAt=t.payload.nextRunAt),void 0!==t.payload.scheduledTo&&(this.task.scheduledTo=t.payload.scheduledTo),r!==Ie.SUCCEEDED?(r===Ie.FAILED&&this.fail(),r===Ie.CANCELED&&this.cancel(t),r===Ie.WAITING_RETRY&&this.retry(),r===Ie.SCHEDULED&&this.reschedule()):this.succeed()}registerStatusHandler(t,e){const r=async(r,s)=>{r.payload?.status===t&&await e(r,s)};if(this.pipe(r,Re.STATUS),this.task.status===t){const e=this.buildTerminalEvent(t);r(e,this.getTerminalContext())}return()=>{this.pipes?.[Re.STATUS]?.delete(r)}}getTerminalContext(){return this.terminalContext||(this.terminalContext=new Rt),this.terminalContext}buildTerminalEvent(t){const e={status:t};return t===Ie.SUCCEEDED&&(e.output=this.task.output),t!==Ie.FAILED&&t!==Ie.CANCELED||!this.task.error||(e.error=this.task.error),this.task.nextRunAt&&(e.nextRunAt=this.task.nextRunAt),this.task.scheduledTo&&(e.scheduledTo=this.task.scheduledTo),new Ps({classification:Re.STATUS,taskId:this.task.id,payload:e})}createTaskControlError(t,e,r){switch(t){case Ie.FAILED:return new ii(this.task.id,e,r);case Ie.CANCELED:return new oi(this.task.id,e,r);case Ie.WAITING_RETRY:return new ni(this.task.id,e,r);case Ie.SCHEDULED:return new ai(this.task.id,e,r);default:return new ii(this.task.id,e,r)}}assignNextAction(t,e){return e&&(t.nextAction=e),t}getNextAction(t){switch(t){case Ie.CANCELED:return Ie.CANCELED;case Ie.WAITING_RETRY:return Ie.WAITING_RETRY;case Ie.SCHEDULED:return Ie.SCHEDULED;case Ie.FAILED:return Ie.FAILED;default:return}}buildMeta(t,e){const r={};if(e?.nextRunAt&&(r.nextRunAt=e.nextRunAt),e?.scheduledTo&&(r.scheduledTo=e.scheduledTo),Object.keys(r).length)return r}resolveTerminalState(){if(!this.isTerminalStatus(this.task.status))return;if(this.task.status===Ie.SUCCEEDED)return void this.succeed(this.task.output);const t={status:this.task.status,nextRunAt:this.task.nextRunAt,scheduledTo:this.task.scheduledTo};this.fail(this.createTaskControlError(this.task.status,this.task.error,this.buildMeta(this.task.status,t)))}async refresh(t,e){if(!this.pipes)return;const r=this.pipes[Re.ALL]?[...this.pipes[Re.ALL].values()]:[];r.push(...this.pipes[t.classification]?.values()||[]);for(const s of r)try{await s(t,e)}catch(r){e.logger.error(`Failed to trigger pipe ${s.name} for event ${t.classification}. discarding event`,r)}}}class li extends Ft{get Context(){return Zs}get adapter(){return this._adapter||(this._adapter=this.config.adapter,this.config.overrides&&(this._adapter=this.adapter.for(this.config.overrides))),this._adapter}get registry(){return this.config.registry}get bus(){return this.config.bus}get tasks(){return this._tasks||(this._tasks=new(this.adapter.repository())(this.adapter,Fs,!0).override({afterQueryHandlers:!0})),this._tasks}get events(){return this._events||(this._events=new(this.adapter.repository())(this.adapter,Ps,!0).override({afterQueryHandlers:!0})),this._events}static createTaskContext(t,e){const r=new Zs(t);return e&&Object.keys(e).length?r.accumulate(e):r}constructor(t){super(),this.config=t,this.lock=new ct,this.running=!1;const e=Object.assign({},Ue.autoShutdown,t.autoShutdown);this.config=Object.assign({},Ue,t,{autoShutdown:e,bus:t.bus||new ei,registry:t.registry||new ti}),this.idleDelayMs=this.config.pollMsIdle}async push(t,e=!1,...r){const{ctx:s,log:i}=(await this.logCtx(r,a.CREATE,!0)).for(this.push);i.verbose("pushing task "+t.classification);const n=await this.tasks.create(t,s);return i.info(`${t.classification} task registered under ${n.id}`),e?{task:n,tracker:new ci(this.bus,n)}:n}schedule(t,e=!1,...r){return{for:async s=>{const i=s instanceof Date?s:s.build();return t.status=Ie.SCHEDULED,t.scheduledTo=i,t.nextRunAt=void 0,t.leaseOwner=void 0,t.leaseExpiry=void 0,await this.push(t,e,...r)}}}async track(t,...e){const{ctx:r,log:s}=(await this.logCtx(e,a.READ,!0)).for(this.track);s.verbose("tracking task "+t);let i=await this.tasks.read(t,r);return i=await this.ensureTaskError(i,r),s.info(`${i.classification} task found with id ${t}`),{task:i,tracker:new ci(this.bus,i)}}async ensureTaskError(t,e){if(![Ie.FAILED,Ie.CANCELED].includes(t.status)||t.error)return t;let r=t;for(let t=0;6>t;t+=1){await Xs(20);try{const t=await this.tasks.read(r.id,e);if(t.error)return t;r=t}catch{break}}return r}async cancel(t,...e){const{ctx:r}=(await this.logCtx(e,"cancel",!0)).for(this.cancel),s=await this.tasks.read(t,r);if(s.status===Ie.SUCCEEDED||s.status===Ie.FAILED)return s;s.status=Ie.CANCELED;const i=new Bs({message:`Task ${s.id} canceled`,code:400});s.error=i,s.leaseOwner=void 0,s.leaseExpiry=void 0,s.nextRunAt=void 0,s.scheduledTo=void 0;const n=await this.tasks.update(s,r);return await this.emitStatus(r,n,Ie.CANCELED,i),n}async isRunning(){await this.lock.acquire();const t=this.running;return this.lock.release(),t}async start(...t){const{ctx:e}=(await this.logCtx(t,"run",!0)).for(this.start);await this.lock.acquire(),this.running||(this.running=!0,this.lock.release(),this.idleDelayMs=this.config.pollMsIdle,this.loop(e))}async stop(...t){const{ctx:e,log:r}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.stop);await this.lock.acquire(),this.running||r.warn("stop method called when task engine was not running"),this.running=!1,this.lock.release();const s=await this.tasks.select(["id"]).where(ne.attr("status").eq(Ie.RUNNING)).execute(e),i=e.getOrUndefined?.("gracefulShutdownMsTimeout")??this.config.gracefulShutdownMsTimeout;return new Promise((t,n)=>{const o=setTimeout(()=>{r.error(`Graceful shutdown interrupted after ${i} ms...`),t()},i);Promise.allSettled(s.map(({id:t})=>new Promise((r,s)=>{this.track(t,e).then(({tracker:t})=>{t.resolve().then(r)}).catch(s)}))).then(e=>{clearTimeout(o),r.info(`Graceful shutdown completed before expiry. concluded ${e.length} tasks`),t()}).catch(t=>{clearTimeout(o),n(t)})})}async loop(...t){const{ctx:e}=this.logCtx(t,this.loop),r=this.config.autoShutdown??{enabled:!1,backoffStepMs:0,maxIdleDelayMs:this.config.pollMsIdle},s=Math.max(r.maxIdleDelayMs??this.config.pollMsIdle,this.config.pollMsIdle),i=r.backoffStepMs??0;for(;await this.isRunning();){const t=await this.claimBatch(e);await Promise.allSettled(t.map(t=>this.executeClaimed(t)));const n=0===t.length;if(n)if(r.enabled){if(this.idleDelayMs=Math.min(this.idleDelayMs+i,s),this.idleDelayMs>=s)return e.logger.info(`auto-shutdown triggered after ${this.idleDelayMs}ms idle polling`),void await this.stop(e)}else this.idleDelayMs=this.config.pollMsIdle;else this.idleDelayMs=this.config.pollMsIdle;const o=n?this.idleDelayMs:this.config.pollMsBusy;await Xs(Math.max(o,0))}}async claimBatch(t){const e=t.logger.for(this.claimBatch),r=new Date,s=ne.attribute("status").eq(Ie.PENDING),i=ne.attribute("status").eq(Ie.WAITING_RETRY).and(ne.attribute("nextRunAt").lte(r)),n=ne.attribute("status").eq(Ie.RUNNING).and(ne.attribute("leaseExpiry").lte(r)),o=ne.attribute("status").eq(Ie.SCHEDULED).and(ne.attribute("scheduledTo").lte(r)),a=s.or(i).or(n).or(o),c=await this.tasks.select().where(a).limit(Math.max(4*this.config.concurrency,20)).execute();e.verbose("claimBatch candidates:"+c.length);const l=[];for(const e of c){const r=await this.tryClaim(e,t);if(r&&l.push(r),l.length>=this.config.concurrency)break}return e.verbose("claimBatch claimed:"+l.length),l}async tryClaim(t,e){const r=e.logger.for(this.claimBatch),s=(new Date).getTime();let i=t;try{i=await this.tasks.read(t.id,e)}catch{}if(!await this.isRunnable(i,e))return null;const n=new Fs({...i,status:Ie.RUNNING,leaseOwner:this.config.workerId.toString(),leaseExpiry:new Date(s+(parseInt(this.config.leaseMs.toString())||6e4)),scheduledTo:void 0,nextRunAt:void 0});r.info(`running handler for ${t.id} (${t.classification}) atomicity ${t.atomicity}`);try{return await this.tasks.update(n,e)}catch{return null}}isTaskFinished(t){return[Ie.SUCCEEDED,Ie.FAILED,Ie.CANCELED].includes(t)}parseTaskDependency(t){const e=t?.trim();if(!e)return;const r=e.lastIndexOf(":");if(0>=r||r>=e.length-1)return{taskId:e};const s=e.slice(0,r).trim(),i=e.slice(r+1).trim();return s&&i?{taskId:s,stepRef:i}:{taskId:e}}normalizeDependencies(t){if(!t)return[];let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{e=[e]}return e instanceof Set&&(e=Array.from(e)),Array.isArray(e)?e.filter(t=>"string"==typeof t).map(t=>this.parseTaskDependency(t)).filter(Boolean):[]}resolveDependencyStepIndex(t,e){const r=e.trim();if(!r)return;const s=Number(r);if(Number.isInteger(s)&&s>=0)return s;const i=this.normalizeSteps(t.steps).findIndex(t=>t.name===r||t.classification===r);return 0>i?void 0:i}async areDependenciesSatisfied(t,e){if(!t.length)return!0;const r=Array.from(new Set(t.map(t=>t.taskId))),s=new Map;try{const t=await this.tasks.readAll(r,e);for(const e of t)e?.id&&s.set(e.id,e)}catch{return!1}for(const e of t)try{const t=s.get(e.taskId);if(!t)return!1;if(!e.stepRef){if(!this.isTaskFinished(t.status))return!1;continue}const r=this.resolveDependencyStepIndex(t,e.stepRef);if(null==r)return!1;const i=this.normalizeStepResults(t.stepResults)[r];if(!i||!this.isTaskFinished(i.status))return!1}catch{return!1}return!0}getStepLock(t,e){if(t.atomicity!==$e.COMPOSITE)return;const r=this.normalizeSteps(t.steps);if(!r.length)return;const s=r[e??0];return s?.lock}async hasLockConflict(t,e,r){const s=[t.lock,this.getStepLock(t,e)].filter(t=>!!t&&"string"==typeof t);if(!s.length)return!1;const i=await this.tasks.select().where(ne.attribute("status").eq(Ie.RUNNING)).execute(r);for(const e of i)if(e.id!==t.id&&[e.lock,this.getStepLock(e,e.currentStep)].filter(t=>!!t&&"string"==typeof t).some(t=>s.includes(t)))return!0;return!1}async isRunnable(t,e){const r=this.normalizeDependencies(t.dependencies);if(!await this.areDependenciesSatisfied(r,e))return!1;const s=t.atomicity===$e.COMPOSITE?t.currentStep??0:void 0;return!await this.hasLockConflict(t,s,e)}async executeClaimed(t){const{ctx:e,log:r}=(await this.logCtx([],t.classification,!0)).for(this.executeClaimed),s=this;let i=Promise.resolve();const n=new Zs(e).accumulate({taskId:t.id,logger:new Vs(r,this.config.streamBufferSize,this.config.maxLoggingBuffer),attempt:t.attempt,resultCache:{"task.attempt":t.attempt},pipe:async function(...e){const r=s.normalizePipeArgs(e);r.length&&(i=i.then(async()=>{const[e,i]=await s.appendLog(this,t,r);Object.assign(t,e),await s.emitLog(this,t.id,i)}),await i)},flush:async()=>n.logger.flush(n.pipe),progress:async e=>{await this.emitProgress(n,t.id,e)},heartbeat:async()=>{if(t.leaseOwner===this.config.workerId){t.leaseExpiry=new Date(Date.now()+this.config.leaseMs);try{t=await this.tasks.update(t)}catch{}}}});let o,a;await this.emitStatus(n,t,Ie.RUNNING);try{let e;if(t.atomicity===$e.COMPOSITE){e=await this.runComposite(t,n);try{const e=await this.tasks.read(t.id,n);Object.assign(t,e)}catch{}e?.stepResults&&(t.stepResults=e.stepResults,t.currentStep=e.stepResults.length)}else{const s=this.registry.get(t.classification);if(o=s,a=t.input,r.debug(`handler type for ${t.id} is ${s?.constructor?.name??"none"}`),!s)throw new u("No task handler registered for type: "+t.classification);e=await s.run(t.input,n),await n.flush(),r.verbose("handler finished for "+t.id)}t.status=Ie.SUCCEEDED,t.output=e,t.error=void 0,t.leaseOwner=void 0,t.leaseExpiry=void 0;const s=await this.tasks.update(t,n);Object.assign(t,s),n.logger.info(`task ${t.id} success state ${t.status}`),r.info(`task ${t.id} success state ${t.status} attempt ${t.attempt}`),await this.emitStatus(n,t,Ie.SUCCEEDED,e)}catch(e){try{await n.flush()}catch{}try{const e=await this.tasks.read(t.id,n);Object.assign(t,e)}catch{}if(e instanceof Ks)return void await this.handleTaskStateChange(e.request,t,n);try{await(o?.catch?.(a,e,n))}catch(t){r.error("task handler catch() hook failed",t)}if(r.error("task execution error",e),t.atomicity===$e.COMPOSITE){const e=this.normalizeStepResults(t.stepResults);if(t.stepResults=e,null==t.currentStep){const r=e.findIndex(t=>t.status===Ie.FAILED);0>r||(t.currentStep=r)}}const s=(t.attempt??0)+1,i=Js(e);if(s<t.maxAttempts){const o=Ws(s,this.normalizeBackoff(t.backoff)),a=new Date(Date.now()+o);t.attempt=s,t.status=Ie.WAITING_RETRY,t.nextRunAt=a,t.error=i,t.leaseOwner=void 0,t.leaseExpiry=void 0;const c=await this.tasks.update(t,n);Object.assign(t,c),r.warn(`task ${t.id} waiting retry state ${t.status} attempt ${t.attempt}`),await n.pipe(G.warn,"Retry scheduled",{nextRunAt:a,delayMs:o,attempt:s}),await this.emitStatus(n,t,Ie.WAITING_RETRY,i,e)}else{t.attempt=s,t.status=Ie.FAILED,t.error=i,t.leaseOwner=void 0,t.leaseExpiry=void 0;const o=await this.tasks.update(t,n);Object.assign(t,o),r.error(`task ${t.id} failed state ${t.status} attempt ${t.attempt}`),await n.pipe(G.error,"Task failed (max attempts reached)",{maxAttempts:t.maxAttempts}),await this.emitStatus(n,t,Ie.FAILED,i,e)}}}async handleTaskStateChange(t,e,r){switch(e.leaseOwner=void 0,e.leaseExpiry=void 0,t.status){case Ie.CANCELED:{const s=t.error??new Bs({message:`Task ${e.id} canceled`});return e.status=Ie.CANCELED,e.error=s,e.nextRunAt=void 0,e.scheduledTo=void 0,e=await this.tasks.update(e,r),await this.emitStatus(r,e,Ie.CANCELED,s),void await r.pipe(G.warn,"Task canceled via context")}case Ie.WAITING_RETRY:{const s=(e.attempt??0)+1,i=Ws(s,this.normalizeBackoff(e.backoff)),n=t.scheduledTo instanceof Date?t.scheduledTo:new Date(Date.now()+i),o=t.error??new Bs({message:`Task ${e.id} requested retry`});return e.status=Ie.WAITING_RETRY,e.attempt=s,e.error=o,e.nextRunAt=n,e.scheduledTo=void 0,e=await this.tasks.update(e,r),await this.emitStatus(r,e,Ie.WAITING_RETRY,o),void await r.pipe(G.warn,"Retry requested",{nextRunAt:n,delayMs:i,attempt:s})}case Ie.SCHEDULED:{if(!t.scheduledTo)throw new u("Scheduled state requires a target date");const s=t.error??new Bs({message:`Task ${e.id} rescheduled`});return e.status=Ie.SCHEDULED,e.scheduledTo=t.scheduledTo,e.error=s,e.nextRunAt=void 0,e=await this.tasks.update(e,r),await this.emitStatus(r,e,Ie.SCHEDULED,s),void await r.pipe(G.info,"Task rescheduled",{scheduledTo:t.scheduledTo.toISOString()})}default:throw new u("Unsupported task state change requested: "+t.status)}}async runComposite(t,e){const{ctx:r}=(await this.logCtx([e],t.classification,!0)).for(this.runComposite);let s=this.normalizeSteps(t.steps),i=t.currentStep??0;const n=this.normalizeStepResults(t.stepResults),o=(t,s)=>{e.cacheResult(t,s),r instanceof Zs&&r!==e&&r.cacheResult(t,s)};for(let e=0;e<n.length;e+=1){const r=n[e];if(r?.status===Ie.SUCCEEDED){const i=s[e];if(!i)continue;const n=`${t.id}:step:${e}`;o(i.classification,r.output),o(n,r.output)}}for(;i<s.length;){e.setStep(i);const a=s[i],c=this.registry.get(a.classification);if(!c)throw Error("No task handler registered for composite step: "+a.classification);const l=this.normalizeDependencies(a.dependsOn);await this.areDependenciesSatisfied(l,e)||e.reschedule(new Date(Date.now()+this.config.pollMsIdle),`Waiting dependencies for step ${i} (${a.classification})`),await this.hasLockConflict(t,i,e)&&e.reschedule(new Date(Date.now()+this.config.pollMsIdle),`Waiting lock for step ${i} (${a.classification})`),t.currentStep=i;const u=await this.tasks.update(t);Object.assign(t,u),await e.progress({currentStep:i,totalSteps:s.length});const d=i;e.cache.put("scheduleCompositeSteps",async r=>{const i=this.normalizeSteps(r);if(!i.length)return;const n=this.normalizeSteps(t.steps),o=Math.min(d+1,n.length);n.splice(o,0,...i),t.steps=n;const a=await this.tasks.update(t,e);Object.assign(t,a),s=this.normalizeSteps(t.steps);const c=await this.persistEvent(e,t.id,Re.UPDATE,{status:"update",currentStep:d,totalSteps:s.length,output:{added:i.length,insertionIndex:o}});this.bus.emit(c,e)}),await e.pipe([G.info,`Composite step ${i+1}/${s.length}: ${a.classification}`]);try{const r=await c.run(a.input,e);await e.flush();const l=new Date;n[d]=new Ls({status:Ie.SUCCEEDED,output:r,createdAt:l,updatedAt:l});const u=`${t.id}:step:${d}`;o(a.classification,r),o(u,r),i=d+1,t.stepResults=n,t.currentStep=i;const h=await this.tasks.update(t);Object.assign(t,h),await this.emitProgress(e,t.id,{currentStep:i,totalSteps:s.length,output:r})}catch(s){try{await(c.catch?.(a.input,s,e))}catch(t){r.logger.warn("composite step catch() hook failed",{error:t})}const o=new Date;n[i]=new Ls({status:Ie.FAILED,error:Js(s),createdAt:o,updatedAt:o}),t.stepResults=n,t.currentStep=i,t.error=Js(s);const l=await this.tasks.update(t);throw Object.assign(t,l),s}}return{stepResults:n}}normalizeBackoff(t){if(t instanceof Is)return t;let e=t??{};if("string"==typeof e)try{e=JSON.parse(e)}catch{e={}}return new Is(e)}normalizeSteps(t){if(!t)return[];let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{return[]}return e instanceof Set&&(e=Array.from(e)),Array.isArray(e)?e.map(t=>{if(t instanceof Ms)return t;let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{e={}}return new Ms(e)}):[]}normalizeStepResults(t){if(!t)return[];let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{return[]}return e instanceof Set&&(e=Array.from(e)),Array.isArray(e)?e.map(t=>{if(t instanceof Ls)return t;let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{e={}}return new Ls(e)}):[]}async appendLog(t,e,r){const s=Array.isArray(r)&&Array.isArray(r[0]),i=e.atomicity===$e.COMPOSITE?t instanceof Zs?t.step??e.currentStep:e.currentStep:void 0,n=(s?r:[r]).map(([t,e,r])=>new $s({level:t,msg:e,meta:r,step:i})),o=[...e.logTail??[],...n].slice(-this.config.logTailMax);e.logTail=o;try{return[await this.tasks.update(e,t),n]}catch{return[e,[]]}}async emitStatus(t,e,r,s,i){t instanceof Zs&&await t.flush();const n={status:r};s&&s instanceof Bs?n.error=s:s&&(n.output=s),e.nextRunAt&&(n.nextRunAt=e.nextRunAt),e.scheduledTo&&(n.scheduledTo=e.scheduledTo);const o=await this.persistEvent(t,e.id,Re.STATUS,n),a=void 0!==i?Object.assign({},n,{originalError:i}):n,c=new Ps({...o,payload:a});this.bus.emit(c,t)}async emitLog(t,e,r){const s=await this.persistEvent(t,e,Re.LOG,r.map(t=>({ts:t.ts,level:t.level,msg:t.msg,meta:t.meta,step:t.step})));this.bus.emit(s,t)}normalizePipeArgs(t){if(!t.length)return[];if(1===t.length){const e=t[0];return Array.isArray(e)?0===e.length?[]:Array.isArray(e[0])?e.filter(Array.isArray):[e]:[]}const[e,r,s]=t;return"string"!=typeof e||"string"!=typeof r?[]:[[e,r,s]]}async emitProgress(t,e,r){const s=await this.persistEvent(t,e,Re.PROGRESS,r);this.bus.emit(s,t)}async persistEvent(t,e,r,s){const i=new Ps({taskId:e,classification:r,payload:s});return await this.events.create(i,t)}toString(){return`TaskEngine<${this.config.adapter.alias}>`}async context(t,e,...r){return this.adapter.context(t,e,Fs,...r)}}class ui extends Es{constructor(){super(Ps)}get repo(){return this._repository||(this._repository=hs.get(Fs).events),this._repository}}class di extends ps{get adapter(){return this.client.adapter}get tasks(){return this.client.tasks}get events(){return this.client.events}constructor(){super()}async initialize(...t){const e=t.shift();if(!e||e instanceof Rt)throw new u("No/invalid config provided");if(!e.adapter)throw new u("No adapter provided");return{client:new(e.engine||li)(e),config:e}}async push(t,e=!1,...r){const{ctxArgs:s}=(await this.logCtx(r,a.CREATE,!0)).for(this.push),i=await this.client.push(t,e,...s);return await this.client.isRunning()||this.client.start(),i}async track(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.CREATE,!0)).for(this.push);return this.client.track(t,...r)}select(t){return this.tasks.select(t)}async create(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.CREATE,!0)).for(this.create),s=await this.tasks.create(t,...r);return await this.client.isRunning()||this.client.start(),s}async createAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.CREATE_ALL,!0)).for(this.createAll),s=await this.tasks.createAll(t,...r);return await this.client.isRunning()||this.client.start(),s}async delete(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.DELETE,!0)).for(this.delete);return this.tasks.delete(t,...r)}async deleteAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.DELETE_ALL,!0)).for(this.deleteAll);return this.tasks.deleteAll(t,...r)}async read(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.READ,!0)).for(this.read);return this.tasks.read(t,...r)}async readAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.READ_ALL,!0)).for(this.readAll);return this.tasks.readAll(t,...r)}async query(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.QUERY,!0)).for(this.query),s=this.tasks?.[t];if("function"!=typeof s)throw new u(`Method "${t}" is not implemented`);return s.apply(this.tasks,r)}async update(t,...e){throw new Mt("Updates to tasks are not available")}async updateAll(t,...e){throw new Mt("Updates to tasks are not available")}async listBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.LIST_BY,!0)).for(this.listBy);return this.tasks.listBy(t,e,...s)}async paginateBy(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.PAGE_BY,!0)).for(this.paginateBy);return this.tasks.paginateBy(t,e,r,...i)}async findOneBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_ONE_BY,!0)).for(this.findOneBy);return this.tasks.findOneBy(t,e,...s)}async findBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_BY,!0)).for(this.findBy);return this.tasks.findBy(t,e,...s)}async findByPaginate(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.FIND_BY_PAGINATE,!0)).for(this.findByPaginate);return this.tasks.findByPaginate(t,e,r,...i)}async statement(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.STATEMENT,!0)).for(this.statement);return this.tasks.statement(t,...r)}refresh(t,e,r,...s){return this.tasks.refresh(t,e,r,...s)}observe(t,e){return this.tasks.observe(t,e)}unObserve(t){return this.tasks.unObserve(t)}updateObservers(t,e,r,...s){return this.tasks.updateObservers(t,e,r,...s)}logCtx(t,e,r=!1){const s=this.tasks._adapter.logCtx([this.tasks.class,...t],e,r,this.tasks._overrides||{});function i(t){return t.ctxArgs.shift(),t}return s instanceof Promise?s.then(i):i(s)}async shutdown(...t){const{ctxArgs:e,ctx:r,log:s}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.shutdown);await super.shutdown(...e),s.info("attempting to gracefully shutdown task runner"),await this.client.stop(r),s.verbose("gracefully shutdown task runner")}}function hi(t={count:1},e=0){return function r(s,i,n){return gt(ft(dt.key(Ct.THROTTLE,i),t),(s,i,n)=>{n.value=new Proxy(n.value,{async apply(s,n,o){const a=o,c=(()=>{try{return"function"==typeof t?t(...a):t}catch(t){throw new u("Failed to obtain throttling configuration from handler: "+t)}})(),{log:l,ctx:d}=(await n.logCtx(o,Ct.THROTTLE,!0)).for(r),h=(t=>{const e=(Array.isArray(t)?t:[t]).map(t=>{if(!Number.isFinite(t)||0>t)throw new u("@throttling() argument indexes must be non-negative integers");return t});return Array.from(new Set(e)).sort((t,e)=>t-e)})(e);if(!h.length)throw new u("@throttling() expects at least one argument index to throttle");h.forEach(t=>{if(t>=a.length)throw new u(`@throttling() requires argument index ${t} but only ${a.length} provided`);if(!Array.isArray(a[t]))throw new u(`@throttling() expects argument at index ${t} to be an array`)});const p=h.map(t=>a[t]),g=p[0].length;if(!p.every(t=>t.length===g))throw new u("@throttling() requires all targeted arguments to have the same length");if(0===g)return s.apply(n,a);const f=((t,e,r)=>{if("count"in r){if(0>=r.count)throw new u("@throttling() configuration 'count' must be greater than zero");const e=[];for(let s=0;t>s;s+=r.count)e.push({start:s,end:Math.min(t,s+r.count)});return e}if("bufferSize"in r){if(0>=r.bufferSize)throw new u("@throttling() configuration 'bufferSize' must be greater than zero");const s=[];let i=0,n=0;for(let o=0;t>o;o++){const t=pi(e,o);n>0&&n+t>r.bufferSize?(s.push({start:i,end:o}),i=o,n=t):n+=t}return i>=t&&s.length||s.push({start:i,end:t}),s}return[{start:0,end:t}]})(g,p,c),y=f.map(({start:t,end:e})=>a.map((r,s)=>{const i=h.indexOf(s);return-1===i?r:p[i].slice(t,e)})),m=d.get("breakOnSingleFailureInBulk")??!0,w=[],v=[];for(const t of y){try{gi(await s.apply(n,t),w)}catch(t){if(m)throw t;v.push(t)}c.delayMs&&await new Promise(t=>setTimeout(t,c.delayMs))}if(v.length){l.warn(`${i+""} throttled execution continued with ${v.length} failure(s)`);const t=new AggregateError(v,`Throttled ${i+""} failed for ${v.length} chunk(s)`);throw t.results=w,t}return w}})})(s,i,n)}}function pi(t,e){return t.reduce((t,r)=>t+(t=>{if(null==t)return 0;try{return Buffer.byteLength(JSON.stringify(t))}catch{return 0}})(r[e]),0)}function gi(t,e){Array.isArray(t)?e.push(...t):void 0!==t&&e.push(t)}i([fs(),n("design:type",Function),n("design:paramtypes",[Fs,void 0]),n("design:returntype",Promise)],di.prototype,"create",null),i([fs(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"createAll",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],di.prototype,"delete",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"deleteAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],di.prototype,"read",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"readAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[String,void 0]),n("design:returntype",Promise)],di.prototype,"query",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Fs,void 0]),n("design:returntype",Promise)],di.prototype,"update",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"updateAll",null);const fi=Object.assign({},Nt,{persistMigrationSteps:!0});class yi{constructor(t="migration-task"){this.builder=(new Ys).setClassification("migration-composite").setName(t).setMaxAttempts(1)}addMigrationStep(t){return this.builder.addStep("migration",t),this}addStep(t,e){return this.builder.addStep(t,e),this}build(){return this.builder.build()}}class mi{isVersionHint(t){return!!t}normalize(t,e){return e&&t&&(t.includes(e)||t===e)?e:t||e||"migration"}compare(t,e){return t.localeCompare(e)}gt(t,e){return this.compare(t,e)>0}lte(t,e){return 0>=this.compare(t,e)}}class wi extends ps{constructor(){super(),this.versioning=new mi,this.queuedTaskChain=[],this.reference=wi.name,this.precedence=null}static async migrateAdapters(t,e={},...r){const s=e.flavours?.length?new Set(e.flavours):void 0,i=t.filter(t=>!s||s.has(t.flavour)),n=new Set(t.map(t=>t.alias||t.flavour).filter(Boolean)),o=e.taskService?.client,a=o?.adapter?.alias||o?.adapter?.flavour;if(a&&n.has(a))throw new u(`TaskEngine adapter alias "${a}" cannot participate in the migration targets`);const c=[];for(const t of i){const s=e.handlers?.[t.flavour]||{},n=new wi;c.push(n),await n.boot({persistenceFlavour:t.flavour,targetVersion:e.toVersion,taskMode:!!e.taskMode,includeGenericInTaskMode:!(e.taskMode&&i.length>1),retrieveLastVersion:s.retrieveLastVersion,setCurrentVersion:s.setCurrentVersion,taskService:e.taskService}),e.taskMode?await n.migrateViaTasks(void 0,void 0,...r):await n.migrateNormally(void 0,void 0,...r)}return c}async initialize(...t){const{log:e,ctx:r}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.initialize);try{hs.get(Ct.PERSISTENCE)}catch(t){r.get("ignoreDevSafeGuards")||e.warn("Persistence service not available. this may indicate poor initialization of the persistence layer (or not)")}const s=Object.assign({},t.length?t[0]:fi,fi);return this.versioning=s.versioning||new mi,this.transaction=s.persistMigrationSteps,{config:s,client:s.persistenceFlavour?re.get(s.persistenceFlavour):void 0}}async down(t,e,...r){const{log:s}=this.logCtx(r,this.down);s.verbose(Y("Cleaning up after all migrations").green.bold)}normalizeVersion(t,e){return this.versioning.normalize(t,e)}extractPrecedenceTokens(t){const e=t.precedence;return e?(Array.isArray(e)?e:[e]).map(t=>{if(t&&"string"!=typeof t)return"function"==typeof t?t.name:"string"==typeof t.reference?t.reference:t.constructor?.name?t.constructor.name:void 0}).filter(t=>!!t):[]}referencesMigration(t,e){const r=this.extractPrecedenceTokens(t);return!!r.length&&(r.includes(e.reference)||r.includes(e.migration?.constructor?.name))}precedenceHint(t){return"string"==typeof t.precedence?t.precedence:void 0}compareByPrecedence(t,e){const r=t.migration,s=e.migration,i=this.referencesMigration(r,e),n=this.referencesMigration(s,t);if(i&&!n)return 1;if(n&&!i)return-1;const o=this.extractPrecedenceTokens(r),a=this.extractPrecedenceTokens(s);return o.length!==a.length?o.length-a.length:0}sort(t){const e=[...t].sort((t,e)=>{const r=this.versioning.compare(t.version,e.version);if(0!==r)return r;const s=this.compareByPrecedence(t,e);if(0!==s)return s;const i=t.flavour.localeCompare(e.flavour);return 0!==i?i:t.reference.localeCompare(e.reference)});for(let t=0;t<e.length;t++){const r=e[t],s=e[t+1];if(r&&s&&r.version===s.version&&r.flavour===s.flavour&&0===this.compareByPrecedence(r,s))throw new u(`Unable to deterministically sort flavour migrations for version ${r.version} and flavour ${r.flavour}: ${r.reference} vs ${s.reference}`)}return e}resolveMigration(t){const e=dt.get(t.constructor,Ct.MIGRATION),r=e?.flavour||t.flavour||pt,s=e?.reference||t.reference,i=this.precedenceHint(t);return{migration:t,flavour:r,reference:s,version:this.normalizeVersion(s,i)}}shouldIncludeMigration(t,e,r=!0){return!e||t.flavour===e||r&&t.flavour===pt}collectMigrations(t,e=!0){const r=dt.migrations(),s=[];for(const[i,n]of r){let r;try{r=new n}catch(t){throw new u(`failed to create migration ${i}: ${t}`)}const o=this.resolveMigration(r);this.shouldIncludeMigration(o,t,e)&&s.push(o)}return s}buildExecutionPlan(t){const e=t?.fromVersion?this.normalizeVersion(t.fromVersion):void 0,r=t?.toVersion?this.normalizeVersion(t.toVersion):void 0;return this.sort(this.collectMigrations(t?.targetFlavour,t?.includeGeneric)).filter(t=>!(e&&!this.versioning.gt(t.version,e)||r&&!this.versioning.lte(t.version,r)))}async executeMigration(t,...e){const r=t.migration;let s,i;try{if(s=re.get(t.flavour),!s)throw new u(`failed to create migration ${r.reference}. did you call Service.boot() or use the Persistence Service??`);i=s.client}catch(t){throw new u(`Failed to load adapter to migrate ${r.reference}: ${t}`)}try{await r.up(i,s,...e)}catch(t){throw new jt(`failed to initialize migration ${r.reference}: ${t}`)}try{await r.migrate(i,s,...e)}catch(t){throw new jt(`failed to migrate ${r.reference}: ${t}`)}try{await r.down(i,s,...e)}catch(t){throw new jt(`failed to conclude migration ${r.reference}: ${t}`)}}buildMigrationTaskForPlan(t,...e){const r=[...e],s=new yi;return t.forEach(t=>{const e={reference:t.reference,args:r};s.addMigrationStep(e)}),s.build()}buildMigrationTasksForPlan(t,...e){const r=new Map;for(const e of t){const t=r.get(e.version)||[];t.push(e),r.set(e.version,t)}return[...r.entries()].map(([t,r])=>({version:t,task:this.buildMigrationTaskForPlan(r,...e)}))}createMigrationTask(t,e,...r){const s=this.config,i=!s.taskMode||(s.includeGenericInTaskMode??!0),n=this.buildExecutionPlan({toVersion:t||s.targetVersion,fromVersion:e,targetFlavour:s.persistenceFlavour,includeGeneric:i});return this.buildMigrationTaskForPlan(n,...r)}createMigrationTasks(t,e,...r){const s=this.config,i=!s.taskMode||(s.includeGenericInTaskMode??!0),n=this.buildExecutionPlan({toVersion:t||s.targetVersion,fromVersion:e,targetFlavour:s.persistenceFlavour,includeGeneric:i});return this.buildMigrationTasksForPlan(n,...r)}migrationTaskIdsFromContext(t,e){const r=e[e.length-1],s=r?.pending?.()||r?.pending||{},i=s?.[t];return Array.isArray(i)?i.filter(t=>"string"==typeof t):[]}async migrate(t,e,...r){this.config.taskMode?await this.migrateViaTasks(void 0,void 0,...r):await this.migrateNormally(void 0,void 0,...r)}async migrateNormally(t,e,...r){const{ctxArgs:s,log:i}=(await this.logCtx(r,Ct.MIGRATION,!0)).for(this.migrateNormally),n=this.config,o=n.persistenceFlavour,a=!n.taskMode||(n.includeGenericInTaskMode??!0),c=o?re.get(o):void 0;let l;if(n.retrieveLastVersion&&c){const t=await n.retrieveLastVersion(c,...s);t&&(l=this.normalizeVersion(t))}const u=this.buildExecutionPlan({fromVersion:l,toVersion:n.targetVersion,targetFlavour:o,includeGeneric:a});i.debug("sorted migration before execution: "+u.map(t=>`${t.reference}@${t.version}`));for(const t of u)await this.executeMigration(t,...s);if(n.setCurrentVersion&&c){const t=n.targetVersion||u[u.length-1]?.version||l||void 0;t&&await n.setCurrentVersion(this.normalizeVersion(t),c,...s)}}async migrateViaTasks(t,e,...r){const{ctx:s,ctxArgs:i,log:n}=(await this.logCtx(r,Ct.MIGRATION,!0)).for(this.migrateViaTasks),o=this.config,a=o.persistenceFlavour,c=o.includeGenericInTaskMode??!0,l=a?re.get(a):void 0;let u;if(o.retrieveLastVersion&&l){const t=await o.retrieveLastVersion(l,...i);t&&(u=this.normalizeVersion(t))}const d=this.buildExecutionPlan({fromVersion:u,toVersion:o.targetVersion,targetFlavour:a,includeGeneric:c});if(n.debug("sorted migration before execution: "+d.map(t=>`${t.reference}@${t.version}`)),this.queuedTaskChain=[],d.length){const t=this.buildMigrationTasksForPlan(d,...i);if(o.taskService){let e;for(const r of t){e&&(r.task.dependencies=[...r.task.dependencies||[],e]);const t=await o.taskService.push(r.task,!1,...i);e=t.id,this.queuedTaskChain.push({id:t.id,version:r.version}),t?.id||n.warn("TaskService.push returned missing id for version "+r.version),s.pushPending(Ct.MIGRATION,t.id)}}else{for(const t of d)await this.executeMigration(t,...i);if(o.setCurrentVersion&&l){const t=o.targetVersion||d[d.length-1]?.version||u||void 0;t&&await o.setCurrentVersion(this.normalizeVersion(t),l,...i)}}}}async track(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.MIGRATION,!0)).for(this.track),s=this.config;if(!s.taskService||!s.taskMode)return;const i="string"==typeof t?[t]:Array.isArray(t)?t:void 0,n=this.queuedTaskChain.map(t=>t.id),o=this.migrationTaskIdsFromContext(Ct.MIGRATION,r),a=i?.length?i:n.length?n:o;if(!a.length)return;const c=this.queuedTaskChain.reduce((t,e)=>(t[e.id]=e.version,t),{}),l=this.config.persistenceFlavour?re.get(this.config.persistenceFlavour):void 0;for(const t of a){const{tracker:e}=await s.taskService.track(t,...r);await e.wait(),s.setCurrentVersion&&l&&c[t]&&await s.setCurrentVersion(this.normalizeVersion(c[t]),l,...r)}}async retry(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.MIGRATION,!0)).for(this.retry),s=this.config;if(!s.taskMode||!s.taskService)return void await this.migrateNormally(void 0,void 0,...r);const i="string"==typeof t?[t]:Array.isArray(t)?t:void 0,n=this.queuedTaskChain.map(t=>t.id),o=this.migrationTaskIdsFromContext(Ct.MIGRATION,r),a=i?.length?i:n.length?n:o;if(!a.length)return void await this.migrateViaTasks(void 0,void 0,...r);const c=s.taskService.client.tasks,l="function"==typeof c?.override?c.override({ignoreHandlers:!0}):c;for(const t of a){const e=(await s.taskService.track(t,...r)).task;if(![Ie.FAILED,Ie.CANCELED].includes(e.status))continue;const i=new Fs({...e,status:Ie.PENDING,error:void 0,nextRunAt:void 0,scheduledTo:void 0,leaseOwner:void 0,leaseExpiry:void 0});await l.update(i,...r)}}async up(t,e,...r){const{log:s}=this.logCtx(r,this.down);s.verbose(Y("Setting up migration process").yellow.bold)}}const vi=dt.innerGet(Symbol.for(Ct.MIGRATION),pt)||[];function bi(t,e,r,s){return ht.for(Ct.MIGRATION).define({decorator:(e,r,s)=>i=>{const n=e&&"object"==typeof e&&!("name"in e)?e:void 0,o=n?.precedence,a=n?.flavour,c=n?.rules,l=n?o:e,u=n?a:r,d=n?c:s,h=n?void 0!==o:void 0!==l&&("string"!=typeof l||"string"==typeof l&&"string"==typeof u);let p,g,f=l;"string"==typeof l?"string"==typeof u?(f=l,p=u,g=d):Array.isArray(u)?(f=void 0,p=l,g=u):(f=void 0,p=l,g=d):Array.isArray(u)?g=u:(p=u,g=d),void 0===f&&null!==f&&(f=wi);const y=dt.flavourOf(i)||pt,m=(h&&f===wi&&t&&t!==p?t:p)||y,w=dt.innerGet(Symbol.for([Ct.MIGRATION,Ct.BY_KEY].join("-")),m||pt)||[];return dt.set([Ct.MIGRATION,Ct.BY_KEY].join("-"),m||pt,[...w,{class:i}]),dt.set(Ct.MIGRATION,t,i),vt(Ct.MIGRATION,{reference:t||i.name,precedence:f,flavour:m||pt,rules:g})(i)},args:[e,r,s]}).apply()}dt.set(Ct.MIGRATION,pt,[...vi,wi]);class Ai extends Ft{get reference(){if(!this._reference){const t=dt.get(this.constructor,Ct.MIGRATION);if(this._reference=t.reference,!this._reference)throw new u(`No precedence defined for ${this.constructor.name}. did you use @migration()?`)}return this._reference}get precedence(){if(void 0===this._precedence){const t=dt.get(this.constructor,Ct.MIGRATION);if(this._precedence=t.precedence,!this._precedence)throw new u(`No precedence defined for ${this.constructor.name}. did you use @migration()?`)}return this._precedence}constructor(){super(),this.transaction=!0,[this.up,this.down].forEach(t=>{const e=t.name;Qt(this,t,this.prefix(e))})}get adapter(){const t=dt.get(this.constructor,Ct.MIGRATION);if(!t)throw new u("No migration metadata for "+this.constructor.name);const e=t.flavour;return re.get(e)}async enforceRules(t,e,r){const s=dt.get(this.constructor,Ct.MIGRATION)?.rules;if(!s||!s.length)return!0;for(const i of s)if(!await i(t,e,r))return!1;return!0}prefix(t){return async function(e){let r;e instanceof re?r=this.getQueryRunner(e.client):(r=e,e=this.adapter);const{ctx:s,log:i}=await this.logCtx([t],Ct.MIGRATION,!0);if(!await this.enforceRules(r,e,s))throw i.verbose(`Skipping migration ${this.constructor.name} due to rules`),new Ut("Migration skipped for rule enforcement");return[r,e,s]}.bind(this)}}let Si=class extends zs{async run(t,e){e.logger.info("Executing migration "+t.reference);const r=dt.migrations().find(([,e])=>{const r=e?.name,s=dt.get(e,Ct.MIGRATION)?.reference;return r===t.reference||s===t.reference});if(!r)throw new u(`Migration ${t.reference} is not registered with the metadata layer`);const s=r[1];let i;try{i=new s}catch(e){throw new u(`Failed to instantiate migration ${t.reference}: ${e}`)}const n=dt.get(i.constructor,Ct.MIGRATION),o=n?.flavour||i.flavour,a=re.get(o);if(!a)throw new u("Unable to resolve adapter for migration "+t.reference);const c=a.client,l=t.args??[];try{await i.up(c,a,...l,e)}catch(r){throw e.logger.error(`Up phase for ${t.reference} failed: ${r}`),new jt(`Up phase for ${t.reference} failed: ${r}`)}try{await i.migrate(c,a,...l,e)}catch(r){throw e.logger.error(`migration phase for ${t.reference} failed: ${r}`),new jt(`Migration phase for ${t.reference} failed: ${r}`)}try{await i.down(c,a,...l,e)}catch(r){throw e.logger.error(`down phase for ${t.reference} failed: ${r}`),new jt(`Down phase for ${t.reference} failed: ${r}`)}e.logger.info(`migration ${t.reference} completed`)}};Si=i([qs("migration")],Si),e.setRegistry(new Me);const xi="##VERSION##",Ei="##PACKAGE##";dt.registerLibrary(Ei,xi);export{Ft as AbsContextual,Ai as AbsMigration,re as Adapter,Xt as AdapterTransaction,ze as AuthKeys,Nr as AuthorizationError,Be as BackoffStrategy,es as BaseModel,Je as BigIntSequence,ae as Cascade,Hs as CleanUpTask,ps as ClientBasedService,Ys as CompositeTaskBuilder,ne as Condition,_r as ConnectionError,Rt as Context,Kt as ContextLock,$t as ContextualLoggedClass,Nt as DefaultAdapterFlags,ce as DefaultCascade,Tt as DefaultContextFlags,fi as DefaultMigrationConfig,Ee as DefaultRepositoryFilters,Qe as DefaultSequenceOptions,Ue as DefaultTaskEngineConfig,Os as Dispatch,Dr as ForbiddenError,Ot as GroupOperator,Me as InjectablesRegistry,Pe as JitterStrategy,de as MethodQueryBuilder,jt as MigrationError,Ut as MigrationRuleError,wi as MigrationService,Si as MigrationTask,yi as MigrationTaskBuilder,Es as ModelService,Bt as MultipleSelectOperationKeys,_t as NonTransactionOperationKeys,Ve as NoneSequenceOptions,We as NumericSequence,Ye as ObserverError,Lt as ObserverHandler,Et as Operator,le as OperatorsMap,oe as OrderDirection,Ei as PACKAGE_NAME,Pt as PaginationOperationKeys,ss as Paginator,ie as PagingError,Ct as PersistenceKeys,_s as PersistenceService,kt as PreparedStatementKeys,xt as QueryClause,se as QueryError,Fe as Repository,It as SelectOperationKeys,Ts as Sequence,rs as SequenceModel,Jt as Serial,hs as Service,mi as StandardMigrationVersioning,ds as Statement,js as TaskBackoffBuilder,Is as TaskBackoffModel,Us as TaskBuilder,oi as TaskCancelError,Zs as TaskContext,si as TaskControlError,li as TaskEngine,Bs as TaskErrorModel,ei as TaskEventBus,Ps as TaskEventModel,ui as TaskEventService,Re as TaskEventType,ii as TaskFailError,zs as TaskHandler,ti as TaskHandlerRegistry,Rs as TaskIOSerializer,$s as TaskLogEntryModel,Vs as TaskLogger,Fs as TaskModel,ai as TaskRescheduleError,ni as TaskRetryError,di as TaskService,Ie as TaskStatus,Ls as TaskStepResultModel,Gs as TaskStepSpecBuilder,Ms as TaskStepSpecModel,ci as TaskTracker,$e as TaskType,je as TasksKey,Dt as TransactionOperationKeys,Wt as UUID,Mt as UnsupportedError,xi as VERSION,qe as allowIf,fe as applyViewDecorator,bs as auth,He as blockIf,Er as cacheModelForPopulate,kr as cascadeDelete,Br as column,Ws as computeBackoffMs,fs as create,or as createOrUpdate,Mr as createdAt,Fr as createdBy,$r as createdByOnCreateUpdate,he as defaultQueryAttr,ws as del,Le as generateInjectableNameForRepository,Ns as getAdapterTransaction,vr as getAndConstructJunctionTable,Ds as getContextLock,Oe as getFilters,Qs as getLogPipe,qr as getPkTypes,Sr as getPopulateKey,xr as getTagForDeleteKey,Xe as index,Gt as injectableServiceKey,Ht as isOperationBlocked,ri as isTaskError,Wr as manyToMany,mr as manyToManyOnCreate,Ar as manyToManyOnDelete,br as manyToManyOnUpdate,Qr as manyToOne,pr as manyToOneOnCreate,yr as manyToOneOnDelete,fr as manyToOneOnUpdate,bi as migration,Jr as noValidateOn,Xr as noValidateOnCreate,Zr as noValidateOnCreateUpdate,Kr as noValidateOnUpdate,Vt as normalizeImport,Vr as oneToMany,ur as oneToManyOnCreateUpdate,hr as oneToManyOnDelete,dr as oneToManyOnUpdate,Hr as oneToOne,ar as oneToOneOnCreate,lr as oneToOneOnDelete,cr as oneToOneOnUpdate,Se as onlyOnBulk,me as onlyOnCreate,ve as onlyOnDelete,xe as onlyOnFilter,Ae as onlyOnSingle,be as onlyOnTransactional,we as onlyOnUpdate,Yr as persistentVersion,ir as pk,rr as pkDec,tr as pkOnCreate,Or as populate,Qt as prefixMethod,pe as prepared,Yt as promiseSequence,ge as query,ys as read,ts as relation,Ge as repository,Tr as repositoryFromTypeMetadata,ee as resolveBulkSequenceResult,As as roles,Ss as route,nr as sequence,sr as sequenceDec,er as sequenceOnCreateUpdate,Js as serializeError,vs as service,Xs as sleep,Ir as table,qs as task,hi as throttle,Rr as unique,Pr as uniqueOnCreateUpdate,ms as update,jr as updatedAt,Lr as updatedBy,Cs as uuid,ks as uuidCreateUpdateHandler,gr as validBidirectionalRelation,zr as version,ye as view};
1
+ import{InjectableRegistryImp as t,Injectables as e,inject as r,injectable as s}from"@decaf-ts/injectable-decorators";import{__decorate as i,__metadata as n}from"tslib";import{DefaultRepositoryFlags as o,OperationKeys as a,BulkCrudOperationKeys as c,Context as l,InternalError as u,ValidationError as d,Repository as h,wrapMethodWithContext as p,wrapMethodWithContextForUpdate as g,enforceDBDecorators as f,reduceErrorsToPrint as y,NotFoundError as m,DefaultSeparator as w,DBKeys as v,readonly as b,onCreate as A,generated as x,onUpdate as E,BadRequestError as O,timestamp as k,onCreateUpdate as C,ConflictError as T,version as N,afterAny as D,onDelete as _,SerializationError as I,prefixMethod as B,composed as P,transient as R,serialize as $,BaseError as F}from"@decaf-ts/db-decorators";import{Logging as L,LoggedClass as M,final as j,toCamelCase as U,LogLevel as G,style as Y}from"@decaf-ts/logging";import{Model as z,hashObj as q,required as H,sf as V,isEqual as Q,model as W,ValidationKeys as J,type as X,async as Z,list as tt,option as et,date as rt,JSONSerializer as st,ModelKeys as it,min as nt,minlength as ot,gt as at}from"@decaf-ts/decorator-validation";import{Lock as ct,MultiLock as lt,TransactionalKeys as ut}from"@decaf-ts/transactional-decorators";import{Metadata as dt,Decoration as ht,DefaultFlavour as pt,apply as gt,methodMetadata as ft,propMetadata as yt,DecorationKeys as mt,uses as wt,metadata as vt,prop as bt,method as At,description as St}from"@decaf-ts/decoration";var xt,Et,Ot,kt,Ct;(t=>{t.FIND_BY="findBy",t.PAGE_BY="pageBy",t.COUNT_BY="countBy",t.SUM_BY="sumBy",t.AVG_BY="avgBy",t.MIN_BY="minBy",t.MAX_BY="maxBy",t.DISTINCT_BY="distinctBy",t.GROUP_BY_PREFIX="groupBy",t.SELECT="Select",t.AND="And",t.OR="Or",t.GROUP_BY="GroupBy",t.ORDER_BY="OrderBy",t.THEN="Then",t.THEN_BY="ThenBy"})(xt||(xt={})),(t=>{t.EQUAL="EQUAL",t.DIFFERENT="DIFFERENT",t.BIGGER="BIGGER",t.BIGGER_EQ="BIGGER_EQ",t.SMALLER="SMALLER",t.SMALLER_EQ="SMALLER_EQ",t.BETWEEN="BETWEEN",t.NOT="NOT",t.IN="IN",t.REGEXP="REGEXP",t.STARTS_WITH="STARTS_WITH",t.ENDS_WITH="ENDS_WITH",t.GROUP_BY="group-by",t.COUNT="count",t.SUM="sum",t.MAX="v_max",t.MIN="v_min",t.DISTINCT="distinct",t.VIEW="view"})(Et||(Et={})),(t=>{t.AND="AND",t.OR="OR"})(Ot||(Ot={})),(t=>{t.LIST_BY="listBy",t.FIND_BY="findBy",t.FIND_BY_PAGINATE="findByPaginate",t.FIND_ONE_BY="findOneBy",t.PAGE_BY="paginateBy",t.FIND="find",t.PAGE="page",t.COUNT_OF="countOf",t.MAX_OF="maxOf",t.MIN_OF="minOf",t.AVG_OF="avgOf",t.SUM_OF="sumOf",t.DISTINCT_OF="distinctOf",t.GROUP_OF="groupOf"})(kt||(kt={})),(t=>{t.PERSISTENCE="persistence",t.INDEX="index",t.SEQUENCE="sequence",t.UNIQUE="unique",t.ADAPTER="adapter",t.INJECTABLE="decaf_{0}_adapter_for_{1}",t.SERVICE="service",t.TABLE="table",t.COLUMN="column",t.METADATA="__metadata",t.OWNERSHIP="ownership",t.CREATED_BY="ownership.created-by",t.UPDATED_BY="ownership.updated-by",t.RELATIONS="__relations",t.RELATION="relation",t.ONE_TO_ONE="relation.one-to-one",t.ONE_TO_MANY="relation.one-to-many",t.MANY_TO_ONE="relation.many-to-one",t.MANY_TO_MANY="relation.many-to-many",t.POPULATE="populate",t.NO_VALIDATE="no-validate",t.MIGRATION="migration",t.STATEMENT="statement",t.QUERY="query",t.UUID="uuid",t.TAG_FOR_DELETION="tag_for_deletion",t.INITIALIZATION="initialization",t.SHUTDOWN="shutdown",t.BY_KEY="by-key",t.AUTH="auth",t.AUTH_ROLE="auth-role",t.DECAF_ROUTE="DecafRoute",t.THROTTLE="throttle",t.PERSISTENT_VERSION="persistent-version",t.DEFAULT_QUERY_ATTR="default-query-attr"})(Ct||(Ct={}));const Tt=Object.assign({},{ignoreDevSafeGuards:!1}),Nt=Object.assign({},o,{enforceUpdateValidation:!0,allowRawStatements:!0,forcePrepareSimpleQueries:!1,forcePrepareComplexQueries:!1,cacheForPopulate:{},preferFromCache:!1,noEmit:!1,noEmitSingle:!1,noEmitBulk:!1,breakOnSingleFailureInBulk:!0,observeFullResult:!0,paginateByBookmark:!1,dryRun:!1,afterQueryHandlers:!1}),Dt=[a.CREATE,a.UPDATE,a.DELETE,c.CREATE_ALL,c.UPDATE_ALL,c.DELETE_ALL],_t=[a.READ,c.READ_ALL],It=[Ct.STATEMENT,kt.FIND_ONE_BY],Bt=[Ct.QUERY,kt.PAGE_BY,kt.FIND_BY_PAGINATE,kt.LIST_BY,kt.FIND_BY,kt.FIND,kt.PAGE],Pt=[kt.PAGE_BY,kt.FIND_BY_PAGINATE,kt.PAGE];class Rt extends l{constructor(t){super(t)}static{this.factory=t=>(new Rt).accumulate(Object.assign({},t,{timestamp:new Date,logger:t.logger||L.get()}))}static async from(t,e,r,...s){return this.factory(Object.assign({},e||{},{operation:t,model:r,affectedTables:r,args:s,logger:e?.logger||L.get()}))}pushPending(t,e){const r=this.pending()||{};if(r[t]=r[t]||[],r[t].includes(e))throw new u(`Trying to push a repeated pending ${t} task: ${e}`);r[t].push(e),this.accumulate({pending:r})}getFromChildren(t,e=new Set){if(e.has(this))return;e.add(this);const r=this.getOrUndefined(t);if(null!=r)return r;let s=this.getOrUndefined("childContexts");if(s&&s.length&&(s=s.filter(t=>!e.has(t)),s.length)){const r=s.map(r=>r.getFromChildren(t,e)).reduce((t,e)=>(Array.isArray(e)?t.push(...e):null!=e&&t.push(e),t),[]).filter(t=>null!=t);if(!r.length)return;return r.some(t=>"object"!=typeof t)?r[0]:r.reduce((t,e)=>Object.assign(t,e),{})}}pending(){return this.getFromChildren("pending")}getOrUndefined(t){try{return this.get(t)}catch(t){return}}override(t){return new Proxy(this,{get:(e,r,s)=>"get"===r?new Proxy(e.get,{apply:(e,r,i)=>{const n=i[0];if(!n)throw new u("Invalid property access to overridden context: "+n);return n in t?t[n]:Reflect.apply(e,s,i)}}):Reflect.get(e,r,s)})}toOverrides(){return this.cache.keys().reduce((t,e)=>(t[e]=this.get(e),t),{})}accumulate(t){return super.accumulate(t)}}class $t extends M{logCtx(t,e,r=!1,s){return $t.logCtx.call(this,e,s||{},r,...t.filter(t=>void 0!==t))}static logFrom(t,e,r,s){const i=t.context?e.clear().for(t):e.for(t);return s?i.for(s):i}static logCtx(t,e,r=!1,...s){const i=(t,e,r)=>{const s=e.log||L.get();return e.log=t.context?s.clear().for(t):s.for(t),"string"==typeof r?e.for=t=>Object.assign(e,{log:e.log.for(t)}):e.log=e.log.for(r),e};let n=s.pop();const o=n instanceof Rt||(t=>{if(!t||"object"!=typeof t)return!1;const e=t;return"function"==typeof e.get&&"function"==typeof e.accumulate&&"function"==typeof e.override&&"function"==typeof e.toOverrides&&void 0!==e.cache})(n);if(n&&!o&&(s.push(n),n=void 0),!r&&!o)throw new u("No context provided");if(o&&!r){if(!n)throw new u("Missing context. should be impossible");return i(this,{log:n.logger,ctx:n,ctxArgs:[...s,n]},t)}return async function(...r){if(!this)throw new u("No contextual provided");if(!this.context)throw new u("Invalid contextual provided");return this.context("string"==typeof t?t:t.name,e||{},...r)}.call(this,...[...s,n].filter(Boolean)).then(e=>i(this,{log:e.logger,ctx:e,ctxArgs:[...s,e]},t))}}class Ft extends $t{constructor(){super(),this._Context=Rt}get Context(){return this._Context}async context(t,e,...r){this.log.for(this.context).debug(`Creating new context for ${"string"==typeof t?t:t.name} operation with flag overrides: ${Object.keys(e)}`);let s=r.pop();return s instanceof Rt||(r.push(s),s=void 0),this.flags,!s||s instanceof this.Context?(new this.Context).accumulate(e):new this.Context(s).accumulate(e)}}class Lt{constructor(){this.observers=[]}count(){return this.observers.length}observe(t,e){if(-1!==this.observers.map(t=>t.observer).indexOf(t))throw new u("Observer already registered");return this.observers.push({observer:t,filter:e}),()=>this.unObserve(t)}unObserve(t){const e=this.observers.map(t=>t.observer).indexOf(t);if(-1===e)throw new u("Failed to find Observer");this.observers.splice(e,1)}async updateObservers(t,e,r,...s){const{log:i,ctxArgs:n}=$t.logCtx(this.updateObservers,void 0,!1,...s);(await Promise.allSettled(this.observers.filter(s=>{const{filter:o}=s;if(!o)return!0;try{return o(t,e,r,...n)}catch(t){return i.error(`Failed to filter observer ${s.observer.toString()}: ${t}`),!1}}).map(s=>{s.observer.refresh(t,e,r,...n)}))).forEach((t,e)=>{"rejected"===t.status&&i.error(`Failed to update observable ${this.observers[e].toString()}: ${t.reason}`)})}}class Mt extends u{constructor(t){super(t,Mt.name,500)}}class jt extends u{constructor(t,e=jt.name){super(t,e,500)}}class Ut extends jt{constructor(t){super(t,Ut.name)}}function Gt(t){if(!t)throw new u("No name provided");return"string"==typeof t?t.replaceAll(".","-"):dt.Symbol(dt.constr(t)).toString().replaceAll(".","-")}async function Yt(t,e=!1){if(!e){const e=[];for(const r of t)e.push(await r());return e}const r=[];for(const e of t)try{r.push({status:"fulfilled",value:await e()})}catch(t){r.push({status:"rejected",reason:t})}return r}const zt=[a.CREATE,a.READ,a.UPDATE,a.DELETE];function qt(t){return zt.includes(t)}function Ht(t,e,r){const s=dt.get(t,a.REFLECT+a.BLOCK)||{};if(!s?.handler)return!1;const i=void 0===r&&qt(e)?"crud":e,n=void 0===r&&qt(e)?e:r,o=s.args?.[0]||[];return s.handler(o,i,n)??!1}async function Vt(t){return t.then(t=>t.default||t)}function Qt(t,e,r,s){const i=async function(...t){let s;try{s=await Promise.resolve(r.call(this,...t))}catch(t){if(t instanceof Ut)return;throw t}return Promise.resolve(e.apply(this,s))}.bind(t),n=s||e.name;Object.defineProperty(i,"name",{enumerable:!0,configurable:!0,writable:!1,value:n}),t[n]=i}class Wt{generate(t){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{const e=16*Math.random()|0;return("x"==t?e:3&e|8).toString(16)})}static get instance(){return Wt._instance||(Wt._instance=new Wt),Wt._instance}}class Jt{constructor(){this.count=14}generate(t){return(""+((t=(t?parseInt(t):0)||0)+1)).padStart(this.count,"0")}static get instance(){return Jt._instance||(Jt._instance=new Jt),Jt._instance}}class Xt{constructor(t,...e){this.adapter=t}async begin(...t){}async commit(...t){}async rollback(...t){}}class Kt extends ct{constructor(t){super(),this.adapterTransaction=t,this.acquireCount=0,this.lock=new ct}async acquire(...t){await this.lock.acquire(),this.acquireCount++,1===this.acquireCount?(this.lock.release(),await this.adapterTransaction.begin(...t)):this.lock.release()}async release(...t){if(await this.lock.acquire(),this.acquireCount--,0===this.acquireCount)try{await this.adapterTransaction.commit(...t)}catch(e){await this.adapterTransaction.rollback(new u("Failed to submit transaction: "+e),...t)}finally{this.lock.release()}else 0>this.acquireCount?(this.acquireCount=0,this.lock.release()):this.lock.release()}async rollback(t,...e){await this.lock.acquire();try{await this.adapterTransaction.rollback(new u("Failed to submit transaction: "+t),...e)}catch(t){throw new u("Failed to rollback transaction: "+t)}finally{this.lock.release()}}}const Zt=ht.flavourResolver.bind(ht);ht.flavourResolver=t=>{const e=t=>{if(!t)return;const e=re._cache?.[t];return e?.flavour||t};try{const r=Zt(t);if(r&&r!==pt)return e(r);const s="function"==typeof t?t:t?.constructor,i=s&&"function"==typeof dt.registeredFlavour?dt.registeredFlavour(s):void 0;if(i&&i!==pt)return e(i);const n=re._currentFlavour;if(n){const t=re._cache?.[n];return t?.flavour?t.flavour:e(n)}}catch(t){return pt}};const te=Symbol("AdapterProxyCleanup");function ee(t,e,r,s){if(!e)return t;const i=t,n=[],o=[];for(const t of i)"fulfilled"===t.status?n.push(t.value):o.push(t.reason);if(o.length){r.warn(`Bulk ${s} encountered ${o.length} failure(s) while continuing`);const t=new AggregateError(o,`Bulk ${s} failed for ${o.length} item(s)`);throw t.results=i,t}return n}class re extends Ft{static{this._cache={}}get config(){return this._config}get alias(){return this._alias||this.flavour}repository(){if(!re._baseRepository)throw new u("This should be overridden when necessary. Otherwise it will be replaced lazily");return re._baseRepository}transactionLock(...t){return new Xt(this,...t)}async shutdownProxies(t,...e){t&&"string"!=typeof t&&(e=[t,...e],t=void 0);const{log:r}=this.logCtx(e,this.shutdownProxies);if(!this.proxies)return;if(t&&!(t in this.proxies))throw new u("No proxy found for "+t);const s=async t=>{if(!t)return;const e=t[te];"function"==typeof e&&await e()};if(t)try{await s(this.proxies[t]),delete this.proxies[t]}catch(e){r.error("Failed to cleanup proxied adapter "+t,e)}else for(const t in this.proxies){try{await s(this.proxies[t])}catch(e){r.error("Failed to cleanup proxied adapter "+t,e);continue}delete this.proxies[t]}}async shutdown(...t){const{log:e,ctxArgs:r}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.shutdown);await this.internalLock.acquire(Ct.SHUTDOWN);try{if(this.shutdownPromise)return this.shutdownPromise;this.shutdownPromise=(async()=>{const{log:e}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.shutdown);await this.shutdownProxies(...r),this.dispatch&&await this.dispatch.close(...r)})()}catch(t){throw new u("Failed to create shutdown wrapper: "+t)}finally{this.internalLock.release(Ct.SHUTDOWN)}try{await this.shutdownPromise}catch(t){e.error("Error during proxy shutdown",t)}finally{this.shutdownPromise=void 0}}constructor(t,e,r){if(super(),this._config=t,this.flavour=e,this._alias=r,this.internalLock=new ct,this.alias in re._cache)throw new u(`${this.alias} persistence adapter ${this._alias?`(${this.flavour}) `:""} already registered`);re._cache[this.alias]=this,this.alias!==this.flavour&&(this.flavour in re._cache||(re._cache[this.flavour]=this)),this.log.info(`Created ${this.alias} persistence adapter ${this._alias?`(${this.flavour}) `:""} persistence adapter`),re._currentFlavour||(this.log.verbose(`Defined ${this.alias} persistence adapter as current`),re._currentFlavour=this.alias)}Dispatch(){return new re._baseDispatch}ObserverHandler(){return new Lt}isReserved(t){return!t}async initialize(...t){}async Sequence(t,e){return new re._baseSequence(t,this,e)}async flags(t,e,r,...s){if("string"==typeof e)throw new u("Model must be a constructor or array of constructors or undefined. this should be impossible");const i=Array.isArray(e)?e.length?e[0]:void 0:e,n=i?""+z.tableName(i):"";r.correlationId=r.correlationId||`${n}|${t}|${Wt.instance.generate()}`;const o=r.logger||L.for(this),a=Object.assign({},Nt.cacheForPopulate,r.cacheForPopulate);return Object.assign({},Nt,r,{affectedTables:e?[...new Set([...(Array.isArray(e)?e:[e]).filter(Boolean),...r.affectedTables?Array.isArray(r.affectedTables)?r.affectedTables:[r.affectedTables]:[]])]:r.affectedTables,cacheForPopulate:a,args:s,writeOperation:Dt.includes(t),timestamp:new Date,operation:t,ignoredValidationProperties:e?dt.validationExceptions(Array.isArray(e)&&e[0]?e[0]:e,t):[],logger:o})}get Context(){return Rt}async context(t,e,r,...s){this.log.for(this.context).silly(`creating new context for ${t} operation on ${r?Array.isArray(r)?r.map(t=>z.tableName(t)):z.tableName(r):"no"} table ${e&&Object.keys(e)?Object.keys(e).length:"no"} with flag overrides`);let i=s.pop();void 0===i||i instanceof Rt||(s.push(i),i=void 0);const n=(()=>{if(!i)return!1;try{return!!i.get("allowGenerationOverride")}catch{return!1}})();e=i?Object.assign({},i.toOverrides(),e):e,n&&(e.allowGenerationOverride=!0);const o=await this.flags("string"==typeof t?t:t.name,r,e,...[...s,i].filter(Boolean));if(i){if(!(i instanceof this.Context)){const t=(new this.Context).accumulate({...i.cache,...o,parentContext:i});return i.accumulate({childContexts:[...i.getOrUndefined("childContexts")||[],t]}),t}const e=i.getOrUndefined("operation"),s=i.getOrUndefined("affectedTables");if(!e||e!==t||r&&r!==s){const t=(new this.Context).accumulate({...i.cache,...o,parentContext:i});return i.accumulate({childContexts:[...i.getOrUndefined("childContexts")||[],t]}),t}return i.accumulate(o)}return(new this.Context).accumulate({...o})}prepare(t,...e){const{log:r}=this.logCtx(e,this.prepare),s=t.segregate(),i=Object.entries(s.model).reduce((e,[r,s])=>{if(void 0===s)return e;const i=z.columnName(t.constructor,r);if(this.isReserved(i))throw new u(`Property name ${i} is reserved`);return e[i]=s,e},{});return t[Ct.METADATA]&&(r.silly("Passing along persistence metadata for "+t[Ct.METADATA]),Object.defineProperty(i,Ct.METADATA,{enumerable:!1,writable:!0,configurable:!0,value:t[Ct.METADATA]})),{record:i,id:t[z.pk(t.constructor)],transient:s.transient}}revert(t,e,r,s,...i){const{log:n,ctx:o}=this.logCtx(i,this.revert),a=z.pk(e),c=new e;c[a]=r,n.silly(`Rebuilding model ${c.constructor.name} id ${r}`);const l=t[Ct.METADATA],d=Object.keys(c).filter(t=>t!==a).reduce((r,s)=>(r[s]=t[z.columnName(e,s)],r),c);return o.get("rebuildWithTransient")&&s&&(n.verbose("re-adding transient properties: "+Object.keys(s).join(", ")),Object.entries(s).forEach(([t,e])=>{if(t in d&&void 0!==d[t])throw new u(`Transient property ${t} already exists on model ${c.constructor.name}. should be impossible`);d[t]=e})),l&&(n.silly(`Passing along ${this.flavour} persistence metadata for ${c.constructor.name} id ${r}: ${l}`),Object.defineProperty(d,Ct.METADATA,{enumerable:!1,configurable:!0,writable:!0,value:l})),d}async createAll(t,e,r,...s){const{log:i,ctx:n}=this.logCtx(s,this.createAll);if(!e||!r)throw new d("Ids and models cannot be null or undefined");if(e.length!==r.length)throw new d("Ids and models must have the same length");const o=z.tableName(t);i.debug(`Creating ${e.length} entries ${o} table`);const a=!(n.get("breakOnSingleFailureInBulk")??1),l=e.map((e,i)=>()=>this.create(t,e,r[i],...s,n.override({noEmitSingle:!0})));return ee(a?await Yt(l,!0):await Yt(l),a,i,c.CREATE_ALL)}async readAll(t,e,...r){const{log:s,ctx:i}=this.logCtx(r,this.readAll),n=z.tableName(t);s.debug(`Reading ${e.length} entries ${n} table`);const o=!(i.get("breakOnSingleFailureInBulk")??1),a=e.map(e=>()=>this.read(t,e,...r,i.override({noEmitSingle:!0})));return ee(o?await Yt(a,!0):await Yt(a),o,s,c.READ_ALL)}async updateAll(t,e,r,...s){const{log:i,ctx:n}=this.logCtx(s,this.updateAll);if(e.length!==r.length)throw new u("Ids and models must have the same length");const o=z.tableName(t);i.debug(`Updating ${e.length} entries ${o} table`);const a=!(n.get("breakOnSingleFailureInBulk")??1),l=e.map((e,i)=>()=>this.update(t,e,r[i],...s,n.override({noEmitSingle:!0})));return ee(a?await Yt(l,!0):await Yt(l),a,i,c.UPDATE_ALL)}async deleteAll(t,e,...r){const{log:s,ctx:i}=this.logCtx(r,this.deleteAll);s.debug(`Deleting ${e.length} entries from ${t} table`);const n=!(i.get("breakOnSingleFailureInBulk")??1),o=e.map(e=>()=>this.delete(t,e,...r,i.override({noEmitSingle:!0})));return ee(n?await Yt(o,!0):await Yt(o),n,s,c.DELETE_ALL)}observe(t,e){this.observerHandler||Object.defineProperty(this,"observerHandler",{value:this.ObserverHandler(),writable:!1}),this.observerHandler.observe(t,e);const r=this.log.for(this.observe);return r.silly("Registering new observer "+t.toString()),this.dispatch||(r.verbose("Creating dispatch for "+this.alias),this.dispatch=this.Dispatch()),this.dispatch.observe(this),()=>this.unObserve(t)}unObserve(t){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");this.observerHandler.unObserve(t),this.observerHandler.count()>0||(this.log.for(this.unObserve).debug("No active observers for adpter. Closing dispatcher and unobserving."),this.dispatch?.close([]),this.dispatch?.unObserve(this)),this.log.for(this.unObserve).debug(`Observer ${t.toString()} removed`)}async updateObservers(t,e,r,...s){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");const{ctx:i,ctxArgs:n}=this.logCtx(s,this.updateObservers);if(!i.get("noEmit")){const s=Array.isArray(r),o=!i.get("noEmitSingle"),a=!i.get("noEmitBulk");(s&&a||!s&&o)&&await this.observerHandler.updateObservers(t,e,r,...n)}}async refresh(t,e,r,...s){return this.updateObservers(t,e,r,...s)}toString(){return this.flavour+" adapter"}static flavourOf(t){return dt.flavourOf(t)}static get currentFlavour(){if(!re._currentFlavour)throw new u("No persistence flavour set. Please initialize your adapter");return re._currentFlavour}static get current(){return re.get(this.currentFlavour)}static unregister(t){if(!t)return;const e=re._cache[t];e&&(delete re._cache[t],re._currentFlavour===t&&(re._currentFlavour=void 0),e.flavour&&re._cache[e.flavour]&&re._cache[e.flavour]===e&&delete re._cache[e.flavour])}static get(t){if(!t)return re.get(this._currentFlavour);if(t in this._cache)return this._cache[t];throw new u(`No Adapter registered under ${t}.`)}static setCurrent(t){this._currentFlavour=t}static models(t){try{return dt.flavouredAs(t).filter(z.isModel)}catch(t){throw new u(t)}}static decoration(){}get client(){return this._client||(this._client=this.getClient()),this._client}for(t,...e){this.proxies||(this.proxies={});const r=`${this.alias} - ${q(t)}`;if(r in this.proxies)return this.proxies[r];let s;const i=new Proxy(this,{get:(e,r,i)=>{if("_config"===r){const s=Reflect.get(e,r,i);return Object.assign({},s,t)}return"_client"===r?s:Reflect.get(e,r,i)},set:(t,e,r,i)=>"_client"===e?(s=r,!0):Reflect.set(t,e,r,i)});return Reflect.defineProperty(i,te,{value:async()=>{if(!s)return;const t=["cancel","close","destroy","disconnect"];for(const e of t){const t=s[e];if("function"==typeof t)try{const e=t.call(s);e instanceof Promise&&await e}catch{}}s=void 0},configurable:!0,enumerable:!1}),this.proxies[r]=i,i}migrations(){return dt.migrationsFor(this)}async getQueryRunner(){return this}logCtx(t,e,r=!1,s){return super.logCtx(t,e,r,s)}}i([j(),n("design:type",Function),n("design:paramtypes",[Object,Object,Object,Rt]),n("design:returntype",Promise)],re.prototype,"context",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,Function]),n("design:returntype",Function)],re.prototype,"observe",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",void 0)],re.prototype,"unObserve",null),i([j(),n("design:type",Object),n("design:paramtypes",[])],re.prototype,"client",null);class se extends u{constructor(t){super(t,se.name,500)}}class ie extends u{constructor(t){super(t,ie.name,500)}}class ne extends z{constructor(t,e,r){super(),this.attr1=void 0,this.operator=void 0,this.comparison=void 0,e||r?(this.attr1=t,this.operator=e,this.comparison=r):z.fromModel(this,t)}and(t){return ne.and(this,t)}or(t){return ne.or(this,t)}not(t){return new ne(this,Et.NOT,t)}hasErrors(...t){const e=()=>{const t=`Invalid operator ${this.operator}}`;if("string"==typeof this.attr1){if(this.comparison instanceof ne)return{comparison:{condition:"Both sides of the comparison must be of the same type"}};if(-1===Object.values(Et).indexOf(this.operator))return{operator:{condition:t}};if(this.operator===Et.BETWEEN&&(!Array.isArray(this.comparison)||2!==this.comparison.length))return{comparison:{condition:"BETWEEN operator requires an array with exactly 2 values [min, max]"}}}if(this.attr1 instanceof ne){if(!(this.comparison instanceof ne)&&this.operator!==Et.NOT)return{comparison:{condition:t}};if(-1===Object.values(Ot).indexOf(this.operator)&&this.operator!==Et.NOT)return{operator:{condition:t}}}},r=super.hasErrors(...t);return this.isAsync()?(async()=>await Promise.resolve(r)??e())():r??e()}static and(t,e){return ne.group(t,Ot.AND,e)}static or(t,e){return ne.group(t,Ot.OR,e)}static group(t,e,r){return new ne(t,e,r)}static attribute(t){return(new ne.Builder).attribute(t)}static attr(t){return this.attribute(t)}static{this.Builder=class{constructor(){this.attr1=void 0,this.operator=void 0,this.comparison=void 0}attribute(t){return this.attr1=t,this}attr(t){return this.attribute(t)}eq(t){return this.setOp(Et.EQUAL,t)}dif(t){return this.setOp(Et.DIFFERENT,t)}gt(t){return this.setOp(Et.BIGGER,t)}lt(t){return this.setOp(Et.SMALLER,t)}gte(t){return this.setOp(Et.BIGGER_EQ,t)}lte(t){return this.setOp(Et.SMALLER_EQ,t)}in(t){return this.setOp(Et.IN,t)}regexp(t){return this.setOp(Et.REGEXP,RegExp(t).source)}startsWith(t){return this.setOp(Et.STARTS_WITH,t)}endsWith(t){return this.setOp(Et.ENDS_WITH,t)}between(t,e){return this.setOp(Et.BETWEEN,[t,e])}setOp(t,e){return this.operator=t,this.comparison=e,this.build()}build(){try{return new ne(this.attr1,this.operator,this.comparison)}catch(t){throw new se(t)}}}}static builder(){return new ne.Builder}static from(t){return new ne(t)}}var oe,ae;i([H(),n("design:type",Object)],ne.prototype,"attr1",void 0),i([H(),n("design:type",String)],ne.prototype,"operator",void 0),i([H(),n("design:type",Object)],ne.prototype,"comparison",void 0),(t=>{t.ASC="asc",t.DSC="desc"})(oe||(oe={})),(t=>{t.CASCADE="cascade",t.NONE="none"})(ae||(ae={}));const ce={update:ae.CASCADE,delete:ae.NONE},le={Equals:(t,e)=>ne.attribute(t).eq(e),Diff:(t,e)=>ne.attribute(t).dif(e),LessThan:(t,e)=>ne.attribute(t).lt(e),LessThanEqual:(t,e)=>ne.attribute(t).lte(e),GreaterThan:(t,e)=>ne.attribute(t).gt(e),GreaterThanEqual:(t,e)=>ne.attribute(t).gte(e),In:(t,e)=>ne.attribute(t).in(e),Matches:(t,e)=>ne.attribute(t).regexp(e)},ue=t=>t.charAt(0).toLowerCase()+t.slice(1);class de extends M{static get log(){return this._logger||(this._logger=L.for(de.name)),this._logger}static{this.prefixMap={[xt.FIND_BY]:"find",[xt.PAGE_BY]:"page",[xt.COUNT_BY]:"count",[xt.SUM_BY]:"sum",[xt.AVG_BY]:"avg",[xt.MIN_BY]:"min",[xt.MAX_BY]:"max",[xt.DISTINCT_BY]:"distinct",[xt.GROUP_BY_PREFIX]:"group"}}static getActionFromMethodName(t){for(const[e,r]of Object.entries(this.prefixMap))if(t.startsWith(e))return{action:r,prefix:e}}static build(t,...e){const r=this.getActionFromMethodName(t);if(!r)throw Error("Unsupported method "+t);const{action:s,prefix:i}=r;let n;["count","sum","avg","min","max","distinct","group"].includes(s)&&(n=this.extractAggregationSelector(t,i));const o=this.extractCore(t,i),a=this.extractSelect(t),c=this.extractGroupBy(t),l=this.buildWhere(o,e),{orderBy:u,limit:d,offset:h}=this.extractOrderLimitOffset(t,e,o);return{action:s,select:a,selector:n,where:l,groupBy:c,orderBy:u,limit:d,offset:h}}static extractAggregationSelector(t,e){const r=t.substring(e.length),s=r.match(/(And|Or|GroupBy|OrderBy|Select|Limit|Offset|ThenBy)/),i=s?r.substring(0,s.index):r;return i?ue(i):void 0}static extractCore(t,e=xt.FIND_BY){const r=t.substring(e.length);if(e!==xt.FIND_BY&&e!==xt.PAGE_BY){const t=r.match(/(And|Or|GroupBy|OrderBy|ThenBy|Select|Limit|Offset)/);if(!t)return"";if("And"===t[0]||"Or"===t[0]){const e=r.substring(t.index+t[0].length),s=e.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset|Select|ThenBy)/);return s?e.substring(0,s.index):e}return""}const s=r.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset|Select)/);return s?r.substring(0,s.index):r}static getFieldsFromMethodName(t){const e=this.getActionFromMethodName(t),r=e?.prefix||xt.FIND_BY,s=this.extractCore(t,r);return s?(s.split(/OrderBy|GroupBy/)[0]||"").split(/And|Or/).filter(t=>t.length>0).map(t=>{const{operator:e,field:r}=this.parseFieldAndOperator(t);return r+(e??"")}):[]}static extractSelect(t){const e=t.indexOf(xt.SELECT);if(-1===e)return;const r=t.substring(e+xt.SELECT.length),s=r.match(/(Then[A-Z]|OrderBy|GroupBy|Limit|Offset)/);return(s?r.substring(0,s.index):r).split(xt.AND).map(ue).filter(Boolean)}static extractGroupBy(t){const e=t.indexOf(xt.GROUP_BY);if(-1!==e)return t.substring(e+xt.GROUP_BY.length).split(xt.ORDER_BY)[0].split(xt.THEN_BY).map(ue).filter(Boolean);const r=this.getActionFromMethodName(t);if("group"===r?.action){const e=t.substring(r.prefix.length),s=e.indexOf(xt.THEN_BY);if(-1===s)return;const i=e.substring(s+xt.THEN_BY.length).split(xt.THEN_BY),n=[];for(const t of i){const e=t.match(/(OrderBy|Limit|Offset|Select)/),r=e?t.substring(0,e.index):t;r&&n.push(ue(r))}return n.length>0?n:void 0}}static buildWhere(t,e){if(!t)return;const r=t.split(/OrderBy|GroupBy/)[0]||"";if(!r)return;const s=r.split(/And|Or/).filter(t=>t.length>0);if(0===s.length)return;const i=t.match(/And|Or/g)||[];let n;return s.forEach((t,r)=>{const{field:s,operator:o}=this.parseFieldAndOperator(t),a=o?le[o]:le.Equals;if(!a)throw Error("Unsupported operator "+o);const c=e[r];if(void 0===c)throw Error("Invalid value for field "+s);const l=a(s,c);n=0===r?l:i[r-1]===xt.AND?n.and(l):n.or(l)}),n}static parseFieldAndOperator(t){for(const e of Object.keys(le))if(t.endsWith(e)){const r=t.slice(0,-e.length);return{field:ue(r),operator:e}}return{field:ue(t)}}static extractOrderByField(t){const e=t.match(/OrderBy(.+)$/);if(!e)return;const r=e[1];return r.charAt(0).toLowerCase()+r.slice(1)}static getProperlyOrderByOrThrow(t,e){const r=de.log.for(this.getProperlyOrderByOrThrow);if(e||t){if(e&&!t)throw new se("Expected OrderBy clause, but no sortable field was found in method name.");if(e||!t){if(!Object.values(oe).includes(e))throw new se(`Invalid OrderBy direction ${e}. Expected one of: ${Object.values(oe).join(", ")}.`);return[[t,e]]}r.debug("Ignoring OrderBy clause because direction is undefined.")}}static extractOrderLimitOffset(t,e,r){const s=r??this.extractCore(t),i=s?s.split(/And|Or/).filter(t=>t.length>0).length:0,n=e.slice(i)??[];let o,a,c;if(n.at(-1)instanceof l&&n.pop(),n.length>=1){const e=n[0],r=this.extractOrderByField(t);o=this.getProperlyOrderByOrThrow(r,e)}return 2>n.length||"number"!=typeof n[1]||(a=n[1]),3>n.length||"number"!=typeof n[2]||(c=n[2]),{orderBy:o,limit:a,offset:c}}}function he(){return(t,e)=>{const r=dt.key(Ct.DEFAULT_QUERY_ATTR);let s=dt.get(t.constructor,r)||[];return s=[...new Set([...s,e])],gt(yt(r,s))(t,e)}}function pe(){return ht.for(Ct.STATEMENT).define({decorator:()=>(t,e,r)=>gt(ft(dt.key(Ct.STATEMENT,e),!0))(t,e,r),args:[]}).apply()}function ge(t={}){return ht.for(Ct.QUERY).define({decorator:t=>function e(r,s,i){const n=de.getFieldsFromMethodName(s);return gt(ft(dt.key(Ct.QUERY,s),{...t,fields:n}),pe(),(t=>(r,s,i)=>{i.value=new Proxy(i.value,{async apply(r,s,i){const{action:n,select:o,selector:a,where:c,groupBy:l,orderBy:u,limit:d,offset:p}=de.build(r.name,...i);if(!(s instanceof h))throw Error("thisArg must be an instance of Repository");const g=s,{ctx:f}=(await g.logCtx(i,e.name,!0)).for(e);let y;switch(n){case"find":case"page":y=g.select(o);break;case"count":y=g.count(a);break;case"sum":y=g.sum(a);break;case"avg":y=g.avg(a);break;case"min":y=g.min(a);break;case"max":y=g.max(a);break;case"distinct":y=g.distinct(a);break;case"group":y=g.select(),a&&(y=y.groupBy(a));break;default:throw new se("Unsupported action: "+n)}if(c&&(y=y.where(c)),l&&l.length>0&&"group"!==n){y=y.groupBy(l[0]);for(let t=1;t<l.length;t++)y=y.thenBy(l[t])}else if(l&&l.length>0&&"group"===n)for(const t of l)y=y.thenBy(t);const{allowLimit:m,allowOffset:w,allowOrderBy:v,throws:b}={allowLimit:!0,allowOrderBy:!0,allowOffset:!0,throws:!0,...t},A=[{key:"orderBy",value:(u||[])[0],allowed:v},{key:"limit",value:d,allowed:m},{key:"offset",value:p,allowed:w}];for(const t of A)if(void 0!==t.value){if(!t.allowed&&b)throw new se(t.key[0].toUpperCase()+t.key.slice(1)+" is not allowed for this query");t.allowed&&(y=y[t.key](t.value))}if("page"===n){const t=i[i.length-1],e="number"==typeof t?t:t?.limit??10;return y.paginate(e,f)}return y.execute(f)}})})(t))(r,s,i)},args:[t]}).apply()}function fe(t,e,r){return(s,i)=>{const n=r?.name||((t,e,r)=>{const s=(dt.get(t.constructor,e)||{})[r]||{};return Object.keys(s).length+1+""})(s,t,i),o=dt.key(t,i,n),a={...r||{},kind:e,attribute:i};return yt(o,a)(s,i)}}function ye(t){return ht.for(Et.VIEW).define({decorator:t=>fe(Et.VIEW,"view",t),args:[t]}).apply()}function me(t){return xe(t,[a.CREATE,c.CREATE_ALL])}function we(t){return xe(t,[a.UPDATE,c.UPDATE_ALL])}function ve(t){return xe(t,[a.DELETE,c.DELETE_ALL])}function be(t){return xe(t,Dt)}function Ae(t){return xe(t,Object.values(a))}function Se(t){return xe(t,Object.values(c))}function xe(t,e){return(r,s,i,...n)=>{if("string"==typeof t)throw new u("clazz cannot be string. This should be impossible");const{log:o}=$t.prototype.logCtx(n,xe);return o.silly(`filtering ${s} event for${r?" "+(z.tableName(r)||r):""} ${i}`),("string"==typeof r?r===z.tableName(t)||r===t.constructor.name:dt.constr(t)===dt.constr(r))&&e.includes(s)}}const Ee={onlyOnCreate:me,onlyOnUpdate:we,onlyOnDelete:ve,onlyOnTransactional:be,onlyOnSingle:Ae,onlyOnBulk:Se};function Oe(t){const e=Object.assign({},Ee);return Object.entries(e).forEach(([r,s])=>{e[r]=s(t.class)}),e}var ke,Ce,Te,Ne,De,_e,Ie,Be,Pe,Re,$e;class Fe extends h{static{this._cache={}}get log(){return this.logger||(this.logger=this.adapter.log.for(this.toString())),this.logger}get adapter(){if(!this._adapter)throw new u("No adapter found for this repository. did you use the @uses decorator or pass it in the constructor?");return this._adapter}get tableName(){return this._tableName||(this._tableName=z.tableName(this.class)),this._tableName}get pkProps(){return super.pkProps}get filters(){return Oe(this)}constructor(t,e,r=!1,...s){super(e),this.observers=[],this._overrides={ignoreHandlers:!1,ignoreValidation:!1,allowGenerationOverride:!1,allowRawStatements:!0,forcePrepareSimpleQueries:!1,forcePrepareComplexQueries:!1,ignoreDevSafeGuards:!1,mergeForUpdate:!0,applyUpdateValidation:!0,afterQueryHandlers:!1},t&&(this._adapter=t),e&&(Fe.register(e,this,this.adapter.alias,r),t)&&dt.get(e,mt.FLAVOUR)===pt&&wt(t.flavour)(e);const i=this;[this.createAll,this.readAll,this.deleteAll].forEach(t=>{const e=t.name;p(i,i[e+"Prefix"],t,i[e+"Suffix"])}),g(i,i[this.updateAll.name+"Prefix"],this.updateAll,i[this.updateAll.name+"Suffix"])}logCtx(t,e,r=!1,s){const i=this.adapter.logCtx([this.class,...t],e,r,Object.assign({},s||{},this._overrides||{}));function n(t){return t.ctxArgs.shift(),t}return i instanceof Promise?i.then(n):n(i)}override(t){return new Proxy(this,{get:(e,r,s)=>{const i=Reflect.get(e,r,s);return"_overrides"!==r?i:Object.assign({},i,t)}})}for(t,...e){return new Proxy(this,{get:(r,s,i)=>"adapter"===s?this.adapter.for(t,...e):Reflect.get(r,s,i)})}ObserverHandler(){return new Lt}async createPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.CREATE,!0)).for(this.createPrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");if(i.silly(`handlerSetting: ${n}, validationSetting: ${o}`),t=new this.class(t),n||await f(this,r,t,a.CREATE,a.ON),!o){const e=r.get("ignoredValidationProperties")||[];i.silly("ignored validation properties: "+e);const s=await Promise.resolve(t.hasErrors(...e));if(s)throw new d(s.toString())}return[t,...s]}async create(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.create);s.debug(`Creating new ${this.class.name} in table ${z.tableName(this.class)}`);let{record:n,id:o,transient:a}=this.adapter.prepare(t,r);return n=await this.adapter.create(this.class,o,n,...i),this.adapter.revert(n,this.class,o,a,r)}async createAll(t,...e){if(!t.length)return t;const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.createAll);s.debug(`Creating ${t.length} new ${this.class.name} in table ${z.tableName(this.class)}`);const n=t.map(t=>this.adapter.prepare(t,r)),o=n.map(t=>t.id);let a=n.map(t=>t.record);return a=await this.adapter.createAll(this.class,o,a,...i),a.map((t,e)=>this.adapter.revert(t,this.class,o[e],r.get("rebuildWithTransient")?n[e].transient:void 0,r))}async createAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.CREATE_ALL,!0)).for(this.createAllPrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");if(i.silly(`handlerSetting: ${n}, validationSetting: ${o}`),!t.length)return[t,...s];const l=z.sequenceFor(t[0]);let h=[];if(z.generatedBySequence(this.class)?(l.name||(l.name=z.sequenceName(t[0],"pk")),h=await(await this.adapter.Sequence(l,this._overrides)).range(t.length,...s)):z.generated(this.class,this.pk)||(h=t.map((t,e)=>{if(void 0===t[this.pk])throw new u("Primary key is not defined for model in position "+e);return t[this.pk]})),t=await Promise.all(t.map(async(t,e)=>(t=new this.class(t),l.type&&(t[this.pk]="String"!==l.type||l.generated?h[e]:""+t[this.pk]),n||await f(this,r,t,a.CREATE,a.ON),t))),!o){const e=r.get("ignoredValidationProperties")||[];i.silly("ignored validation properties: "+e);const s=await Promise.all(t.map(t=>Promise.resolve(t.hasErrors(...e)))),n=y(s);if(n)throw new d(n)}return[t,...s]}async readPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.READ,!0)).for(this.readPrefix),n=r.get("ignoreHandlers");i.silly("handlerSetting: "+n);const o=new this.class;return o[this.pk]=t,n||await f(this,r,o,a.READ,a.ON),[t,...s]}async read(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.read);s.debug(`reading ${this.class.name} from table ${z.tableName(this.class)} with pk ${this.pk}`);const n=await this.adapter.read(this.class,t,...i);return this.adapter.revert(n,this.class,t,void 0,r)}async readAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.READ_ALL,!0)).for(this.readAllPrefix),n=r.get("ignoreHandlers");return i.silly("handlerSetting: "+n),n||await Promise.all(t.map(async t=>{const e=new this.class;return e[this.pk]=t,f(this,r,e,a.READ,a.ON)})),[t,...s]}async readAll(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.readAll);return s.debug(`reading ${t.length} ${this.class.name} in table ${z.tableName(this.class)}`),(await this.adapter.readAll(this.class,t,...i)).map((e,s)=>this.adapter.revert(e,this.class,t[s],void 0,r))}async update(t,...e){const{ctxArgs:r,log:s,ctx:i}=this.logCtx(e,this.update);let{record:n,id:o,transient:a}=this.adapter.prepare(t,i);return s.debug(`updating ${this.class.name} in table ${z.tableName(this.class)} with id ${o}`),n=await this.adapter.update(this.class,o,n,...r),this.adapter.revert(n,this.class,o,a,i)}async updatePrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.UPDATE,!0)).for(this.updatePrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");i.silly(`handlerSetting: ${n}, validationSetting: ${o}`);const c=t[this.pk];if(!c)throw new u("No value for the Id is defined under the property "+this.pk);let l;if(r.get("applyUpdateValidation")&&(l=await this.read(c,r),r.get("mergeForUpdate")&&(t=z.merge(l,t,this.class))),n||await f(this,r,t,a.UPDATE,a.ON,l),!o){const e=r.get("ignoredValidationProperties")||[];i.silly("ignored validation properties: "+e);const s=await Promise.resolve(t.hasErrors(l,...e));if(s)throw new d(s.toString())}return[t,...s,l]}async updateAll(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.updateAll);s.verbose(`Updating ${t.length} new ${this.class.name} in table ${z.tableName(this.class)}`);const n=t.map(t=>this.adapter.prepare(t,r));return(await this.adapter.updateAll(this.class,n.map(t=>t.id),n.map(t=>t.record),...i)).map((t,e)=>this.adapter.revert(t,this.class,n[e].id,r.get("rebuildWithTransient")?n[e].transient:void 0,r))}async updateAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.UPDATE_ALL,!0)).for(this.updateAllPrefix),n=r.get("ignoreHandlers"),o=r.get("ignoreValidation");i.silly(`handlerSetting: ${n}, ignoredValidation: ${o}`);const l=t.map(t=>{const e=t[this.pk];if(!e)throw new u("missing id on update operation");return e});let h;if(r.get("applyUpdateValidation")&&(h=await this.readAll(l,r),r.get("mergeForUpdate")&&(t=t.map((t,e)=>z.merge(h[e],t,this.class)))),n||await Promise.all(t.map((t,e)=>f(this,r,t,a.UPDATE,a.ON,h?h[e]:void 0))),!o){const e=r.get("ignoredValidationProperties")||[];let s;i.silly("ignored validation properties: "+e),s=r.get("applyUpdateValidation")?await Promise.all(t.map((t,r)=>Promise.resolve(t.hasErrors(h[r],...e)))):await Promise.resolve(t.map(t=>t.hasErrors(...e)));const n=y(s);if(n)throw new d(n)}return[t,...s,h]}async deletePrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,a.DELETE,!0)).for(this.deletePrefix),n=r.get("ignoreHandlers");if(i.silly("handlerSetting: "+n),!n){const e=await this.read(t,...s);await f(this,r,e,a.DELETE,a.ON)}return[t,...s]}async delete(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.delete);s.debug(`deleting new ${this.class.name} in table ${z.tableName(this.class)} with pk ${t}`);const n=await this.adapter.delete(this.class,t,...i);return this.adapter.revert(n,this.class,t,void 0,r)}async deleteAllPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.logCtx(e,c.DELETE_ALL,!0)).for(this.deleteAllPrefix),n=r.get("ignoreHandlers");if(i.silly("handlerSetting: "+n),!n){const e=await this.readAll(t,...s);await Promise.all(e.map(async t=>f(this,r,t,a.DELETE,a.ON)))}return[t,...s]}async deleteAll(t,...e){const{ctx:r,log:s,ctxArgs:i}=this.logCtx(e,this.create);return s.debug(`deleting ${t.length} ${this.class.name} in table ${z.tableName(this.class)}`),(await this.adapter.deleteAll(this.class,t,...i)).map((e,s)=>this.adapter.revert(e,this.class,t[s],void 0,r))}select(t){return this.adapter.Statement(this._overrides).select(t).from(this.class)}count(t){return this.adapter.Statement(this._overrides).count(t).from(this.class)}min(t){return this.adapter.Statement(this._overrides).min(t).from(this.class)}max(t){return this.adapter.Statement(this._overrides).max(t).from(this.class)}sum(t){return this.adapter.Statement(this._overrides).sum(t).from(this.class)}avg(t){return this.adapter.Statement(this._overrides).avg(t).from(this.class)}distinct(t){return this.adapter.Statement(this._overrides).distinct(t).from(this.class)}async query(t,e,r=oe.ASC,s,i,...n){const{ctxArgs:o}=(await this.logCtx(n,Ct.QUERY,!0)).for(this.query),a=[e,r],c=this.select().where(t).orderBy(a);return s&&c.limit(s),i&&c.offset(i),c.execute(...o)}async listBy(t,e,...r){const{log:s,ctxArgs:i}=(await this.logCtx(r,kt.LIST_BY,!0)).for(this.listBy);return s.verbose(`listing ${z.tableName(this.class)} by ${t} ${e}`),this.select().orderBy([t,e]).execute(...i)}async paginateBy(t,e,r={offset:1,limit:10},...s){r.offset=r.offset||1,r.limit=r.limit||10;const{offset:i,bookmark:n,limit:o}=r;if(!i&&!n)throw new se("PaginateBy needs a page or a bookmark");const{log:a,ctx:c,ctxArgs:l}=(await this.logCtx(s,kt.PAGE_BY,!0)).for(this.paginateBy);let u;if(a.verbose(`paginating ${z.tableName(this.class)} with page size ${o}`),n&&c.get("paginateByBookmark"))u=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().where((()=>e===oe.ASC?this.attr(z.pk(this.class)).gt(n):this.attr(z.pk(this.class)).lt(n))()).orderBy([t,e]).paginate(o,...l);else{if(!i)throw new se("PaginateBy needs a page or a bookmark");u=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().orderBy([t,e]).paginate(o,...l)}const d=await u.page(i,n,...l);return u.serialize(d)}async find(t,e=oe.ASC,...r){if("string"!=typeof t)throw new se("Find value must be a string");const s=this.getDefaultQueryAttributes(),{log:i,ctxArgs:n}=(await this.logCtx(r,kt.FIND,!0)).for(this.find);i.verbose(`finding ${z.tableName(this.class)} by default attributes ${s.join(", ")}`);const o=this.buildDefaultStartsWithCondition(t,s);return this.select().where(o).orderBy([s[0],e]).execute(...n)}async page(t,e=oe.ASC,r={offset:1,limit:10},...s){if("string"!=typeof t)throw new se("Page value must be a string");const i=r.offset||1,{offset:n,bookmark:o,limit:a}=r;if(!n&&!o)throw new se("PaginateBy needs a page or a bookmark");const c=this.getDefaultQueryAttributes(),l=this.buildDefaultStartsWithCondition(t,c),{log:u,ctx:d,ctxArgs:h}=(await this.logCtx(s,kt.PAGE,!0)).for(this.page);u.verbose(`paging ${z.tableName(this.class)} by default attributes ${c.join(", ")}`);const p=a??10,g=c[0],f=this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1});let y;if(o&&d.get("paginateByBookmark")){const t=z.pk(this.class),r=e===oe.ASC?this.attr(t).gt(o):this.attr(t).lt(o);y=await f.select().where(l.and(r)).orderBy([g,e]).paginate(p,...h)}else{if(!n)throw new se("PaginateBy needs a page or a bookmark");y=await f.select().where(l).orderBy([g,e]).paginate(p,...h)}const m=await y.page(i,o,...h);return y.serialize(m)}async findOneBy(t,e,...r){const{log:s,ctxArgs:i}=(await this.logCtx(r,kt.FIND_ONE_BY,!0)).for(this.findOneBy);s.verbose(`finding ${z.tableName(this.class)} with ${t} ${e}`);const n=await this.select().where(this.attr(t).eq(e)).limit(1).execute(...i);if(!n.length)throw new m("No results found");return n[0]}async findBy(t,e,...r){const{log:s,ctxArgs:i}=(await this.logCtx(r,kt.FIND_BY,!0)).for(this.findBy);return s.verbose(`finding ${z.tableName(this.class)} with ${t} ${e}`),this.select().where(this.attr(t).eq(e)).execute(...i)}async findByPaginate(t,e,r={direction:oe.DSC,offset:1,limit:10},...s){r.direction=r.direction||oe.DSC,r.offset=r.offset||1,r.limit=r.limit||10;const{direction:i,offset:n,bookmark:o,limit:a}=r;if(!n&&!o)throw new se("FindByPaginate needs a page or a bookmark");const{log:c,ctx:l,ctxArgs:u}=(await this.logCtx(s,kt.FIND_BY_PAGINATE,!0)).for(this.findByPaginate);c.verbose(`finding and paginating ${z.tableName(this.class)} with ${t} ${e}`);const d=this.attr(t).eq(e);let h;if(o&&l.get("paginateByBookmark")){const e=z.pk(this.class),r=i===oe.ASC?this.attr(e).gt(o):this.attr(e).lt(o);h=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().where(d.and(r)).orderBy([t,i]).paginate(a,...u)}else{if(!n)throw new se("FindByPaginate needs a page or a bookmark");h=await this.override({forcePrepareComplexQueries:!1,forcePrepareSimpleQueries:!1}).select().where(d).orderBy([t,i]).paginate(a,...u)}const p=await h.page(n,o,...u);return h.serialize(p)}async countOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.COUNT_OF,!0)).for(this.countOf);return r.verbose(`counting ${z.tableName(this.class)}${t?" by "+t:""}`),this.count(t).execute(...s)}async maxOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.MAX_OF,!0)).for(this.maxOf);return r.verbose(`finding max of ${t} in ${z.tableName(this.class)}`),this.max(t).execute(...s)}async minOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.MIN_OF,!0)).for(this.minOf);return r.verbose(`finding min of ${t} in ${z.tableName(this.class)}`),this.min(t).execute(...s)}async avgOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.AVG_OF,!0)).for(this.avgOf);return r.verbose(`calculating average of ${t} in ${z.tableName(this.class)}`),this.avg(t).execute(...s)}async sumOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.SUM_OF,!0)).for(this.sumOf);return r.verbose(`calculating sum of ${t} in ${z.tableName(this.class)}`),this.sum(t).execute(...s)}async distinctOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.DISTINCT_OF,!0)).for(this.distinctOf);return r.verbose(`finding distinct values of ${t} in ${z.tableName(this.class)}`),this.distinct(t).execute(...s)}async groupOf(t,...e){const{log:r,ctxArgs:s}=(await this.logCtx(e,kt.GROUP_OF,!0)).for(this.groupOf);return r.verbose(`grouping ${z.tableName(this.class)} by ${t}`),this.select().groupBy(t).execute(...s)}async statement(t,...e){if(!Fe.statements(this,t))throw new se("Invalid prepared statement requested "+t);const{log:r,ctxArgs:s}=(await this.logCtx(e,Ct.STATEMENT,!0)).for(this.statement);return r.verbose("Executing prepared statement "+t),this[t](...s)}getDefaultQueryAttributes(){const t=z.defaultQueryAttributes(this.class);if(!t||!t.length)throw new se("No default query attributes defined for "+z.tableName(this.class));return t}buildDefaultStartsWithCondition(t,e){if("string"!=typeof t)throw new se("Default query value must be a string");let r;for(const s of e){const e=this.attr(s).startsWith(t);r=r?r.or(e):e}if(!r)throw new se("No default query attributes available for "+z.tableName(this.class));return r}attr(t){return ne.attr(t)}observe(t,e){this.observerHandler||Object.defineProperty(this,"observerHandler",{value:this.ObserverHandler(),writable:!1});const r=this.log.for(this.observe),s=this.class.name;return this.observerHandler?.count()||this.adapter.observe(this,(t,e,r,...i)=>"string"==typeof t?t===s:dt.constr(t)===dt.constr(this.class)),r.verbose(`now observing ${this.adapter} filtering on table === ${s}`),this.observerHandler.observe(t,e),r.verbose("Registered new observer "+t.toString()),()=>this.unObserve(t)}unObserve(t){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");this.observerHandler.unObserve(t),this.log.for(this.unObserve).verbose(`Observer ${t.toString()} removed`),this.observerHandler.count()||(this.log.verbose(`No more observers registered for ${this.adapter}, unsubscribing`),this.adapter.unObserve(this),this.log.verbose("No longer observing adapter "+this.adapter.flavour))}async updateObservers(t,e,r,...s){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");const{log:i,ctxArgs:n}=this.logCtx(s,this.updateObservers);i.verbose(`Updating ${this.observerHandler.count()} observers for ${this}`),await this.observerHandler.updateObservers(t,e,Array.isArray(r)?r.map(t=>re._baseSequence.parseValue(z.sequenceFor(this.class).type,t)):re._baseSequence.parseValue(z.sequenceFor(this.class).type,r),...n)}async refresh(t,e,r,...s){return this.updateObservers(t,e,r,...s)}static forModel(t,e,...r){let s;const i=dt.registeredFlavour(t),n=i&&i!==pt?i:void 0,o=e||n||dt.flavourOf(t)||re.currentFlavour;try{s=this.get(t,o)}catch(t){s=void 0}const a="function"==typeof s?s:void 0,c=e||n||dt.flavourOf(t)||a&&dt.get(a,Ct.ADAPTER)||re.currentFlavour,l=c?re.get(c):void 0;if(!l)throw new u("No registered persistence adapter found flavour "+c);if(s instanceof Fe)return s;const d=[z.tableName(t),l.alias].join(w),h=a||l.repository();return delete this._cache[d],new h(l,t,...r)}static get(t,e){const r=z.tableName(t);let s=r;if(e&&(s=[r,e].join(w)),s in this._cache)return this._cache[s];if(r in this._cache)return this._cache[r];throw new u("Could not find repository registered under "+r)}static register(t,e,r,s=!1){let i=z.tableName(t);if(r&&(i=[i,r].join(w)),i in this._cache&&this._cache[i]instanceof Fe&&!s)throw new u(i+" already has a registered instance");this._cache[i]=e}static statements(t,e){const r=t instanceof Fe?t.constructor:t,s=dt.get(r,e?dt.key(Ct.STATEMENT,e):Ct.STATEMENT);return(e?s:Object.keys(s))||!1}static queries(t,e){const r=t instanceof Fe?t.constructor:t;return dt.get(r,e?dt.key(Ct.QUERY,e):Ct.QUERY)}}function Le(t,e){if(!(e||(e=ht.flavourResolver(t instanceof z?t.constructor:t))&&e!==pt))throw new u("Could not retrieve flavour from model "+(t instanceof z?t.constructor.name:t.name));return V(Ct.INJECTABLE,e,z.tableName(t))}i([pe(),n("design:type",Function),n("design:paramtypes",[Object,String,void 0]),n("design:returntype",Promise)],Fe.prototype,"listBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,String,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"paginateBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[String,String,void 0]),n("design:returntype",Promise)],Fe.prototype,"find",null),i([pe(),n("design:type",Function),n("design:paramtypes",[String,String,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"page",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"findOneBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"findBy",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,Object,Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"findByPaginate",null),i([pe(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"countOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(ke="undefined"!=typeof K&&K)?ke:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"maxOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(Ce="undefined"!=typeof K&&K)?Ce:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"minOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(Te="undefined"!=typeof K&&K)?Te:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"avgOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(Ne="undefined"!=typeof K&&K)?Ne:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"sumOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(De="undefined"!=typeof K&&K)?De:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"distinctOf",null),i([pe(),n("design:type",Function),n("design:paramtypes",["function"==typeof(_e="undefined"!=typeof K&&K)?_e:Object,void 0]),n("design:returntype",Promise)],Fe.prototype,"groupOf",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,Function]),n("design:returntype",Function)],Fe.prototype,"observe",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",void 0)],Fe.prototype,"unObserve",null),re&&(re._baseRepository=Fe);class Me extends t{get log(){return this.logger||(this.logger=L.for(this)),this.logger}constructor(){super()}get(t,r){const s=this.log.for(this.get);let i;try{i=super.get(t)}catch{}if(!i){let n;if("function"==typeof t?n=z.get(t.name)||t:"symbol"!=typeof t&&"string"!=typeof t||(n=z.get(t.toString())),!n)return;const o=Ct.ADAPTER,a=r||dt.get(n,o)||dt.flavourOf(n);try{let t=a;try{a&&re.get(a)}catch{const e=re.current;e&&e.flavour===a&&(t=e.alias)}if(i=Fe.forModel(n,t),i instanceof Fe)return i;const r=a||dt.get(i.constructor,o)||dt.get(n,o);e.register(i,Le(n,r))}catch(t){s.debug("No registered repository or adapter found. falling back to default adapter. Error: "+(t?.message||JSON.stringify(t)));const e=Fe.get(n,a);if("function"==typeof e){const t=a?re.get(a):re.current;if(!t)return;return new e(t,n)}}}return i}}(t=>{t.PENDING="pending",t.SCHEDULED="scheduled",t.RUNNING="running",t.FAILED="failed",t.SUCCEEDED="succeeded",t.CANCELED="canceled",t.WAITING_RETRY="waiting_retry"})(Ie||(Ie={})),(t=>{t.EXPONENTIAL="exponential",t.FIXED="fixed"})(Be||(Be={})),(t=>{t.NONE="none",t.FULL="full"})(Pe||(Pe={})),(t=>{t.STATUS="status",t.UPDATE="update",t.LOG="log",t.PROGRESS="progress",t.ALL="all"})(Re||(Re={})),(t=>{t.ATOMIC="atomic",t.COMPOSITE="composite"})($e||($e={}));const je="tasks",Ue={workerId:"default-worker",concurrency:10,leaseMs:6e4,pollMsIdle:1e3,pollMsBusy:500,logTailMax:100,streamBufferSize:5,maxLoggingBuffer:300,loggingBufferTruncation:20,gracefulShutdownMsTimeout:12e4,autoShutdown:{enabled:!1,backoffStepMs:1e3,maxIdleDelayMs:6e4}};function Ge(t,e){return(i,n)=>n?r(dt.constr(t))(i,n):(dt.set(v.REPOSITORY,dt.key(e||re.currentFlavour,z.tableName(t)),i),vt(v.REPOSITORY,i.name)(t),e=e||dt.get(i.constructor,Ct.ADAPTER),Fe.register(t,i),s(dt.constr(t),{callback:e=>(Object.defineProperty(e,v.CLASS,{enumerable:!1,configurable:!1,writable:!1,value:t}),e)})(i))}dt.tasks=(()=>dt.innerGet(Symbol.for(je))).bind(dt),dt.taskFor=(t=>{const e=dt.tasks();return e?e[t]:void 0}).bind(dt),dt.validationExceptions=((t,e)=>{const r=dt.get(t,Ct.NO_VALIDATE)||[],s=Object.entries(r).filter(([,t])=>t.includes(e)).map(([t])=>t);let i=[];return e!==a.CREATE&&e!==a.UPDATE||(i=z.nestedRelations(t)),[...new Set([...s,...i])]}).bind(dt),dt.migrationsFor=(t=>{if(!(t=t??re.current))throw new u("Could not get adapter for migrations");return dt.innerGet(Symbol.for(Ct.MIGRATION),t.alias).map(t=>t.class)}).bind(dt),dt.migrations=(()=>{const t=dt.innerGet(Symbol.for([Ct.MIGRATION,Ct.BY_KEY].join("-")));return Object.values(t).flat().map(t=>[t.class.name,t.class])}).bind(dt),dt.relations=((t,e)=>{const r=dt.get(t,Ct.RELATIONS);if(r){if(!e)return Object.keys(r);if(!r[e])throw new u("No relations metadata found for property "+e);return r[e]}}).bind(dt),z.relations=(t,e)=>dt.relations(t instanceof z?t.constructor:t,e)||[],z.nestedRelations=((t,e=[])=>{let r=[];const s=dt.get(t,Ct.RELATIONS);if(!s||!Object.keys(s).length)return[...new Set([...e])];for(const t in s){const i=s[t];if(i?.class&&z.relations(i.class)){const s=z.relations(i.class).map(e=>`${t}.${e}`);e=[...e,...s],r=z.nestedRelations(i.class,e)}}return[...new Set([...e,...r])]}).bind(z),z.generatedBySequence=((t,e)=>{const r="function"!=typeof t?t.constructor:t;return!!z.sequenceFor(r).generated}).bind(z),z.fromTable=(t=>{const e=dt.innerGet(Symbol.for(Ct.TABLE));if(!e||!e[t]||!z.get(e[t].name))throw new u("No table metadata found for model. did you use @table()?");return z.get(e[t].name)}).bind(z),dt.createdBy=(t=>{const e=dt.get("function"!=typeof t?t.constructor:t,Ct.CREATED_BY);if(!e)throw new u("No createdBy metadata found for model. did you use @createdBy()?");return e}).bind(dt),dt.updatedBy=(t=>{const e=dt.get("function"!=typeof t?t.constructor:t,Ct.UPDATED_BY);if(!e)throw new u("No updatedBy metadata found for model. did you use @updatedBy()?");return e}).bind(dt),z.tableName=t=>{if(!(t instanceof z?z.get(t.constructor.name):t))throw new u("Unable to find model "+t);return dt.get(t instanceof z?t.constructor:t,Ct.TABLE)||(t instanceof z?t.constructor.name:t.name)},z.columnName=(t,e)=>dt.get(t instanceof z?t.constructor:t,dt.key(Ct.COLUMN,e))||e,z.defaultQueryAttributes=(t,e=!1)=>{const r="function"==typeof t?t:t.constructor;return dt.get(r,dt.key(Ct.DEFAULT_QUERY_ATTR))||(e?[z.pk(t)]:[])},z.sequenceName=(t,...e)=>[z.tableName(t),...e].join("_"),z.versionOf=(t=>{const e=dt.get(t.constructor),r=e?.[Ct.PERSISTENT_VERSION],s=r&&"object"==typeof r?Object.keys(r)[0]:void 0,i=e?.[v.VERSION],n=i&&"object"==typeof i?Object.keys(i)[0]:void 0,o=s??n;if(!o)throw new u("No version found for "+t.constructor.name);const a=t[o];if("number"!=typeof a||1>a)throw new u("Invalid version number: "+a);return a}).bind(z),z.sequenceFor=(t,e)=>{const r="function"!=typeof t?t.constructor:t;let s=Ct.SEQUENCE;const i=z.pk(r);e&&e+""!=i+""||(e=i,s=v.ID),s=dt.key(s,e);const n=dt.get(r,s);if(!n)throw new u(`No sequence options defined for property ${e+""}. did you use @sequence() or @pk()?`);return n},z.indexes=t=>{const e=dt.get(t instanceof z?t.constructor:t,Ct.INDEX);return Object.keys(e||{}).reduce((t,r)=>(t[r]={[Ct.INDEX]:e[r]},t),{})},e.services=()=>dt.innerGet(Symbol.for(Ct.SERVICE)),e.repositories=()=>dt.innerGet(Symbol.for(v.REPOSITORY)),z.merge=((t,e,r)=>{const s=t=>Object.entries(t).reduce((t,[e,s])=>{let i=!1;try{"relation.one-to-one"===z.relations(r,e).key&&(i=!0)}catch(t){i=!1}return(void 0!==s||i)&&(t[e]=s),t},{});return new(r=r||t.constructor)(Object.assign({},s(t),s(e)))}).bind(z);class Ye extends u{constructor(t){super(t,Ye.name,500)}}var ze;function qe(t,...e){return(r,s,i)=>{i.value=new Proxy(i.value,{async apply(r,s,i){const{ctx:n,ctxArgs:o}=await s.logCtx(i,r.name,!0);let a;try{a=t(...i,...e,n)}catch(t){throw new u("Failed to execute auth validation handler: "+t)}if(a)throw a;return r.call(s,...o)}})}}function He(t,...e){return(r,s,i)=>{i.value=new Proxy(i.value,{async apply(r,s,i){const{ctx:n,ctxArgs:o}=await s.logCtx(i,r.name,!0);let a;try{a=t(...i,...e,n)}catch(t){throw new u("Failed to execute auth validation handler: "+t)}if(a)throw a;return r.call(s,...o)}})}}(t=>{t.AUTH="auth",t.ROLES="roles",t.NAMESPACE="namespace"})(ze||(ze={}));const Ve={type:void 0,generated:!1,startWith:0,incrementBy:1,cycle:!1},Qe=Ve,We={type:Number,generated:!0,startWith:0,incrementBy:1,cycle:!1},Je=Object.assign({},We,{type:"BigInt"});function Xe(t,e,r){return ht.for(Ct.INDEX).define({decorator:(t,e,r)=>(s,i)=>("string"==typeof t&&(r=t,t=void 0,e=void 0),"string"==typeof e&&(r=e,e=void 0),!e&&t&&t.find(t=>![oe.ASC,oe.DSC].includes(t))&&(e=t,t=void 0),yt(dt.key(`${Ct.INDEX}${e&&e?.length?"."+e.join("."):""}`,i),{directions:t,compositions:e,name:r})(s,i)),args:[t,e,r]}).apply()}function Ke(t){return"function"==typeof t}function Ze(t,e,r){if(!r.type){const s=dt.type(t.constructor,e);if(![Number.name,String.name,BigInt.name].includes(s?.name||s))throw Error("Incorrrect option type");r.type=s}switch(r.type){case String.name||String.name.toLowerCase():case String:r.generated=void 0!==r.generated&&r.generated,r.type=String;break;case Number.name||String.name.toLowerCase():case Number:r.generated=void 0===r.generated||r.generated,r.type=Number;break;case BigInt.name||BigInt.name.toLowerCase():case BigInt:r.type=BigInt,r.generated=void 0===r.generated||r.generated;break;case"uuid":case"serial":r.generated=!0;break;default:throw Error("Unsupported type")}void 0===r.generated&&(r.generated=!0)}async function tr(t,e,r,s){if(!e.type||!e.generated||s[r])return;let i;e.name||(e.name=z.sequenceName(s,"pk"));try{i=await this.adapter.Sequence(e,this._overrides)}catch(t){throw new u(`Failed to instantiate Sequence ${e.name}: ${t}`)}var n,o,a;n=s,o=r,a=await i.next(t),Reflect.set(n,o,a)}async function er(t,e,r,s,i){if(!e.type||!e.generated)return;if(!e.name){const t=z.pk(s,!0);if(null==t)throw new u("Cannot generate sequence without an id for "+s.constructor.name);e.name=z.sequenceName(s,t+"",r+"")}let n;try{n=await this.adapter.Sequence(e,this._overrides)}catch(t){throw new u(`Failed to instantiate Sequence ${e.name}: ${t}`)}const o=null!=i,a=void 0!==s[r]&&null!==s[r],c=!!t.get("allowGenerationOverride")&&a;if(a&&await n.ensureAtLeast(s[r],t),o&&!e.update)return;if(c)return;const l=await n.next(t);Reflect.set(s,r,l)}function rr(t,e){return(r,s)=>{bt()(r,s),Ze(r,s,t),t.name||(t.name=((t,e)=>Ke(z.sequenceName)?z.sequenceName(t,e):[Ke(z.tableName)?z.tableName(t):t?.name??"",e].filter(Boolean).join("_"))(r.constructor,"pk"));const i=[yt(dt.key(v.ID,s),t),yt(dt.key(Ct.SEQUENCE,s),t),Xe([oe.ASC,oe.DSC]),H(),b(),A(tr,t,e)];return t.generated&&i.push(x()),gt(...i)(r,s)}}function sr(t,e={},r){return(s,i)=>{bt()(s,i),Ze(s,i,t);const n=[H(),yt(dt.key(Ct.SEQUENCE,i),t),A(er,{...t,...e},r)];return e.update&&n.push(E(er,{...t,...e},r)),t.generated&&n.push(x()),gt(...n)(s,i)}}function ir(t){const e=Object.assign({},Qe);return delete e.generated,t=Object.assign({},e,t),ht.for(v.ID).define({decorator:rr,args:[t,{priority:60}]}).apply()}function nr(t,e){const r=Object.assign({},Qe);delete r.generated,t=Object.assign({},r,t);const s="boolean"==typeof e?{update:e}:e||{};return ht.for(Ct.SEQUENCE).define({decorator:sr,args:[t,s,{priority:70}]}).apply()}async function or(t,e,r,s,i){const n=e.logger.for(or);if(!s){const e=z.get(t.constructor.name);if(!e)throw new u("Could not find model "+t.constructor.name);s=Fe.forModel(e,r),n.info("Retrieved "+s.toString())}let o;if(s=i?s.override(i):s,void 0===t[z.pk(s.class)])n.info(`No pk found in ${z.tableName(s.class)} - creating`),o=await s.create(t,e);else{n.info(`pk found in ${z.tableName(s.class)} - attempting update`);try{o=await s.update(t,e),n.info("Updated "+z.tableName(s.class))}catch(r){if(!(r instanceof m))throw r;n.info("update Failed - creating new "+z.tableName(s.class)),o=await s.create(t,e)}n.info("After create update: "+o)}return o}async function ar(t,e,r,s){const i=s[r];if(!i)return;if(gr(s,e),"object"!=typeof i){const e=Tr(s,r,this.adapter.alias),n=await e.override(this._overrides).read(i,t);return await Er(t,s,r,i,n),void(s[r]=i)}const n="function"!=typeof e.class||e.class.name?e.class:e.class();if(!n)throw new u("Could not find model "+e.class);const o=Fe.forModel(n,this.adapter.alias),a=await o.override(this._overrides).create(i,t),c=z.pk(a);await Er(t,s,r,a[c],a),s[r]=a[c]}async function cr(t,e,r,s){const i=s[r];if(!i)return;if(e.cascade.update!==ae.CASCADE)return;if("object"!=typeof i){const e=Tr(s,r,this.adapter.alias),n=await e.override(this._overrides).read(i,t);return await Er(t,s,r,i,n),void(s[r]=i)}const n=await or(s[r],t,this.adapter.alias,void 0,this._overrides),o=z.pk(n);await Er(t,s,r,n[o],n),s[r]=n[o]}async function lr(t,e,r,s){const i=s[r];if(null==i)return;if(e.cascade.delete!==ae.CASCADE)return;const n=Tr(s,r,this.adapter.alias);let o;o=i instanceof z?await n.delete(s[r][n.pk],t):await n.delete(s[r],t),await Er(t,s,r,o[n.pk],o)}async function ur(t,e,r,s,i){const n=s[r];if(!n||!n.length)return;gr(s,e);const o=t.logger.for(ur),a=Tr(s,r,this.adapter.alias),c=z.pk("function"!=typeof e.class||e.class.name?e.class:e.class()),l=new Set;for(const e of n){let i;"object"!=typeof e?(i=await a.override(this._overrides).read(e,t),o.debug("read: "+i[c])):(o.verbose("Creating or updating one-to-many model: "+e[c]),i=await or(e,t,this.adapter.alias,void 0,this._overrides)),o.debug(`caching for populate: ${JSON.stringify(i)} under ${i[c]}`),await Er(t,s,r,i[c],i),l.add(i[c])}s[r]=[...l]}async function dr(t,e,r,s,i){const{cascade:n}=e;if(n.update===ae.CASCADE)return ur.call(this,t,e,r,s,i)}async function hr(t,e,r,s){if(e.cascade.delete!==ae.CASCADE)return;const i=s[r];if(!i)return;const n=typeof i[0];if(!i.every(t=>typeof t===n))throw new u(`Invalid operation. All elements of property ${r} must match the same type.`);const o="function"!=typeof e.class||e.class.name?e.class:e.class(),a="object"===n,c=a?Fe.forModel(o,this.adapter.alias):Tr(s,r,this.adapter.alias),l=[...new Set([...a?i.map(t=>t[c.pk]):i]).values()];let d,h;try{d=await c.override(this._overrides).deleteAll(l,t)}catch(e){throw t.logger.error("Failed to delete all records",e),e}for(let e=0;e<d.length;e++){h=d[e];try{await Er(t,s,r,l[e],h)}catch(i){throw t.logger.error(`Failed to cache record ${l[e]} with key ${r} and model ${JSON.stringify(s,void 0,2)} `,i),i}}s[r]=l}async function pr(t,e,r,s){const i=s[r];if(!i)return;gr(s,e);const n=t.logger.for(pr);if("object"!=typeof i){const e=Tr(s,r,this.adapter.alias),n=await e.override(this._overrides).read(i,t);return await Er(t,s,r,i,n),void(s[r]=i)}if(!(e.class instanceof z?e.class.constructor:e.class))throw new u("Could not find model "+e.class);n.info("Creating or updating many-to-one model: "+JSON.stringify(i));const o=await or(i,t,this.adapter.alias,void 0,this._overrides),a=z.pk(o);n.info(`caching: ${JSON.stringify(o)} under ${o[a]}`),await Er(t,s,r,o[a],o),s[r]=o[a]}function gr(t,e){let r;const s="function"==typeof e.class&&e.class.name?e.class:e.class(),i=dt.get(s,Ct.RELATIONS);if(i&&(r=Object.values(i)?.find(e=>{const r="function"==typeof e.class&&e.class.name?e.class:e.class();return t instanceof r})),!0===r?.populate&&!0===e?.populate)throw new u("Bidirectional populate is not allowed. Please set populate to false on one side of the relation.");return!0}async function fr(t,e,r,s){const{cascade:i}=e;if(i.update===ae.CASCADE)return pr.call(this,t,e,r,s)}async function yr(t,e,r,s){if(e.cascade.delete!==ae.CASCADE)return;const i=s[r];if(!i)return;const n="object"==typeof i,o=n?Fe.forModel(i,this.adapter.alias):Tr(s,r,this.adapter.alias),a=n?i[o.pk]:i,c=await o.override(this._overrides).delete(a);await Er(t,s,r,a,c),s[r]=a}async function mr(t,e,r,s){const i=s[r];if(!i||!i.length)return;gr(s,e);const n=typeof i[0];if(!i.every(t=>typeof t===n))throw new u(`Invalid operation. All elements of property ${r} must match the same type.`);const o=t.logger.for(mr),a=new Set([...i]);if("object"!==n){const n=Tr(s,r,this.adapter.alias),c=await n.override(this._overrides).readAll([...a.values()],t);for(let e=0;e<c.length;e++){const s=c[e];o.info("FOUND MANY TO MANY VALUE: "+JSON.stringify(s)),await Er(t,s,r,[...a.values()][e],c)}return await wr.call(this,s,[...i],o,t,e),s[r]=[...a],void o.info("SET MANY TO MANY IDS: "+s[r])}const c=z.pk(i[0].constructor),l=new Set;for(const e of i){o.info("Creating or updating many-to-many model: "+JSON.stringify(e));const i=await or(e,t,this.adapter.alias,void 0,this._overrides);o.info(`caching: ${JSON.stringify(i)} under ${i[c]}`),await Er(t,s,r,i[c],i),o.info("Creating or updating many-to-many model: "+JSON.stringify(e)),e.id=i.id,l.add(i[c])}const d=z.pk(s.constructor);if(void 0===s[d]){const e=await(async(t,e,r)=>{const s=e[z.pk(e.constructor)];if(void 0!==s)return s;const i=z.sequenceFor(e.constructor);let n;i?.name||(i.name=z.sequenceName(e,"pk"));try{return n=await t.adapter.Sequence(i,t._overrides),await n.next(r)}catch(t){throw new u(`Failed to instantiate Sequence ${i.name}: ${t}`)}})(this,s,t);s[d]=e}const h=await wr.call(this,s,i,o,t,e);o.info("Junction model created: "+h.name),s[r]=[...l]}async function wr(t,e,r,s,i){const{JunctionModel:n,fkA:o,fkB:a}=vr(t,e[0],i),c=[];for(const i of e){r.info("Creating or updating many-to-many junction model: "+JSON.stringify(i));const e={[o]:t instanceof z?t[z.pk(t.constructor)]:t,[a]:i instanceof z?i[z.pk(i.constructor)]:i},l=await or(new n(e),s,this.adapter.alias,void 0,this._overrides);l?.id&&c.push(l.id)}if(c.length===e?.length){const t=Fe.forModel(n);await(t?.override(this._overrides).readAll(c))}return n}function vr(t,e,r){const s=z.tableName(t);let i;if(e instanceof z)i=z.tableName(e);else if(z.isModel(e)&&"function"==typeof e)i=e.name?e.name:e()?.name;else if(r?.class){const t="function"!=typeof r.class||r.class.name?r.class:r.class();i=z.tableName(t)}if(!s||!i)throw new u("Missing tablenames to create junction table");const n=r?.joinTable?.name?r?.joinTable?.name:`${s}_${i}`,o=s?.toLowerCase()+"_fk",a=i?.toLowerCase()+"_fk",c=class extends z{constructor(t){super(t)}};Object.defineProperty(c,"name",{value:n,writable:!1}),ir({type:Number})(c.prototype,"id"),H()(c.prototype,o),H()(c.prototype,a);const l=W()(c);return dt.set(c,Ct.TABLE,n),{fkA:o,fkB:a,JunctionModel:l}}async function br(t,e,r,s){const{cascade:i}=e;if(i.update===ae.CASCADE)return mr.call(this,t,e,r,s)}async function Ar(t,e,r,s){if(e.cascade.delete!==ae.CASCADE)return;const i=s[r];if(!i||!i.length)return;const n=typeof i[0];if(!i.every(t=>typeof t===n))throw new u(`Invalid operation. All elements of property ${r} must match the same type.`);const o="function"!=typeof e.class||e.class.name?e.class:e.class(),a="object"===n,c=a?Fe.forModel(o,this.adapter.alias):Tr(s,r,this.adapter.alias),l=[...new Set([...a?i.map(t=>t[c.pk]):i]).values()];let d,h;try{d=await c.override(this._overrides).deleteAll(l,t)}catch(e){throw t.logger.error("Failed to delete all records",e),e}for(let e=0;e<d.length;e++){h=d[e];try{await Er(t,s,r,l[e],h)}catch(i){throw t.logger.error(`Failed to cache record ${l[e]} with key ${r} and model ${JSON.stringify(s,void 0,2)} `,i),i}}s[r]=l}function Sr(t,e,r){return e?[Ct.POPULATE,t,e,r].join("."):[Ct.POPULATE,t,r].join(".")}function xr(t,e,r){return[Ct.TAG_FOR_DELETION,t,r].join(".")}async function Er(t,e,r,s,i){const n=Sr(e.constructor.name,r,s),o=t.logger.for(Er),a=t.get("cacheForPopulate")||{};let c=a[n],l=t.getOrUndefined("preferFromCache");if(!l)try{o.silly("retrieving from children"),l=t.getFromChildren("preferFromCache")||!1,l&&(c=(t.getFromChildren("cacheForPopulate")||{})[n])}catch(t){l=!1}return l&&o.debug("preferring previous cache: "+!!a[n]),a[n]=l&&c?c:i,t.accumulate({cacheForPopulate:a})}async function Or(t,e,r,s){if(!e.populate)return;const i=s[r],n=Array.isArray(i);if(void 0===i||n&&0===i.length)return;const o=this,l=await(async(e,r,s,i)=>{let n,l;const d=[];let h;try{h=e.get("operation")}catch(t){h=void 0}const p=h===a.READ||h===c.READ_ALL?{}:e.get("cacheForPopulate")||{};for(const e of i){n=Sr(r.constructor.name,s,e);try{if(l=p[n],!l)throw Error("Not found in cache")}catch(i){const n=Tr(r,s,o.adapter.alias);if(!n)throw new u("Could not find repo");l=await n.override(o._overrides).read(e,t)}d.push(l)}return d})(t,s,r,n?i:[i]);s[r]=n?l:l[0]}async function kr(t,e,r,s,i){if(e.cascade.update!==ae.CASCADE)return;if(!i)throw new u("No way to compare old model. do you have updateValidation and mergeModels enabled?");function n(t){return Array.isArray(t)?t.map(n):"object"!=typeof t?t:t[z.pk(t)]}const o=n(s[r]),a=n(i[r]);if(void 0===a||Q(o,a))return;if(Array.isArray(o)!==Array.isArray(a))throw new u("Cannot cascade update for different array types");const c=(Array.isArray(o)?o:[o]).filter(Boolean),l=(Array.isArray(a)?a:[a]).filter(Boolean).filter(t=>!c.includes(t)),d=Tr(s,r,this.adapter.alias);if(!d)throw new u("Could not find repo");try{const e=await d.override(this._overrides).deleteAll(l,t);t.logger.debug(`Deleted ${e.length} entries from table ${z.tableName(d.class)} due to cascade rules with `)}catch(t){throw new u("Error deleting cascade entries: "+t)}}const Cr=["array","string","number","boolean","symbol","function","object","undefined","null","bigint"];function Tr(t,e,r){if(!t)throw Error("No model was provided to get repository");let s,i=t instanceof z?t.constructor:t;if(Array.isArray(t[e])||t[e]instanceof Set){const t=dt.get(i,dt.key(J.REFLECT,e,J.LIST))?.clazz;if(!t)throw new u("Failed to find types decorators for property "+e);s=(Array.isArray(t)?[...t]:[t]).map(t=>"function"!=typeof t||t.name?t:t())}else s=z.relations(i).includes(e)?dt.allowedTypes(i,e):dt.getPropDesignTypes(t instanceof z?t.constructor:t,e)?.designTypes;i=s?.find(t=>!Cr.includes((""+t.name).toLowerCase()));const n=Fe.forModel(i,r);if(i!==n.class)throw new u("Invalid repository class for "+e);return n}class Nr extends O{constructor(t,e=Nr.name,r=401){super(t,e,r)}}class Dr extends Nr{constructor(t,e=Dr.name){super(t,e,403)}}class _r extends u{constructor(t){super(t,_r.name,503)}}function Ir(t){return ht.for(Ct.TABLE).define({decorator:t=>e=>(dt.set(Ct.TABLE,t||e.name.toLowerCase(),e),vt(Ct.TABLE,t||e.name.toLowerCase())(e)),args:[t]}).apply()}function Br(t){return ht.for(Ct.COLUMN).define({decorator:t=>(e,r)=>yt(dt.key(Ct.COLUMN,r),t||r)(e,r),args:[t]}).apply()}async function Pr(t,e,r,s){if(s[r]&&(await this.select().where(ne.attribute(r).eq(s[r])).execute()).length)throw new T(`model already exists with property ${r} equal to ${JSON.stringify(s[r],void 0,2)}`)}function Rr(){const t=Ct.UNIQUE;return ht.for(t).define(Z(),C(Pr),yt(t,{})).apply()}async function $r(t,e,r,s){throw new Nr("This adapter does not support user identification")}function Fr(){return ht.for(Ct.CREATED_BY).define({decorator:()=>(t,e)=>gt(A($r),yt(Ct.CREATED_BY,e),x(Ct.CREATED_BY))(t,e),args:[]}).apply()}function Lr(){return ht.for(Ct.UPDATED_BY).define({decorator:()=>(t,e)=>gt(E($r),yt(Ct.UPDATED_BY,e),x(Ct.UPDATED_BY))(t,e),args:[]}).apply()}function Mr(){return k([a.CREATE])}function jr(){return k()}async function Ur(t,e,r,s){if("??sequence"===z.tableName(s))return;const i=z.pk(s,!0);if(null==i)throw new u("Cannot generate persistent version without an id for "+s.constructor.name);const n={name:z.sequenceName(s,i+"",r+""),type:Number,generated:!0,startWith:0,incrementBy:1,cycle:!1},o=await this.adapter.Sequence(n,this._overrides),a=void 0!==s[r]&&null!==s[r],c=!!t.get("allowGenerationOverride")&&a;if(a&&(await o.ensureAtLeast(s[r],t),c))return;const l=await o.next(t);s[r]=l}async function Gr(t,e,r,s,i){if("??sequence"===z.tableName(s))return;if(t.get("applyUpdateValidation")&&i&&s[r]!==i[r])throw new d(`Version mismatch: ${s[r]} !== ${i[r]}`);const n=z.pk(s,!0);if(null==n)throw new u("Cannot generate persistent version without an id for "+s.constructor.name);const o={name:z.sequenceName(s,n+"",r+""),type:Number,generated:!0,startWith:0,incrementBy:1,cycle:!1},a=await this.adapter.Sequence(o,this._overrides),c=void 0!==s[r]&&null!==s[r],l=!!t.get("allowGenerationOverride")&&c;if(c&&(await a.ensureAtLeast(s[r],t),l))return;const h=await a.next(t);s[r]=h}function Yr(){const t=Ct.PERSISTENT_VERSION;return(e,r)=>ht.for(t).define(bt(),yt(dt.key(t,r),!0),x(t),X(Number),A(Ur,{},{priority:70}),E(Gr,{},{priority:70})).apply()(e,r)}function zr(t=!1){return t?Yr():N()}function qr(t){return[()=>{const e="function"==typeof t&&t.name?t:t(),r=z.pk(e);return(dt.allowedTypes(e,r)||[])[0]}]}function Hr(t,e=ce,r=!0,s,i){const n=Ct.ONE_TO_ONE;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),X([t,...a]),A(ar,o,{priority:70}),E(cr,o,{priority:70}),_(lr,o,{priority:70}),E(kr,o,{priority:80}),D(Or,o,{priority:70})];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Vr(t,e=ce,r=!0,s,i){const n=Ct.ONE_TO_MANY;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),tt([t,...a]),A(ur,o,{priority:70}),E(dr,o,{priority:70}),_(hr,o,{priority:70}),E(kr,o,{priority:80}),D(Or,o,{priority:70})];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Qr(t,e=ce,r=!0,s,i){const n=Ct.MANY_TO_ONE;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),X([t,...a]),A(pr,o),E(fr,o),_(yr,o),D(Or,o)];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Wr(t,e=ce,r=!0,s,i){const n=Ct.MANY_TO_MANY;return ht.for(n).define({decorator:(t,e,r,s,i)=>{const o={class:t,cascade:e,populate:r};s&&(o.joinTable=s),i&&(o.name=i);const a=qr(t),c=[bt(),ts(n,o),tt([t,...a]),A(mr,o),E(dr,o),D(Or,o)];return gt(...c)},args:[t,e,r,s,i]}).apply()}function Jr(...t){return(e,r)=>{const s=dt.get(e,dt.key(Ct.NO_VALIDATE,r))||[],i=[...new Set([...s,...t])];return gt(vt(dt.key(Ct.NO_VALIDATE,r),i))(e,r)}}function Xr(){return Jr(a.CREATE)}function Kr(){return Jr(a.UPDATE)}function Zr(){return Jr(a.UPDATE,a.CREATE)}function ts(t,e){return ht.for(Ct.RELATIONS).define({decorator:(t,e)=>(r,s)=>(yt(t,e)(r,s),yt(dt.key(Ct.RELATIONS,s),Object.assign({},e,{key:t}))(r,s)),args:[t,e]}).apply()}class es extends z{constructor(t){super(t)}}i([Mr(),n("design:type",Date)],es.prototype,"createdAt",void 0),i([jr(),n("design:type",Date)],es.prototype,"updatedAt",void 0);let rs=class extends es{constructor(t){super(t)}};i([ir({type:String,generated:!1}),n("design:type",String)],rs.prototype,"id",void 0),i([H(),Xe(),n("design:type",Object)],rs.prototype,"current",void 0),rs=i([Ir("??sequence"),W(),n("design:paramtypes",[Object])],rs);class ss extends M{get current(){return this._currentPage}get total(){return this._totalPages}get count(){return this._recordCount}get statement(){return this._statement||(this._statement=this.prepare(this.query)),this._statement}constructor(t,e,r,s){super(),this.adapter=t,this.query=e,this.size=r,this.clazz=s,Qt(this,this.page,this.pagePrefix,this.page.name)}isPreparedStatement(){const t=this.query;return t.method&&t.method.match(RegExp(`${kt.FIND_BY}|${kt.FIND_BY_PAGINATE}|${kt.LIST_BY}|${kt.PAGE_BY}|${kt.FIND}`,"gi"))}async pagePrefix(t,...e){const{ctxArgs:r}=(await this.adapter.logCtx([this.clazz,...e],kt.PAGE_BY,!0)).for(this.pagePrefix);return r.shift(),[t,...r]}async pagePrepared(t,e,...r){const{log:s,ctxArgs:i}=this.adapter.logCtx(!e||e instanceof Rt?[e,...r]:[...r],this.pagePrepared);s.debug(`Running paged prepared statement ${t} page${e?" - bookmark "+e:""}`),!e||e instanceof Rt||(this._bookmark=e);const n=Fe.forModel(this.clazz,this.adapter.alias),o=this.query,{method:a,args:c,params:l}=o;if(a===kt.FIND){const e=[kt.PAGE,...c],r={limit:this.size,offset:t,bookmark:this._bookmark};e.push(r);const s=await n.statement(...e,...i);return this.apply(s)}let u;if(a===kt.FIND_BY?u=kt.FIND_BY_PAGINATE:a.startsWith(kt.FIND_BY)?u=a.replace(kt.FIND_BY,kt.PAGE_BY):a===kt.LIST_BY?u=kt.PAGE_BY:a!==kt.PAGE_BY&&a!==kt.FIND_BY_PAGINATE||(u=a),!u)throw new Mt(`Method ${a} is not supported for pagination`);const d=[u,...c];let h={limit:this.size,offset:t,bookmark:this._bookmark};u!==kt.PAGE_BY||d.length>2?h={direction:l.direction,limit:this.size,offset:t,bookmark:this._bookmark}:d.push(l.direction),d.push(h);const p=await n.statement(...d,...i);return this.apply(p)}async next(...t){return this.page(this.current+1,...t)}async previous(...t){return this.page(this.current-1,...t)}validatePage(t){if(1>t||!Number.isInteger(t))throw new ie("Page number cannot be under 1 and must be an integer");if(void 0!==this._totalPages&&t>this._totalPages)throw new ie(`Only ${this._totalPages} are available. Cannot go to page ${t}`);return t}async page(t=1,e,...r){const{ctxArgs:s}=this.adapter.logCtx([e,...r],this.page);if(this.isPreparedStatement())return await this.pagePrepared(t,...s);throw new Mt("Raw support not available without subclassing this")}serialize(t,e=!1){const r={data:t,current:this.current,total:this.total,count:this.count,bookmark:this._bookmark};try{return e?JSON.stringify(r):r}catch(t){throw new I(t)}}apply(t){const e="string"==typeof t?ss.deserialize(t):t;return this._currentPage=e.current,this._totalPages=e.total||this._totalPages,this._recordCount=e.count||this._recordCount,this._bookmark=e.bookmark,e.data}static deserialize(t){try{return JSON.parse(t)}catch(t){throw new I(t)}}static isSerializedPage(t){return t&&"object"==typeof t&&Array.isArray(t.data)&&"number"==typeof t.total&&"number"==typeof t.current&&"number"==typeof t.count}}var is,ns,os,as,cs,ls,us;class ds extends $t{constructor(t,e){super(),this.adapter=t,this.overrides=e,this._inCountMode=!1,[this.execute,this.paginate].forEach(t=>{B(this,t,(...e)=>this.executionPrefix(t,...e),t.name)})}async executionPrefix(t,...e){const{ctx:r,ctxArgs:s,log:i}=(await this.adapter.logCtx([this.fromSelector,...e],t.name===this.paginate.name?kt.PAGE_BY:Ct.QUERY,!0,this.overrides||{})).for(t);s.shift();const n=r.get("forcePrepareSimpleQueries"),o=r.get("forcePrepareComplexQueries");i.silly(`statement force simple ${n}, forceComplex: ${o}`);const a=this.hasAggregation()&&!this.whereCondition&&!this.selectSelector?.length&&1>=(this.groupBySelectors?.length||0);return(n&&(this.isSimpleQuery()||a)||o)&&(i.silly(`squashing ${o?"complex":"simple"} query to prepared statement`),await this.prepare(r),i.silly(`squashed ${o?"complex":"simple"} query to ${JSON.stringify(this.prepared,null,2)}`)),s}get log(){return this.adapter.log.for(ds)}select(t){return Object.defineProperty(this,"selectSelector",{value:t,writable:!1}),this}distinct(t){if(this._inCountMode)return this.countDistinctSelector=this.countSelector,this.countSelector=void 0,this._inCountMode=!1,this;if(!t)throw new se("distinct() requires a selector when not chained after count()");return this.distinctSelector=t,this}max(t){return this.maxSelector=t,this}min(t){return this.minSelector=t,this}sum(t){return this.sumSelector=t,this}avg(t){return this.avgSelector=t,this}count(t){return this.countSelector=t??null,this._inCountMode=!0,this}from(t){if(this.fromSelector="string"==typeof t?z.get(t):t,!this.fromSelector)throw new se("Could not find selector model: "+t);return this}where(t){return this.whereCondition=t,this}orderBy(t,e){return this.orderBySelectors=[this.normalizeOrderCriterion(t,e)],this}thenBy(t,e){if(Array.isArray(t)||void 0!==e){if(!this.orderBySelectors||!this.orderBySelectors.length)throw new se("thenBy requires orderBy to be called first");return this.orderBySelectors.push(this.normalizeOrderCriterion(t,e)),this}if(!this.groupBySelectors||!this.groupBySelectors.length)throw new se("groupBy must be called before chaining group selectors");return this.groupBySelectors.push(t),this}normalizeOrderCriterion(t,e){if(Array.isArray(t)){const[e,r]=t;return[e,this.normalizeOrderDirection(r)]}return[t,this.normalizeOrderDirection(e)]}normalizeOrderDirection(t){if(!t)throw new se("orderBy direction is required when specifying the attribute separately.");const e=(t+"").toLowerCase();if(e===oe.ASC)return oe.ASC;if(e===oe.DSC)return oe.DSC;throw new se(`Invalid OrderBy direction ${t}. Expected one of: ${Object.values(oe).join(", ")}.`)}groupBy(t){if(this.orderBySelectors&&this.orderBySelectors.length)throw new se("groupBy must be called before orderBy.");return this.groupBySelectors=[t],this}limit(t){return this.limitSelector=t,this}offset(t){return this.offsetSelector=t,this}async execute(...t){const{log:e,ctx:r,ctxArgs:s}=this.logCtx(t,this.execute);try{if(this.prepared)return this.executePrepared(...t);e.silly("Building raw statement...");const i=this.build();e.silly("executing raw statement");const n=await this.raw(i,...s);if(this.hasAggregation())return n;if(!this.selectSelector){const t=t=>this.processRecord(t,r);if(this.groupBySelectors?.length){const e=this.revertGroupedResults(n,t);return await this.applyAfterHandlersToResult(e,r)}if(Array.isArray(n)){const e=n.map(t);return await this.applyAfterHandlersToResult(e,r)}const e=t(n);return await this.applyAfterHandlersToResult(e,r)}return n}catch(t){throw new se(t)}}revertGroupedResults(t,e){return Array.isArray(t)?t.map(e):t&&"object"==typeof t?Object.entries(t).reduce((t,[r,s])=>(t[r]=this.revertGroupedResults(s,e),t),{}):t}async executePrepared(...t){const e=Fe.forModel(this.fromSelector,this.adapter.alias),{method:r,args:s,params:i}=this.prepared;return e.statement(r,...s,i,...t)}async raw(t,...e){const{ctx:r,ctxArgs:s}=this.logCtx(e,this.raw);if(!r.get("allowRawStatements"))throw new Mt("Raw statements are not allowed in the current configuration");const i=await this.adapter.raw(t,!0,...s);if(this.hasAggregation())return i;if(!this.selectSelector)return i;const n=t=>this.processRecord(t,r);if(Array.isArray(i)){const t=i.map(n);return await this.applyAfterHandlersToResult(t,r)}const o=n(i);return await this.applyAfterHandlersToResult(o,r)}processRecord(t,e){const r=t[z.pk(this.fromSelector)];return this.adapter.revert(t,this.fromSelector,r,void 0,e)}async applyAfterHandlersToResult(t,e){return e.getOrUndefined("afterQueryHandlers")?t instanceof z?(await f(this.getRepository(),e,t,a.READ,a.AFTER),t):Array.isArray(t)?(await Promise.all(t.map(t=>this.applyAfterHandlersToResult(t,e))),t):t&&"object"==typeof t?(await Promise.all(Object.entries(t).map(([r,s])=>this.applyAfterHandlersToResult(s,e).then(e=>{t[r]=e}))),t):t:t}getRepository(){return Fe.forModel(this.fromSelector,this.adapter.alias)}prepareCondition(t,e){let{attr1:r,operator:s,comparison:i}=t;const n={};switch(s){case Ot.AND:case Ot.OR:{let t=r,o=i;if("string"!=typeof r){const s=this.prepareCondition(r,e);t=s.method,n.args=[...n.args||[],...s.args||[]]}if(i instanceof ne){const t=this.prepareCondition(i,e);o=t.method,n.args=[...n.args||[],...t.args||[]]}n.method=`${t} ${s.toLowerCase()} ${o}`;break}case Et.EQUAL:n.method=r,n.args=[...n.args||[],i];break;case Et.DIFFERENT:n.method=r+" diff",n.args=[...n.args||[],i];break;case Et.REGEXP:n.method=r+" matches",n.args=[...n.args||[],i];break;case Et.BIGGER:n.method=r+" bigger",n.args=[...n.args||[],i];break;case Et.BIGGER_EQ:n.method=r+" bigger than equal";break;case Et.SMALLER:n.method=r+" less",n.args=[...n.args||[],i];break;case Et.SMALLER_EQ:n.method=r+" less than equal",n.args=[...n.args||[],i];break;case Et.IN:n.method=r+" in",n.args=[...n.args||[],i];break;default:throw new se("Unsupported operator "+s)}return n}squash(t){const e=this.matchDefaultQueryCondition();if(e){const t=this.getOrderDirection();return{class:this.fromSelector,method:kt.FIND,args:[e.value,t],params:{direction:t}}}if(this.whereCondition&&this.whereCondition.comparison instanceof ne)return;if(!this.whereCondition&&!this.selectSelector?.length){if(void 0!==this.countSelector&&!this.countDistinctSelector)return{class:this.fromSelector,method:kt.COUNT_OF,args:null!==this.countSelector?[this.countSelector]:[],params:{}};if(this.maxSelector)return{class:this.fromSelector,method:kt.MAX_OF,args:[this.maxSelector],params:{}};if(this.minSelector)return{class:this.fromSelector,method:kt.MIN_OF,args:[this.minSelector],params:{}};if(this.avgSelector)return{class:this.fromSelector,method:kt.AVG_OF,args:[this.avgSelector],params:{}};if(this.sumSelector)return{class:this.fromSelector,method:kt.SUM_OF,args:[this.sumSelector],params:{}};if(this.distinctSelector)return{class:this.fromSelector,method:kt.DISTINCT_OF,args:[this.distinctSelector],params:{}};if(1===this.groupBySelectors?.length)return{class:this.fromSelector,method:kt.GROUP_OF,args:[this.groupBySelectors[0]],params:{}}}if(this.selectSelector&&this.selectSelector.length)return;if(this.groupBySelectors&&this.groupBySelectors.length)return;if(void 0!==this.countSelector)return;if(this.countDistinctSelector)return;if(this.maxSelector)return;if(this.minSelector)return;if(this.sumSelector)return;if(this.avgSelector)return;let r;this.whereCondition&&(r=this.whereCondition.attr1);const s=this.orderBySelectors?.[0]?this.orderBySelectors[0]:r?[r,oe.DSC]:[z.pk(this.fromSelector),oe.DSC],[i,n]=s,o={direction:n};this.limitSelector&&(o.limit=this.limitSelector),this.offsetSelector&&(o.offset=this.offsetSelector);const a={class:this.fromSelector,method:kt.LIST_BY,args:[i],params:o};return r&&(a.method=kt.FIND_BY,a.args=[r,this.whereCondition.comparison],a.params=o),a}matchDefaultQueryCondition(){if(!this.whereCondition)return;const t=this.extractDefaultStartsWithAttributes(this.whereCondition);if(!t)return;const e=z.defaultQueryAttributes(this.fromSelector);if(!e||!e.length)return;const r=Array.from(new Set(e.map(String))),s=Array.from(new Set(t.attributes.map(String)));return r.length===s.length&&r.every(t=>s.includes(t))?{value:t.value,attributes:r}:void 0}extractDefaultStartsWithAttributes(t){const e=this.collectStartsWithAttributes(t);if(e)return{attributes:Array.from(new Set(e.attributes)),value:e.value}}collectStartsWithAttributes(t){if(!t)return;const{attr1:e,operator:r,comparison:s}=t;if(r===Et.STARTS_WITH){if("string"!=typeof e||"string"!=typeof s)return;return{attributes:[e],value:s}}if(r===Ot.OR){const t=e instanceof ne?this.collectStartsWithAttributes(e):void 0,r=s instanceof ne?this.collectStartsWithAttributes(s):void 0;return t&&r&&t.value===r.value?{attributes:[...t.attributes,...r.attributes],value:t.value}:void 0}return r===Ot.AND?(e instanceof ne?this.collectStartsWithAttributes(e):void 0)||(s instanceof ne?this.collectStartsWithAttributes(s):void 0):void 0}getOrderDirection(){return this.orderBySelectors?.[0]?.[1]??oe.ASC}async prepare(t){if(t=t||await this.adapter.context(Ct.QUERY,this.overrides||{},this.fromSelector),this.isSimpleQuery()&&t.get("forcePrepareSimpleQueries")){const e=this.squash(t);if(e)return this.prepared=e,this}if(t.get("forcePrepareSimpleQueries")||t.get("forcePrepareComplexQueries")){const e=this.squash(t);if(e)return this.prepared=e,this}const e=[],r={},s={class:this.fromSelector,args:e,params:r};let i,n=xt.FIND_BY;void 0!==this.countSelector?(n=xt.COUNT_BY,i=null!==this.countSelector?this.countSelector:void 0):this.sumSelector?(n=xt.SUM_BY,i=this.sumSelector):this.avgSelector?(n=xt.AVG_BY,i=this.avgSelector):this.minSelector?(n=xt.MIN_BY,i=this.minSelector):this.maxSelector?(n=xt.MAX_BY,i=this.maxSelector):this.distinctSelector?(n=xt.DISTINCT_BY,i=this.distinctSelector):!this.groupBySelectors?.length||this.selectSelector?.length||this.whereCondition||(n=xt.GROUP_BY_PREFIX,i=this.groupBySelectors[0]);const o=[n];if(i&&o.push(i),this.whereCondition){const r=this.prepareCondition(this.whereCondition,t);o.push(r.method),r.args&&r.args.length&&e.push(...r.args)}if(this.selectSelector&&o.push(xt.SELECT,this.selectSelector.join(` ${xt.AND.toLowerCase()} `)),this.orderBySelectors?.length){const[t,...e]=this.orderBySelectors;o.push(xt.ORDER_BY,t[0]),r.direction=t[1],e.length&&(r.order=this.orderBySelectors.map(([t,e])=>[t,e]),e.forEach(([t])=>{o.push(xt.THEN_BY,t)}))}if(this.groupBySelectors?.length&&n!==xt.GROUP_BY_PREFIX){const[t,...e]=this.groupBySelectors;o.push(xt.GROUP_BY,t),e.forEach(t=>o.push(xt.THEN_BY,t))}else this.groupBySelectors?.length&&n===xt.GROUP_BY_PREFIX&&this.groupBySelectors.slice(1).forEach(t=>o.push(xt.THEN_BY,t));return this.limitSelector&&(r.limit=this.limitSelector),this.offsetSelector&&(r.skip=this.offsetSelector),s.method=U(o.join(" ")),s.params=r,this.prepared=s,this}isSimpleQuery(){return!(this.selectSelector&&this.selectSelector.length||this.groupBySelectors&&this.groupBySelectors.length||void 0!==this.countSelector||this.countDistinctSelector||this.maxSelector||this.minSelector||this.sumSelector||this.avgSelector||this.distinctSelector)}hasAggregation(){return void 0!==this.countSelector||void 0!==this.countDistinctSelector||void 0!==this.maxSelector||void 0!==this.minSelector||void 0!==this.sumSelector||void 0!==this.avgSelector||void 0!==this.distinctSelector||(this.groupBySelectors?.length||0)>0}async paginate(t,...e){e.pop();try{return this.adapter.Paginator(this.prepared||this.build(),t,this.fromSelector)}catch(t){throw new se(t)}}toString(){return this.adapter.flavour+" statement"}}i([j(),n("design:type",Function),n("design:paramtypes",[Array]),n("design:returntype",Object)],ds.prototype,"select",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(is="undefined"!=typeof S&&S)?is:Object]),n("design:returntype",Object)],ds.prototype,"distinct",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(ns="undefined"!=typeof S&&S)?ns:Object]),n("design:returntype",Object)],ds.prototype,"max",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(os="undefined"!=typeof S&&S)?os:Object]),n("design:returntype",Object)],ds.prototype,"min",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(as="undefined"!=typeof S&&S)?as:Object]),n("design:returntype",Object)],ds.prototype,"sum",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(cs="undefined"!=typeof S&&S)?cs:Object]),n("design:returntype",Object)],ds.prototype,"avg",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(ls="undefined"!=typeof S&&S)?ls:Object]),n("design:returntype",Object)],ds.prototype,"count",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",Object)],ds.prototype,"from",null),i([j(),n("design:type",Function),n("design:paramtypes",[ne]),n("design:returntype",Object)],ds.prototype,"where",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,String]),n("design:returntype",Object)],ds.prototype,"orderBy",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object,String]),n("design:returntype",Object)],ds.prototype,"thenBy",null),i([j(),n("design:type",Function),n("design:paramtypes",["function"==typeof(us="undefined"!=typeof Key&&Key)?us:Object]),n("design:returntype",Object)],ds.prototype,"groupBy",null),i([j(),n("design:type",Function),n("design:paramtypes",[Number]),n("design:returntype",Object)],ds.prototype,"limit",null),i([j(),n("design:type",Function),n("design:paramtypes",[Number]),n("design:returntype",Object)],ds.prototype,"offset",null),i([j(),n("design:type",Function),n("design:paramtypes",[void 0]),n("design:returntype",Promise)],ds.prototype,"execute",null);class hs extends $t{constructor(t){super(),this.name=t,this.observers=[],this.Context=Rt}for(t,...e){return new Proxy(this,{get(r,s,i){const n=Reflect.get(r,s,i);return"object"!=typeof n?n:n instanceof hs?n.for(t,...e):n instanceof Fe?n.override(t):n}})}override(t,...e){return new Proxy(this,{get(r,s,i){const n=Reflect.get(r,s,i);return"object"!=typeof n?n:n instanceof hs?n.override(t,...e):n instanceof Fe?n.override(t):n}})}observe(t,e){this.observerHandler||Object.defineProperty(this,"observerHandler",{value:new Lt,writable:!1});const r=this.log.for(this.observe);return this.observerHandler.observe(t,e),r.verbose("Registered new observer "+(t.constructor.name||t.toString())),()=>this.unObserve(t)}unObserve(t){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables? or are you unregistering whe you shouldn't");this.observerHandler.unObserve(t);const e=this.log.for(this.unObserve);e.verbose(`Observer ${t.toString()} removed`),this.observerHandler.count()||(delete this.observerHandler,e.verbose("No longer being observed"))}async updateObservers(t,e,r,...s){if(!this.observerHandler)throw new u("ObserverHandler not initialized. Did you register any observables?");const{log:i,ctxArgs:n}=this.logCtx(s,this.updateObservers);i.verbose(`Updating ${this.observerHandler.count()} observers for ${this}`),await this.observerHandler.updateObservers(t,e,r,...n)}async flags(t,e,...r){e.correlationId=e.correlationId||`${t}-${Wt.instance.generate()}`;const s=e.logger||L.for(this);return s.setConfig({correlationId:e.correlationId}),Object.assign({},Tt,e,{args:r,timestamp:new Date,operation:t,logger:s})}async refresh(t,e,r,...s){return this.updateObservers(t,e,r,...s)}async context(t,e,...r){this.log.for(this.context).silly(`creating new context for ${t} operation with flag overrides: ${JSON.stringify(e)}`);let s=r.pop();void 0===s||s instanceof Rt||(r.push(s),s=void 0),e=s?Object.assign({},s.toOverrides(),e):e;const i=await this.flags("string"==typeof t?t:t.name,e,...[...r,s].filter(Boolean));if(s){if(!(s instanceof this.Context)){const t=(new this.Context).accumulate({...s.cache,...i,parentContext:s});return s.accumulate({childContexts:[...s.getOrUndefined("childContexts")||[],t]}),t}if(s.get("operation")!==t){const t=(new this.Context).accumulate({...s.cache,...i,parentContext:s});return s.accumulate({childContexts:[...s.getOrUndefined("childContexts")||[],t]}),t}return s.accumulate(i)}return(new this.Context).accumulate({...i})}logCtx(t,e,r=!1,s){return $t.logCtx.call(this,e,s||{},r,...t.filter(t=>void 0!==t))}static get(t){if(!t)throw new u("No name provided");const r=Gt(t),s=e.get(r);if(s)return s;throw new u("No Service found for "+("string"==typeof t?t:"symbol"==typeof t?t.toString():t.name))}static async boot(...t){let r=t.pop();void 0===r||r instanceof Rt||(t.push(r),r=void 0);const s=await hs.prototype.flags(Ct.INITIALIZATION,{},...t);r=r?new Rt(r).accumulate({...s,parentContext:r}):(new Rt).accumulate(s),t=[...t,r];const{log:i,ctxArgs:n}=hs.prototype.logCtx(t,this.boot),o=e.services();for(const[t,r]of Object.entries(o))try{i.verbose(`Booting ${r.name} service...`);const s=e.get(r);if(!s)throw new u("Failed to resolve injectable for "+t);s instanceof ps&&(i.verbose(`Initializing ${r.name} service...`),await s.boot(...n))}catch(t){throw new u(`Failed to boot ${r.name} service:${t}`)}}static async shutdown(...t){let r=t.pop();void 0===r||r instanceof Rt||(t.push(r),r=void 0);const s=await hs.prototype.flags(Ct.SHUTDOWN,{},...t);r=r?new Rt(r).accumulate({...s,parentContext:r}):(new Rt).accumulate(s),t=[...t,r];const{log:i,ctxArgs:n}=hs.prototype.logCtx(t,this.shutdown),o=e.services();for(const[t,r]of Object.entries(o).reverse())try{i.verbose(`Shutting down ${r.name} service...`);const s=e.get(r);if(!s)throw new u("Failed to resolve injectable for "+t);if(s instanceof ps){i.verbose(`Gracefully shutting down ${r.name} service...`);try{await s.shutdown(...n)}catch(t){i.error(`Failed to gracefully shutdown ${r.name} service`,t)}}}catch(e){throw new u(`Failed to Shutdown services ${t}: ${e}`)}}}i([j(),n("design:type",Function),n("design:paramtypes",[Object,Function]),n("design:returntype",Function)],hs.prototype,"observe",null),i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",void 0)],hs.prototype,"unObserve",null);class ps extends hs{constructor(){super()}async boot(...t){const{config:e,client:r}=await this.initialize(...t);this._config=e,this._client=r;const{log:s}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.boot);s.verbose(this.toString()+" initialized...")}get config(){if(!this._config)throw new u("Config not initialized");return this._config}get client(){if(!this._client)throw new u("Client not initialized");return this._client}async shutdown(...t){const{log:e}=await this.logCtx(t,this.shutdown,!0);e.info("Shutting down...")}}function gs(t){return function(e,r,s){const i=s.value;return s.value=function(...e){const r=this.class;if(r&&Ht(r,t))throw Error(`Operation "${t}" is blocked by @BlockOperations for ${r?.name??"Model"}.`);return i.apply(this,e)},s}}i([j(),n("design:type",Function),n("design:paramtypes",[Object]),n("design:returntype",Promise)],ps.prototype,"boot",null),i([j(),n("design:type",Object),n("design:paramtypes",[])],ps.prototype,"config",null),i([j(),n("design:type",Object),n("design:paramtypes",[])],ps.prototype,"client",null);const fs=()=>gs(a.CREATE),ys=()=>gs(a.READ),ms=()=>gs(a.UPDATE),ws=()=>gs(a.DELETE);function vs(t){return(e,i,n)=>{n||i?(bt()(e,i),t=t||dt.type(e.constructor,i)):t=t||e,t=Gt(t);const o=[];if(n&&"number"==typeof n.value)o.push(r(t));else if(n||i){if(n)throw Error("Invalid decorator usage. Should be impossible");o.push(r(t))}else dt.set(Ct.SERVICE,t,e),o.push(s(t,{singleton:!0,callback:e=>Object.defineProperty(e,"name",{enumerable:!0,configurable:!1,writable:!1,value:t})}));return gt(...o)(e,i,n)}}function bs(t){const e=Ct.AUTH;return ht.for(e).define({decorator:t=>vt(e,t),args:[t]}).apply()}const As=t=>vt(Ct.AUTH_ROLE,t);function Ss(t,e){const r=Ct.DECAF_ROUTE;return ht.for(r).define({decorator:()=>(s,i,n)=>{const o={path:e,httpMethod:t,handler:n};return gt(ft(dt.key(r,i),o))(s,i,n)},args:[]}).apply()}const xs=t=>"string"==typeof t?t.endsWith("Service")?t:t+"Service":"symbol"==typeof t?t.toString():t.name+"Service";class Es extends hs{get class(){if(!this.clazz)throw new u("Class not initialized");return this.clazz}get repo(){return this._repository||(this._repository=Fe.forModel(this.clazz)),this._repository}constructor(t,e){super(e??t.name+"Service"),this.clazz=t}static getService(t){if(!t)throw new u("No name provided");const e=xs(t);try{const t=hs.get(e);if(t)return t}catch(t){}throw new u("No ModelService found for alias "+e)}async create(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.CREATE,!0)).for(this.create);return this.repo.create(t,...r)}async createAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.CREATE_ALL,!0)).for(this.createAll);return this.repo.createAll(t,...r)}async delete(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.DELETE,!0)).for(this.delete);return this.repo.delete(t,...r)}async deleteAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.DELETE_ALL,!0)).for(this.deleteAll);return this.repo.deleteAll(t,...r)}async read(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.READ,!0)).for(this.read);return this.repo.read(t,...r)}async readAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.READ_ALL,!0)).for(this.readAll);return this.repo.readAll(t,...r)}async query(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.QUERY,!0)).for(this.query),s=this.repo?.[t];if("function"!=typeof s)throw new u(`Method "${t}" is not implemented`);return s.apply(this.repo,r)}async update(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.UPDATE,!0)).for(this.update);return this.repo.update(t,...r)}async updateAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.UPDATE_ALL,!0)).for(this.updateAll);return this.repo.updateAll(t,...r)}select(t){return this.repo.select(t)}async listBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.LIST_BY,!0)).for(this.listBy);return this.repo.listBy(t,e,...s)}async paginateBy(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.PAGE_BY,!0)).for(this.paginateBy);return this.repo.paginateBy(t,e,r,...i)}async findOneBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_ONE_BY,!0)).for(this.findOneBy);return this.repo.findOneBy(t,e,...s)}async findBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_BY,!0)).for(this.findBy);return this.repo.findBy(t,e,...s)}async findByPaginate(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.FIND_BY_PAGINATE,!0)).for(this.findByPaginate);return this.repo.findByPaginate(t,e,r,...i)}async statement(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.STATEMENT,!0)).for(this.statement);return this.repo.statement(t,...r)}static forModel(t,e){let r;e=xs(e||t);try{r=Es.get(e)}catch(t){r=void 0}if(r instanceof Es)return r;const s=this;let o=class extends s{constructor(){super(t)}};return o=i([vs(e),n("design:paramtypes",[])],o),new o}refresh(t,e,r,...s){return this.repo.refresh(t,e,r,...s)}observe(t,e){return this.repo.observe(t,e)}unObserve(t){return this.repo.unObserve(t)}updateObservers(t,e,r,...s){return this.repo.updateObservers(t,e,r,...s)}logCtx(t,e,r=!1){const s=this.repo._adapter.logCtx([this.repo.class,...t],e,r,this.repo._overrides||{});function i(t){return t.ctxArgs.shift(),t}return s instanceof Promise?s.then(i):i(s)}}i([fs(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"create",null),i([fs(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],Es.prototype,"createAll",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"delete",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],Es.prototype,"deleteAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"read",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],Es.prototype,"readAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[String,Object]),n("design:returntype",Promise)],Es.prototype,"query",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],Es.prototype,"update",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Array,Object]),n("design:returntype",Promise)],Es.prototype,"updateAll",null);class Os extends $t{isSameObservedAdapter(t){if(!this.adapter)return!1;if(this.adapter===t)return!0;const e=this.adapter,r=t;return r instanceof re&&e.alias===r.alias&&e.flavour===r.flavour}constructor(){super(),this.initialized=!1}logCtx(t,e,r=!1){if(!this.adapter)throw new u("Adapter not set yet");return this.adapter.logCtx(t,e,r)}async initialize(...t){if(!this.adapter)return void this.log.for(this.initialize).verbose("No adapter observed for dispatch; skipping initialization");if(this.initialized)return void this.log.for(this.initialize).debug("Dispatcher already initialized; skipping initialization to prevent duplicate setup");const{log:e}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.initialize);e.verbose(`Initializing ${this.adapter}'s event Dispatch`),this.initialized=!0;const r=this.adapter;[a.CREATE,a.UPDATE,a.DELETE,c.CREATE_ALL,c.UPDATE_ALL,c.DELETE_ALL].forEach(t=>{if(!r[t])throw new u(`Method ${t} not found in ${r.alias} adapter to bind Observables Dispatch`);let e=Object.getOwnPropertyDescriptor(r,t),s=r;for(;!e&&s!==Object.prototype;)s=Object.getPrototypeOf(s),e=Object.getOwnPropertyDescriptor(s,t);function i(t){switch(t){case c.CREATE_ALL:return a.CREATE;case c.UPDATE_ALL:return a.UPDATE;case c.DELETE_ALL:return a.DELETE;default:return t}}e&&e.writable?r[t]=new Proxy(r[t],{apply:async(e,r,s)=>{const{log:n,ctxArgs:o,ctx:a}=r.logCtx(s.slice(3-(4-s.length),s.length),e),[c,l,u]=s,d=await e.call(r,c,l,u,...o),h=[c,i(t),l];return a.get("observeFullResult")&&h.push(Array.isArray(d)?d.map(t=>c(t)):c(d)),this.updateObservers(...h,...o).catch(e=>n.error(`Failed to dispatch observer refresh for ${t} on ${c.name||c} for ${l}: ${e}`)),d}}):this.log.error(`Could not find method ${t} to bind Observables Dispatch`)})}async close(...t){}observe(t){if(!(t instanceof re))throw new Mt("Only Adapters can be observed by dispatch");if(this.adapter){if(this.isSameObservedAdapter(t))return()=>this.unObserve(t);throw new Mt("Dispatch is already observing another adapter")}return this.adapter=t,this.models=re.models(this.adapter.alias),this.initialize().then(()=>this.log.verbose(`Dispatch initialized for ${this.adapter.alias} adapter`)),()=>this.unObserve(t)}unObserve(t){if(!this.isSameObservedAdapter(t))throw new Mt("Only the adapter that was used to observe can be unobserved");this.adapter=void 0}async updateObservers(t,e,r,...s){if(!t)throw new u("Model must be provided for observer update");const i=t&&"string"==typeof t?t:z.tableName(t);if(!this.adapter)return void this.log.for(this.updateObservers).debug(`No adapter observed for dispatch; skipping observer update for ${i}:${e}`);const{log:n,ctxArgs:o,ctx:a}=this.logCtx(s,this.updateObservers);try{n.debug(`dispatching observer refresh for ${e}:${i}: ${r}${a.get("observeFullResult")?" - including result":""}`),await this.adapter.refresh(t,e,r,...o)}catch(t){throw new u("Failed to refresh dispatch: "+t)}}toString(){return(this.adapter?this.adapter.toString():"uninitialized")+" event dispatch"}}async function ks(t,e,r,s){if(t.get("allowGenerationOverride")&&void 0!==s[r])return;let{seed:i,args:n}=e;i&&"function"==typeof i&&(i=i(s,...n||[],t)),s[r]=await Wt.instance.generate(i)}function Cs(t=!1,e,...r){"function"==typeof t&&(e=t,t=!1);const s=Ct.UUID;return ht.for(s).define({decorator:(t,e,...r)=>{const s={update:t,seed:e,args:r},i=[H(),x(Ct.UUID),A(ks,s,{priority:54})];return t&&i.push(E(ks,s,{priority:54})),t||i.push(b()),gt(...i)},args:[t,e,...r]}).apply()}re&&(re._baseDispatch=Os);class Ts extends $t{static{this.lock=new lt}constructor(t,e,r={}){super(),this.options=t,this.adapter=e,this.repo=Fe.forModel(rs,e.alias).override(r)}async current(...t){const{log:e,ctx:r}=await this.logCtx(t,a.READ,!0),{name:s,startWith:i}=this.options;try{const t=await this.repo.read(s,r);return this.parse(t.current)}catch(t){if(t instanceof m){if(e.debug(`Sequence.current missing ${s}, returning startWith=${i}`),void 0===i)throw new u("Starting value is not defined for a non existing sequence");try{return this.parse(i)}catch(t){throw new u(`Failed to parse initial value for sequence ${i}: ${t}`)}}throw new u(`Failed to retrieve current value for sequence ${s}: ${t}`)}}async increment(t,e){const{log:r,ctx:s}=this.adapter.logCtx([e],this.increment),{type:i,incrementBy:n,name:o}=this.options;if(!o)throw new u("Sequence name is required");return Ts.lock.execute(async()=>{const e=t||n;if(e%n!==0)throw new u("Value to increment does not consider the incrementBy setting: "+n);const a="function"==typeof i&&i?.name?i.name:i,c=await this.current(s),l=async t=>{try{return await this.repo.update(new rs({id:o,current:t}),s)}catch(e){if(e instanceof m)return r.debug(`Sequence create ${o} current=${c} next=${t}`),this.repo.create(new rs({id:o,current:t}),s);throw e}};if("uuid"===a)for(;;){const t=await Promise.resolve(Wt.instance.generate(c));try{const e=await l(t);return r.debug(`Sequence uuid increment ${o} current=${c} next=${t}`),e.current}catch(t){if(t instanceof T)continue;throw t}}const d=await(async t=>{switch(a){case Number.name:return this.parse(t)+e;case BigInt.name:return this.parse(t)+BigInt(e);case String.name:return this.parse(t);case"serial":return await Promise.resolve(Jt.instance.generate(t));default:throw new u("Should never happen")}})(c),h=await l(d);return r.debug(`Sequence.increment ${o} current=${c} next=${d}`),h.current},o)}async next(...t){const{ctx:e}=(await this.logCtx(t,a.UPDATE,!0)).for(this.next);return this.increment(void 0,e)}async range(t,...e){const{ctx:r,log:s}=(await this.logCtx(e,a.UPDATE,!0)).for(this.range);if("uuid"===this.options.type||"serial"===this.options.type)throw new Mt(`type ${this.options.type} is currently not suppported for this adapter`);const i="function"==typeof this.options.type&&this.options.type?.name?this.options.type.name:this.options.type,n=this.parse(this.options.incrementBy),o=await this.increment(this.parse(t)*n,r);let c=[];for(let e=0;t-1>=e;e++)c.push(o-n*this.parse(e));if(c=c.reverse(),c[c.length-1]!==o&&"String"!==i)throw new u("Miscalculation of range");return s.debug("Calculated range: "+c.join(", ")),c}async ensureAtLeast(t,...e){const{ctx:r}=(await this.logCtx(e,a.UPDATE,!0)).for(this.ensureAtLeast),{name:s}=this.options;if(!s)throw new u("Sequence name is required");const i=this.parse(t),n=(t,e)=>"bigint"==typeof t||"bigint"==typeof e?BigInt(t)>BigInt(e):"number"==typeof t||"number"==typeof e?Number(t)>Number(e):t+"">e+"";return Ts.lock.execute(async()=>{const t=async()=>{try{return await this.repo.read(s,r)}catch(t){if(t instanceof m)return;throw t}};for(;;)try{const e=await t();if(!e)return await this.repo.create(new rs({id:s,current:i}),r),i;const o=this.parse(e.current);return n(i,o)?(await this.repo.update(new rs({id:s,current:i}),r),i):o}catch(t){if(t instanceof T)continue;throw t}},s)}parse(t){return Ts.parseValue(this.options.type,t)}logCtx(t,e,r=!1){const s=this.adapter.logCtx([rs,...t],e,r);function i(t){return t.ctxArgs.shift(),t}return s instanceof Promise?s.then(i):i(s)}static pk(t){return z.sequenceName(t,"pk")}static parseValue(t,e){switch("function"==typeof t&&t?.name?t.name:t){case Number.name||Number.name.toLowerCase():return"string"==typeof e?parseInt(e):"number"==typeof e?e:BigInt(e);case BigInt.name||BigInt.name.toLowerCase():return BigInt(e);case String.name||String.name.toLowerCase():return e.toString();case void 0:case"uuid":case"serial":return e;default:throw new Mt(`Unsupported sequence type: ${t} for adapter ${this}`)}}}function Ns(t,...e){let r;if(t instanceof Es&&(r=t.repo.adapter),t instanceof Fe&&(r=t.adapter),t instanceof re&&(r=t),!r)throw new u("Could not find adapter to extract transaction");return r.transactionLock(...e)}function Ds(t,...e){return new Kt(Ns(t,...e))}re._baseSequence=Ts,ht.for(ut.TRANSACTIONAL).define({decorator:(...t)=>(e,r,s)=>{if(!s)throw new u("This decorator only applies to methods");return At()(e,r,s),dt.set(e.constructor,dt.key(ut.TRANSACTIONAL,r),{data:t}),s.value=new Proxy(s.value,{async apply(t,e,r){const{log:s,ctx:i}=(await e.logCtx(r,t.name,!0)).for(t),n=i.getOrUndefined("transactionLock")||Ds(e);let o;i.put("transactionLock",n),await n.acquire();try{o=await t.call(e,...r,i)}catch(t){try{await n.rollback(t)}catch(t){s.error("Failed to rollback transaction",t)}throw t}try{await n.release()}catch(t){throw new u("Failed to release transaction: "+t)}return o}}),s}}).apply();class _s extends ps{constructor(){super()}for(t,...e){throw new Mt("Persistence service cannot be overridden")}async initialize(...t){const e=t.shift();if(!e||!Array.isArray(e)||e instanceof Rt||!e.every(t=>Array.isArray(t)))throw new u("Missing/invalid configuration");const{log:r,ctxArgs:s}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.initialize),i=e.map(([t,e,...s])=>{try{r.silly(`Initializing ${t.name} with config: ${JSON.stringify(e)}`);const i=new t(e,...s);return r.debug(`Initialized ${i.toString()}...`),i}catch(e){throw new u(`Failed to initialize ${t.name}: ${e}`)}});for(const t of i)try{await t.initialize(...s)}catch(e){throw new u(`Failed to initialize ${t.toString()}: ${e}`)}return{client:i,config:e}}}let Is=class extends z{constructor(t){super(t),this.strategy=Be.EXPONENTIAL,this.baseMs=1e3,this.maxMs=6e4,this.jitter=Pe.FULL}};i([H(),X(String),et(Be),St("the backoff strategy"),n("design:type",String)],Is.prototype,"strategy",void 0),i([H(),St("base interval between attempts"),n("design:type",Number)],Is.prototype,"baseMs",void 0),i([H(),St("max interval"),n("design:type",Number)],Is.prototype,"maxMs",void 0),i([X(String),et(Pe),St("optional jitter strategy"),n("design:type",String)],Is.prototype,"jitter",void 0),Is=i([W(),n("design:paramtypes",[Object])],Is);let Bs=class extends z{constructor(t){super(t)}};i([H(),St("The error message"),n("design:type",String)],Bs.prototype,"message",void 0),i([bt(),St("The error stack"),n("design:type",String)],Bs.prototype,"stack",void 0),i([bt(),St("The error code"),n("design:type",String)],Bs.prototype,"code",void 0),i([bt(),St("The error details"),n("design:type",Object)],Bs.prototype,"details",void 0),Bs=i([W(),n("design:paramtypes",[Object])],Bs);let Ps=class extends z{constructor(t){if(super(t),this.ts=new Date,"string"==typeof this.payload)try{this.payload=JSON.parse(this.payload)}catch{}}};i([ir(),P(["taskId","classification","uuid"],":"),n("design:type",String)],Ps.prototype,"id",void 0),i([Br(),b(),H(),R(),Cs(!1),n("design:type",String)],Ps.prototype,"uuid",void 0),i([Br(),b(),H(),Xe([oe.ASC,oe.DSC]),n("design:type",String)],Ps.prototype,"taskId",void 0),i([rt(),Br(),H(),Xe([oe.ASC,oe.DSC]),n("design:type",Date)],Ps.prototype,"ts",void 0),i([Br(),b(),H(),et(Re),Xe([oe.ASC,oe.DSC]),n("design:type",String)],Ps.prototype,"classification",void 0),i([bt(),Br(),$(),b(),n("design:type",Object)],Ps.prototype,"payload",void 0),Ps=i([Ir("task_event"),W(),n("design:paramtypes",[Object])],Ps);class Rs extends st{constructor(){super()}preSerialize(t,...e){return this.serializeValue(t,...e)}deserialize(t,...e){const r=JSON.parse(t);return this.rebuildValue(r)}serializeValue(t,...e){if(null==t)return t;if("object"!=typeof t)return t;if(t instanceof Date)return t.toISOString();if(Array.isArray(t))return t.map(t=>this.serializeValue(t,...e));if(t instanceof ne){const r=this.serializePlain(t,...e);return r[it.ANCHOR]="??condition",r}return z.isModel(t)?this.serializeModel(t,...e):this.serializePlain(t,...e)}serializeModel(t,...e){const r=this.serializePlain(t,...e),s=this.getMetadata(t.constructor)??t.constructor?.name;return s&&(r[it.ANCHOR]=s),r}serializePlain(t,...e){const r={};for(const[s,i]of Object.entries(t))r[s]=this.serializeValue(i,...e);return r}getMetadata(t){try{return dt.modelName(t)}catch{return}}rebuildValue(t){if(null===t||"object"!=typeof t)return t;if(Array.isArray(t))return t.map(t=>this.rebuildValue(t));const e=t[it.ANCHOR],r=this.rebuildObject(t);return e?"??condition"===e?ne.from(r):z.build(r,e):r}rebuildObject(t){const e={};for(const[r,s]of Object.entries(t))r!==it.ANCHOR&&(e[r]=this.rebuildValue(s));return e}serialize(t,...e){return JSON.stringify(this.preSerialize(t))}}let $s=class extends z{constructor(t){super(t),this.ts=new Date}};i([rt(),H(),n("design:type",Date)],$s.prototype,"ts",void 0),i([H(),et(G),n("design:type",String)],$s.prototype,"level",void 0),i([nt(0),n("design:type",Number)],$s.prototype,"step",void 0),i([H(),bt(),n("design:type",String)],$s.prototype,"msg",void 0),i([bt(),n("design:type",Object)],$s.prototype,"meta",void 0),$s=i([W(),n("design:paramtypes",[Object])],$s);let Fs=class extends z{constructor(t){super(t),this.atomicity=$e.ATOMIC,this.status=Ie.PENDING,this.attempt=0,this.logTail=[]}};i([ir(),Cs(),St("the task id"),n("design:type",String)],Fs.prototype,"id",void 0),i([Br(),H(),X(String),et($e),Xe([oe.ASC,oe.DSC]),St("defines a single or composite task"),n("design:type",String)],Fs.prototype,"atomicity",void 0),i([Br(),H(),Xe([oe.ASC,oe.DSC]),St("Holds task classification - must match @task()"),n("design:type",String)],Fs.prototype,"classification",void 0),i([Br(),bt(),Xe([oe.ASC,oe.DSC]),St("optional task name for ambiguity"),n("design:type",String)],Fs.prototype,"name",void 0),i([Br(),bt(),St("Optional lock key. Tasks/steps sharing the same key cannot run concurrently"),n("design:type",String)],Fs.prototype,"lock",void 0),i([Br(),H(),X(String),et(Ie),Xe([oe.ASC,oe.DSC]),Xe([oe.ASC,oe.DSC],["nextRunAt"]),Xe([oe.ASC,oe.DSC],["leaseExpiry"]),Xe([oe.ASC,oe.DSC],["scheduledTo"]),St("Holds the task current status"),n("design:type",String)],Fs.prototype,"status",void 0),i([bt(),Br(),$(Rs),St("Holds task input"),n("design:type",Object)],Fs.prototype,"input",void 0),i([bt(),Br(),$(Rs),St("Holds the task output when successfully completed"),n("design:type",Object)],Fs.prototype,"output",void 0),i([bt(),Br(),$(),St("Holds the error for failed tasks"),n("design:type",Bs)],Fs.prototype,"error",void 0),i([Br(),H(),nt(0),Xe([oe.ASC,oe.DSC]),St("Holds the current attempt"),n("design:type",Number)],Fs.prototype,"attempt",void 0),i([Br(),nt(1),H(),St("max attempts for the task"),n("design:type",Number)],Fs.prototype,"maxAttempts",void 0),i([Br(),H(),$(),St("backoff configuration"),n("design:type",Is)],Fs.prototype,"backoff",void 0),i([rt(),Br(),St("Next execution timestamp"),n("design:type",Date)],Fs.prototype,"nextRunAt",void 0),i([rt(),Br(),St("Task scheduled timestamp"),n("design:type",Date)],Fs.prototype,"scheduledTo",void 0),i([Br(),$(),St("Task dependencies. Supports '<taskId>' or '<taskId>:<step index|step reference>'"),n("design:type",Array)],Fs.prototype,"dependencies",void 0),i([bt(),Br(),St("Task lease owner identifier"),n("design:type",String)],Fs.prototype,"leaseOwner",void 0),i([rt(),Br(),St("Task lease expiration timestamp"),n("design:type",Date)],Fs.prototype,"leaseExpiry",void 0),i([bt(),Br(),$(),St("Holds the various steps definition and inputs - only for type === 'composite'"),n("design:type",Array)],Fs.prototype,"steps",void 0),i([bt(),Br(),nt(0),Xe([oe.ASC,oe.DSC]),St("Holds the current step - only for type === 'composite'"),n("design:type",Number)],Fs.prototype,"currentStep",void 0),i([bt(),Br(),$(),St("Holds the step results - only for type === 'composite'"),n("design:type",Array)],Fs.prototype,"stepResults",void 0),i([bt(),Br(),$(),St("Holds the task log entries"),n("design:type",Array)],Fs.prototype,"logTail",void 0),i([Br(),Mr(),Xe([oe.ASC,oe.DSC]),St("timestamp of creation"),n("design:type",Date)],Fs.prototype,"createdAt",void 0),i([Br(),jr(),Xe([oe.ASC,oe.DSC]),St("timestamp of last update"),n("design:type",Date)],Fs.prototype,"updatedAt",void 0),i([Br(),Fr(),Xe([oe.ASC,oe.DSC]),St("Holds the creator of the task"),n("design:type",String)],Fs.prototype,"createdBy",void 0),i([Br(),Lr(),Xe([oe.ASC,oe.DSC]),St("Holds the creator of the task"),n("design:type",String)],Fs.prototype,"updatedBy",void 0),Fs=i([St("Holds the current step when applicable"),Ir("tasks"),W(),n("design:paramtypes",[Object])],Fs);let Ls=class extends z{constructor(t){super(t)}};i([H(),St("The status of a step"),n("design:type",String)],Ls.prototype,"status",void 0),i([bt(),St("The result of a successful step"),n("design:type",Object)],Ls.prototype,"output",void 0),i([bt(),St("the error of a failed step"),n("design:type",Bs)],Ls.prototype,"error",void 0),Ls=i([W(),n("design:paramtypes",[Object])],Ls);let Ms=class extends z{constructor(t){super(t)}};i([H(),St("task handler type"),n("design:type",String)],Ms.prototype,"classification",void 0),i([ot(1),St("optional task name for ambiguity"),n("design:type",String)],Ms.prototype,"name",void 0),i([St("optional task step input"),bt(),n("design:type",Object)],Ms.prototype,"input",void 0),i([St("Optional lock key. Tasks/steps sharing the same key cannot run concurrently"),bt(),n("design:type",String)],Ms.prototype,"lock",void 0),i([St("Task-step dependencies. Supports '<taskId>' or '<taskId>:<step index|step reference>'"),bt(),tt(()=>String),n("design:type",Array)],Ms.prototype,"dependsOn",void 0),Ms=i([W(),n("design:paramtypes",[Object])],Ms);class js extends z{constructor(t){super(t),this.baseMs=1e3,this.jitter=Pe.FULL,this.maxMs=6e4,this.strategy=Be.EXPONENTIAL,z.fromModel(this,t)}setBaseMs(t){return this.baseMs=t,this}setJitter(t){return this.jitter=t,this}setMaxMs(t){return this.maxMs=t,this}setStrategy(t){return this.strategy=t,this}build(){const t=this.hasErrors();if(t)throw new d(t);return new Is(this)}}i([H(),nt(1e3),n("design:type",Number)],js.prototype,"baseMs",void 0),i([H(),et(Pe),n("design:type",String)],js.prototype,"jitter",void 0),i([at("baseMs"),nt(1e3),H(),n("design:type",Number)],js.prototype,"maxMs",void 0),i([H(),et(Be),n("design:type",String)],js.prototype,"strategy",void 0);class Us extends z{setClassification(t){return this.classification=t,this}setName(t){return this.name=t,this}setAtomicity(t){return this.atomicity=t,this}setBackoff(t){if(t)return this.backoff=t,this;const e=new js,r=this;return e.build=new Proxy(e.build,{apply:(t,e,s)=>(r.backoff=Reflect.apply(t,e,s),r)}),e}setInput(t){return this.input=t,this}setLock(t){return this.lock=t,this}setDependencies(t){return this.dependencies=t,this}setDependsOn(t){return this.setDependencies(t)}setMaxAttempts(t){return this.maxAttempts=t,this}constructor(t){super(t),this.status=Ie.PENDING,this.atomicity=$e.ATOMIC,this.backoff=new Is,this.maxAttempts=1,z.fromModel(this,t)}build(){const t=this.hasErrors();if(t)throw new d(t);return new Fs(this)}}i([H(),n("design:type",String)],Us.prototype,"classification",void 0),i([bt(),n("design:type",String)],Us.prototype,"name",void 0),i([H(),n("design:type",String)],Us.prototype,"status",void 0),i([H(),n("design:type",String)],Us.prototype,"atomicity",void 0),i([H(),n("design:type",Is)],Us.prototype,"backoff",void 0),i([bt(),n("design:type",Object)],Us.prototype,"input",void 0),i([bt(),n("design:type",String)],Us.prototype,"lock",void 0),i([bt(),tt(()=>String),n("design:type",Array)],Us.prototype,"dependencies",void 0),i([nt(1),H(),n("design:type",Number)],Us.prototype,"maxAttempts",void 0);class Gs{constructor(t,e){this.parent=t,this.step=e}setClassification(t){return this.step.classification=t,this}setName(t){return this.step.name=t,this}setInput(t){return this.step.input=t,this}setLock(t){return this.step.lock=t,this}setDependsOn(t){return this.step.dependsOn=t,this}addStep(t,e,r){return this.parent.addStep(t,e,r)}setSteps(t){return this.parent.setSteps(t)}build(){return this.parent}}class Ys extends Us{constructor(t){super(t),this.stepResults=[],z.fromModel(this,t),this.atomicity=$e.COMPOSITE}setAtomicity(t){throw new u("Atomicity locked to "+$e.COMPOSITE)}setSteps(t){return this.steps=(t??[]).map(t=>t instanceof Ms?t:new Ms(t)),this}addStep(t,e,r){this.steps=this.steps||[];const s=new Date,i=1===arguments.length,n=arguments.length>=3,o=new Ms({classification:t,name:n&&"string"==typeof e?e:void 0,input:n?r:i?void 0:e,createdAt:s,updatedAt:s});return this.steps.push(o),i?new Gs(this,o):this}}i([tt(()=>Ms),n("design:type",Array)],Ys.prototype,"steps",void 0);class zs extends Ft{get type(){if(!this._type){const t=dt.get(this.constructor,je);"string"==typeof t?this._type=t:t&&"string"==typeof t.type&&(this._type=t.type)}if(!this._type)throw new u("No type annotation for this handler found. did you use @task()?");return this._type}constructor(){super(),p(this,this.runPrefix.bind(this),this.run.bind(this),this.runSuffix.bind(this),this.run.name)}async runPrefix(t,...e){const{log:r,ctx:s,ctxArgs:i}=this.logCtx(e,this.runPrefix);return r.info(`Running task ${s.taskId} attempt ${s.attempt}`),[t,...i]}runSuffix(t,e){const{log:r}=this.logCtx([e],this.runPrefix);return r.info(`Concluded task ${e.taskId} attempt ${e.attempt}`),t}async catch(t,e,r){}}function qs(t){return ht.for(je).define({decorator:t=>e=>{const r={type:t};return dt.set(je,t,e),vt(je,r)(e)},args:[t]}).apply()}let Hs=class extends zs{constructor(){super()}async run(t,e){const r=e.logger;try{let s;if(t instanceof ne)s=t,r.info("Starting task cleanup with custom condition");else{r.info("Starting task cleanup with expiry dates");const e=ne.attr("status").eq(Ie.SUCCEEDED).and(ne.attr("updatedAt").lte(t.successfulExpiry)),i=ne.attr("status").eq(Ie.FAILED).and(ne.attr("updatedAt").lte(t.failedExpiry)),n=ne.attr("status").eq(Ie.CANCELED).and(ne.attr("updatedAt").lte(t.cancelledExpiry));s=e.or(i).or(n)}r.info("Querying tasks for cleanup");const i=await this.tasks.select(["id"]).where(s).execute(e);if(0===i.length)return r.info("No tasks found for cleanup"),[];r.info(`Found ${i.length} tasks to delete`);const n=await this.tasks.deleteAll(i.map(t=>t.id),e);return r.info(`Successfully deleted ${n.length} tasks`),r.debug("deleted tasks:",n),n}catch(t){throw r.error("Error during task cleanup",t),t}}};i([Ge(Fs),n("design:type",Object)],Hs.prototype,"tasks",void 0),Hs=i([qs("cleanup-task"),n("design:paramtypes",[])],Hs);class Vs{constructor(t,e=150,r=300,s){this.logger=t,this.bufferSize=e,this.maxBufferSize=r,this.pipe=s,this.history=[],this.root=this.logger.root,Object.values(G).forEach(t=>{this[t]=new Proxy(this[t],{apply:(e,r,s)=>{e.apply(r,s),r.push(t,...s)}})})}push(t,e,r){this.history.length<this.maxBufferSize||this.history.splice(0,this.history.length-this.bufferSize),this.history.push([t,e,r])}flush(t){const e=this.history;return this.history=[],t&&e.length?t(e).catch(t=>this.logger.error("Failed to pipe logs",t)).finally(()=>this.history=[]):(this.history=[],e)}benchmark(t){return this.logger.benchmark(t)}clear(){return this.logger=this.logger.clear(),this}debug(t,e){this.logger.debug(t,e)}error(t,e,r){this.logger.error(t,e,r)}for(t,...e){return new Proxy(this,{get(r,s){if("logger"===s){const i=Reflect.get(r,s);try{return i.for(t,...e)}catch(t){r.error("Failed to bind task logger. received: "+(i&&i.constructor?i.constructor.name:i.name?i.name:"unknown"),t);try{r.trace(JSON.stringify(i,void 0,2))}catch(t){r.trace("unserializable output: "+(i.name||"unknown"))}throw t}}return Reflect.get(r,s)}})}info(t,e){this.logger.info(t,e)}setConfig(t){this.logger.setConfig(t)}silly(t,e){this.logger.silly(t,e)}trace(t,e){this.logger.trace(t,e)}verbose(t,e,r){this.logger.verbose(t,e,r)}warn(t,e){this.logger.warn(t,e)}}function Qs(t,e={logProgress:!0,logStatus:!0,style:!0}){return async r=>{switch(t=t.for(r.taskId,{style:!1}),r.classification){case Re.LOG:{const s=r.payload.map(t=>Array.isArray(t)?t:[t.level,t.msg,t.meta]);for(let[r,i,n]of s){e.style||(i=Y(i),i=i.clear().toString());const s=[i];r===G.verbose&&s.push(1),s.push(n);try{t[r](...s)}catch(e){t.error("Failed to pipe task logs",e)}}break}case Re.PROGRESS:if(e.logProgress){const{currentStep:e,totalSteps:s}=r.payload;t.info(`### STEP ${e}/${s}`)}break;case Re.STATUS:if(e.logStatus){const e=r.payload?.status??r.payload;let s=Y(e);switch(e){case Ie.SUCCEEDED:s=s.green.bold;break;case Ie.RUNNING:s=s.blue.bold;break;case Ie.PENDING:s=s.yellow;break;case Ie.WAITING_RETRY:s=s.yellow.bold;break;case Ie.FAILED:s=s.red.bold;break;case Ie.CANCELED:s=s.magenta.bold;break;case Ie.SCHEDULED:s=s.cyan;break;default:throw new u("Received unknown task status: "+r.payload)}t.info("### STATUS "+s)}break;default:throw new u("Unknown task event classification: "+r.classification)}}}function Ws(t,e){const r=e.strategy===Be.FIXED?e.baseMs:e.baseMs*Math.pow(2,Math.max(0,t-1)),s=Math.min(r,e.maxMs);return e.jitter===Pe.FULL?Math.floor(Math.random()*s):s}function Js(t){return new Bs({message:t?.message??t+"",stack:t?.stack,code:t?.code,details:t?.details})}function Xs(t){return new Promise(e=>setTimeout(e,t))}class Ks extends Error{constructor(t){super("Task requested state change: "+t.status),this.request=t,this.name=Ks.name,Object.setPrototypeOf(this,Ks.prototype)}}class Zs extends Rt{get taskId(){return this.get("taskId")}get logger(){return super.logger}get step(){return this.getOrUndefined("step")}setStep(t){this.cache.put("step",t)}get pipe(){return this.get("pipe").bind(this)}flush(){return this.get("flush")()}get attempt(){return this.get("attempt")}get progress(){return this.get("progress")}get heartbeat(){return this.get("heartbeat")}cacheResult(t,e){const r=this.cache.has("resultCache")&&this.cache.get("resultCache")||{};r[t]=e,this.cache.put("resultCache",r)}changeState(t,e){throw new Ks({status:t,...e})}cancel(t,e){this.changeState(Ie.CANCELED,{error:this.toTaskError(t,e)})}retry(t){this.changeState(Ie.WAITING_RETRY,{error:this.toTaskError(t)})}reschedule(t,e){const r=t instanceof Date?t:t.build();this.changeState(Ie.SCHEDULED,{error:this.toTaskError(e),scheduledTo:r})}toTaskError(t,e){if(t||e)return t instanceof Bs?t:t instanceof Error?Js(t):new Bs({message:(t??"Task requested state change")+"",details:e})}get resultCache(){return this.get("resultCache")}scheduleSteps(...t){const e=(t??[]).map(t=>t instanceof Ms?t:new Ms(t));return{afterCurrent:async()=>{const t=this.getOrUndefined("scheduleCompositeSteps");if(!t)throw new u("scheduleSteps().afterCurrent() is only available while running a composite task step");await t(e)}}}constructor(t){super(t)}}class ti{constructor(){this.handlers=new Map,this.initialize()}initialize(){const t=dt.tasks();t&&Object.entries(t).forEach(([t,e])=>{let r;try{r=new e}catch(e){throw new u(`Failed to initialize handler with key ${t}: ${e}`)}this.register(r)})}register(t){if(this.handlers.has(t.type))throw new u("Duplicate task handler: "+t.type);this.handlers.set(t.type,t)}get(t){return this.handlers.get(t)}}class ei extends Lt{constructor(){super(...arguments),this.listeners=new Set}observe(t,e){return super.observe(t,e)}unObserve(t){super.unObserve(t)}emit(t,e){this.updateObservers(Ps,t.classification,t.id,t,e)}async updateObservers(t,e,r,s,...i){const{log:n,ctxArgs:o}=re.logCtx(this.updateObservers,void 0,!1,...i);(await Promise.allSettled(this.observers.filter(s=>{const{filter:i}=s;if(!i)return!0;try{return i(t,e,r,...o)}catch(t){return n.error(`Failed to filter observer ${s.observer.toString()}: ${t}`),!1}}).map(t=>{t.observer.refresh(s,...o)}))).forEach((t,e)=>{"rejected"===t.status&&n.error(`Failed to update observable ${this.observers[e].toString()}: ${t.reason}`)})}}function ri(t,e){return t instanceof Error&&"nextAction"in t&&"string"==typeof t.nextAction&&(!e||t instanceof e)}class si extends F{constructor(t,e,r,s,i,n=500){super(t,r,n),this.taskId=e,this.details=s,this.meta=i}}class ii extends si{constructor(t,e,r){super(ii.name,t,e?.message??`Task ${t} failed`,e,r,500)}}class ni extends si{constructor(t,e,r){const s=r?.nextRunAt instanceof Date?r.nextRunAt.toISOString():r?.nextRunAt;super(ni.name,t,e?.message??`Task ${t} scheduled for retry${s?" at "+s:""}`,e,r,409)}}class oi extends si{constructor(t,e,r){super(oi.name,t,e?.message??`Task ${t} canceled`,e,r,400)}}class ai extends si{constructor(t,e,r){const s=r?.scheduledTo instanceof Date?r.scheduledTo.toISOString():r?.scheduledTo;super(ai.name,t,e?.message??`Task ${t} rescheduled${s?" to "+s:""}`,e,r,202)}}class ci{constructor(t,e){this.bus=t,this.task=e,this.resolved=!1,this.unregistration=t.observe(this,(t,e,r,...s)=>r.startsWith(this.task.id)&&(t===Ps||t===z.tableName(Ps))),this.pipe(this.track.bind(this)),this.resolveTerminalState()}resolve(){return this.awaitStatusTerminal([Ie.SUCCEEDED,Ie.FAILED,Ie.CANCELED,Ie.SCHEDULED])}wait(){return this.awaitStatusTerminal([Ie.SUCCEEDED,Ie.FAILED,Ie.CANCELED])}attach(t,e={logProgress:!0,logStatus:!0,style:!0}){this.pipe(Qs(t,e))}logs(t){this.pipe(async e=>{if(e.classification!==Re.LOG)return;const r=(e.payload??[]).map(t=>Array.isArray(t)?t:[t.level,`${t.ts} - ${t.msg}`,t.meta]);await t(r)},Re.LOG)}pipe(t,e=Re.ALL){this.pipes=this.pipes||{},this.pipes[e]=this.pipes[e]||new Set,this.pipes[e].add(t)}succeed(t){this.complete()}fail(t){this.complete()}cancel(t){t.payload&&this.fail()}retry(){}reschedule(){}onSucceed(t){return this.registerStatusHandler(Ie.SUCCEEDED,t)}onFailure(t){return this.registerStatusHandler(Ie.FAILED,t)}onCancel(t){return this.registerStatusHandler(Ie.CANCELED,t)}onUpdate(t){const e=async(e,r)=>{e.classification===Re.UPDATE&&await t(e,r)};return this.pipe(e,Re.UPDATE),()=>{this.pipes?.[Re.UPDATE]?.delete(e)}}awaitStatusTerminal(t){return new Promise((e,r)=>{const s=[];let i=!1;const n=async t=>{if(!i){(()=>{if(!i){i=!0;for(const t of s)t()}})();try{t.payload?.status===Ie.SUCCEEDED?e(this.extractOutput(t)):r(this.extractError(t))}catch(t){r(t)}}};t.forEach(t=>{const e=this.registerStatusHandler(t,n);s.push(e)})})}extractOutput(t){return void 0!==t.payload?.output?t.payload.output:this.task.output}extractError(t){const e=t.payload?.status??this.task.status,r=this.getNextAction(e),s=t.payload?.originalError;if(s instanceof Error)return this.assignNextAction(s,r);const i=this.buildMeta(e,t.payload),n=this.createTaskControlError(e,t.payload?.error??this.task.error,i);return this.assignNextAction(n,r)}complete(){this.resolved||(this.resolved=!0,this.unregistration(),this.pipes=void 0)}isTerminalStatus(t){return[Ie.SUCCEEDED,Ie.CANCELED,Ie.FAILED].includes(t)}async track(t,e){if(t.classification!==Re.STATUS)return;if(!t.payload)return;const r=t.payload.status;this.task.status=r,void 0!==t.payload.output&&(this.task.output=t.payload.output),t.payload.error&&(this.task.error=t.payload.error),void 0!==t.payload.nextRunAt&&(this.task.nextRunAt=t.payload.nextRunAt),void 0!==t.payload.scheduledTo&&(this.task.scheduledTo=t.payload.scheduledTo),r!==Ie.SUCCEEDED?(r===Ie.FAILED&&this.fail(),r===Ie.CANCELED&&this.cancel(t),r===Ie.WAITING_RETRY&&this.retry(),r===Ie.SCHEDULED&&this.reschedule()):this.succeed()}registerStatusHandler(t,e){const r=async(r,s)=>{r.payload?.status===t&&await e(r,s)};if(this.pipe(r,Re.STATUS),this.task.status===t){const e=this.buildTerminalEvent(t);r(e,this.getTerminalContext())}return()=>{this.pipes?.[Re.STATUS]?.delete(r)}}getTerminalContext(){return this.terminalContext||(this.terminalContext=new Rt),this.terminalContext}buildTerminalEvent(t){const e={status:t};return t===Ie.SUCCEEDED&&(e.output=this.task.output),t!==Ie.FAILED&&t!==Ie.CANCELED||!this.task.error||(e.error=this.task.error),this.task.nextRunAt&&(e.nextRunAt=this.task.nextRunAt),this.task.scheduledTo&&(e.scheduledTo=this.task.scheduledTo),new Ps({classification:Re.STATUS,taskId:this.task.id,payload:e})}createTaskControlError(t,e,r){switch(t){case Ie.FAILED:return new ii(this.task.id,e,r);case Ie.CANCELED:return new oi(this.task.id,e,r);case Ie.WAITING_RETRY:return new ni(this.task.id,e,r);case Ie.SCHEDULED:return new ai(this.task.id,e,r);default:return new ii(this.task.id,e,r)}}assignNextAction(t,e){return e&&(t.nextAction=e),t}getNextAction(t){switch(t){case Ie.CANCELED:return Ie.CANCELED;case Ie.WAITING_RETRY:return Ie.WAITING_RETRY;case Ie.SCHEDULED:return Ie.SCHEDULED;case Ie.FAILED:return Ie.FAILED;default:return}}buildMeta(t,e){const r={};if(e?.nextRunAt&&(r.nextRunAt=e.nextRunAt),e?.scheduledTo&&(r.scheduledTo=e.scheduledTo),Object.keys(r).length)return r}resolveTerminalState(){if(!this.isTerminalStatus(this.task.status))return;if(this.task.status===Ie.SUCCEEDED)return void this.succeed(this.task.output);const t={status:this.task.status,nextRunAt:this.task.nextRunAt,scheduledTo:this.task.scheduledTo};this.fail(this.createTaskControlError(this.task.status,this.task.error,this.buildMeta(this.task.status,t)))}async refresh(t,e){if(!this.pipes)return;const r=this.pipes[Re.ALL]?[...this.pipes[Re.ALL].values()]:[];r.push(...this.pipes[t.classification]?.values()||[]);for(const s of r)try{await s(t,e)}catch(r){e.logger.error(`Failed to trigger pipe ${s.name} for event ${t.classification}. discarding event`,r)}}}class li extends Ft{get Context(){return Zs}get adapter(){return this._adapter||(this._adapter=this.config.adapter,this.config.overrides&&(this._adapter=this.adapter.for(this.config.overrides))),this._adapter}get registry(){return this.config.registry}get bus(){return this.config.bus}get tasks(){return this._tasks||(this._tasks=new(this.adapter.repository())(this.adapter,Fs,!0).override({afterQueryHandlers:!0})),this._tasks}get events(){return this._events||(this._events=new(this.adapter.repository())(this.adapter,Ps,!0).override({afterQueryHandlers:!0})),this._events}static createTaskContext(t,e){const r=new Zs(t);return e&&Object.keys(e).length?r.accumulate(e):r}constructor(t){super(),this.config=t,this.lock=new ct,this.running=!1;const e=Object.assign({},Ue.autoShutdown,t.autoShutdown);this.config=Object.assign({},Ue,t,{autoShutdown:e,bus:t.bus||new ei,registry:t.registry||new ti}),this.idleDelayMs=this.config.pollMsIdle}async push(t,e=!1,...r){const{ctx:s,log:i}=(await this.logCtx(r,a.CREATE,!0)).for(this.push);i.verbose("pushing task "+t.classification);const n=await this.tasks.create(t,s);return i.info(`${t.classification} task registered under ${n.id}`),e?{task:n,tracker:new ci(this.bus,n)}:n}schedule(t,e=!1,...r){return{for:async s=>{const i=s instanceof Date?s:s.build();return t.status=Ie.SCHEDULED,t.scheduledTo=i,t.nextRunAt=void 0,t.leaseOwner=void 0,t.leaseExpiry=void 0,await this.push(t,e,...r)}}}async track(t,...e){const{ctx:r,log:s}=(await this.logCtx(e,a.READ,!0)).for(this.track);s.verbose("tracking task "+t);let i=await this.tasks.read(t,r);return i=await this.ensureTaskError(i,r),s.info(`${i.classification} task found with id ${t}`),{task:i,tracker:new ci(this.bus,i)}}async ensureTaskError(t,e){if(![Ie.FAILED,Ie.CANCELED].includes(t.status)||t.error)return t;let r=t;for(let t=0;6>t;t+=1){await Xs(20);try{const t=await this.tasks.read(r.id,e);if(t.error)return t;r=t}catch{break}}return r}async cancel(t,...e){const{ctx:r}=(await this.logCtx(e,"cancel",!0)).for(this.cancel),s=await this.tasks.read(t,r);if(s.status===Ie.SUCCEEDED||s.status===Ie.FAILED)return s;s.status=Ie.CANCELED;const i=new Bs({message:`Task ${s.id} canceled`,code:400});s.error=i,s.leaseOwner=void 0,s.leaseExpiry=void 0,s.nextRunAt=void 0,s.scheduledTo=void 0;const n=await this.tasks.update(s,r);return await this.emitStatus(r,n,Ie.CANCELED,i),n}async isRunning(){await this.lock.acquire();const t=this.running;return this.lock.release(),t}async start(...t){const{ctx:e}=(await this.logCtx(t,"run",!0)).for(this.start);await this.lock.acquire(),this.running||(this.running=!0,this.lock.release(),this.idleDelayMs=this.config.pollMsIdle,this.loop(e))}async stop(...t){const{ctx:e,log:r}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.stop);await this.lock.acquire(),this.running||r.warn("stop method called when task engine was not running"),this.running=!1,this.lock.release();const s=await this.tasks.select(["id"]).where(ne.attr("status").eq(Ie.RUNNING)).execute(e),i=e.getOrUndefined?.("gracefulShutdownMsTimeout")??this.config.gracefulShutdownMsTimeout;return new Promise((t,n)=>{const o=setTimeout(()=>{r.error(`Graceful shutdown interrupted after ${i} ms...`),t()},i);Promise.allSettled(s.map(({id:t})=>new Promise((r,s)=>{this.track(t,e).then(({tracker:t})=>{t.resolve().then(r)}).catch(s)}))).then(e=>{clearTimeout(o),r.info(`Graceful shutdown completed before expiry. concluded ${e.length} tasks`),t()}).catch(t=>{clearTimeout(o),n(t)})})}async loop(...t){const{ctx:e}=this.logCtx(t,this.loop),r=this.config.autoShutdown??{enabled:!1,backoffStepMs:0,maxIdleDelayMs:this.config.pollMsIdle},s=Math.max(r.maxIdleDelayMs??this.config.pollMsIdle,this.config.pollMsIdle),i=r.backoffStepMs??0;for(;await this.isRunning();){const t=await this.claimBatch(e);await Promise.allSettled(t.map(t=>this.executeClaimed(t)));const n=0===t.length;if(n)if(r.enabled){if(this.idleDelayMs=Math.min(this.idleDelayMs+i,s),this.idleDelayMs>=s)return e.logger.info(`auto-shutdown triggered after ${this.idleDelayMs}ms idle polling`),void await this.stop(e)}else this.idleDelayMs=this.config.pollMsIdle;else this.idleDelayMs=this.config.pollMsIdle;const o=n?this.idleDelayMs:this.config.pollMsBusy;await Xs(Math.max(o,0))}}async claimBatch(t){const e=t.logger.for(this.claimBatch),r=new Date,s=ne.attribute("status").eq(Ie.PENDING),i=ne.attribute("status").eq(Ie.WAITING_RETRY).and(ne.attribute("nextRunAt").lte(r)),n=ne.attribute("status").eq(Ie.RUNNING).and(ne.attribute("leaseExpiry").lte(r)),o=ne.attribute("status").eq(Ie.SCHEDULED).and(ne.attribute("scheduledTo").lte(r)),a=s.or(i).or(n).or(o),c=await this.tasks.select().where(a).limit(Math.max(4*this.config.concurrency,20)).execute();e.verbose("claimBatch candidates:"+c.length);const l=[];for(const e of c){const r=await this.tryClaim(e,t);if(r&&l.push(r),l.length>=this.config.concurrency)break}return e.verbose("claimBatch claimed:"+l.length),l}async tryClaim(t,e){const r=e.logger.for(this.claimBatch),s=(new Date).getTime();let i=t;try{i=await this.tasks.read(t.id,e)}catch{}if(!await this.isRunnable(i,e))return null;const n=new Fs({...i,status:Ie.RUNNING,leaseOwner:this.config.workerId.toString(),leaseExpiry:new Date(s+(parseInt(this.config.leaseMs.toString())||6e4)),scheduledTo:void 0,nextRunAt:void 0});r.info(`running handler for ${t.id} (${t.classification}) atomicity ${t.atomicity}`);try{return await this.tasks.update(n,e)}catch{return null}}isTaskFinished(t){return[Ie.SUCCEEDED,Ie.FAILED,Ie.CANCELED].includes(t)}parseTaskDependency(t){const e=t?.trim();if(!e)return;const r=e.lastIndexOf(":");if(0>=r||r>=e.length-1)return{taskId:e};const s=e.slice(0,r).trim(),i=e.slice(r+1).trim();return s&&i?{taskId:s,stepRef:i}:{taskId:e}}normalizeDependencies(t){if(!t)return[];let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{e=[e]}return e instanceof Set&&(e=Array.from(e)),Array.isArray(e)?e.filter(t=>"string"==typeof t).map(t=>this.parseTaskDependency(t)).filter(Boolean):[]}resolveDependencyStepIndex(t,e){const r=e.trim();if(!r)return;const s=Number(r);if(Number.isInteger(s)&&s>=0)return s;const i=this.normalizeSteps(t.steps).findIndex(t=>t.name===r||t.classification===r);return 0>i?void 0:i}async areDependenciesSatisfied(t,e){if(!t.length)return!0;const r=Array.from(new Set(t.map(t=>t.taskId))),s=new Map;try{const t=await this.tasks.readAll(r,e);for(const e of t)e?.id&&s.set(e.id,e)}catch{return!1}for(const e of t)try{const t=s.get(e.taskId);if(!t)return!1;if(!e.stepRef){if(!this.isTaskFinished(t.status))return!1;continue}const r=this.resolveDependencyStepIndex(t,e.stepRef);if(null==r)return!1;const i=this.normalizeStepResults(t.stepResults)[r];if(!i||!this.isTaskFinished(i.status))return!1}catch{return!1}return!0}getStepLock(t,e){if(t.atomicity!==$e.COMPOSITE)return;const r=this.normalizeSteps(t.steps);if(!r.length)return;const s=r[e??0];return s?.lock}async hasLockConflict(t,e,r){const s=[t.lock,this.getStepLock(t,e)].filter(t=>!!t&&"string"==typeof t);if(!s.length)return!1;const i=await this.tasks.select().where(ne.attribute("status").eq(Ie.RUNNING)).execute(r);for(const e of i)if(e.id!==t.id&&[e.lock,this.getStepLock(e,e.currentStep)].filter(t=>!!t&&"string"==typeof t).some(t=>s.includes(t)))return!0;return!1}async isRunnable(t,e){const r=this.normalizeDependencies(t.dependencies);if(!await this.areDependenciesSatisfied(r,e))return!1;const s=t.atomicity===$e.COMPOSITE?t.currentStep??0:void 0;return!await this.hasLockConflict(t,s,e)}async executeClaimed(t){const{ctx:e,log:r}=(await this.logCtx([],t.classification,!0)).for(this.executeClaimed),s=this;let i=Promise.resolve();const n=new Zs(e).accumulate({taskId:t.id,logger:new Vs(r,this.config.streamBufferSize,this.config.maxLoggingBuffer),attempt:t.attempt,resultCache:{"task.attempt":t.attempt},pipe:async function(...e){const r=s.normalizePipeArgs(e);r.length&&(i=i.then(async()=>{const[e,i]=await s.appendLog(this,t,r);Object.assign(t,e),await s.emitLog(this,t.id,i)}),await i)},flush:async()=>n.logger.flush(n.pipe),progress:async e=>{await this.emitProgress(n,t.id,e)},heartbeat:async()=>{if(t.leaseOwner===this.config.workerId){t.leaseExpiry=new Date(Date.now()+this.config.leaseMs);try{t=await this.tasks.update(t)}catch{}}}});let o,a;await this.emitStatus(n,t,Ie.RUNNING);try{let e;if(t.atomicity===$e.COMPOSITE){e=await this.runComposite(t,n);try{const e=await this.tasks.read(t.id,n);Object.assign(t,e)}catch{}e?.stepResults&&(t.stepResults=e.stepResults,t.currentStep=e.stepResults.length)}else{const s=this.registry.get(t.classification);if(o=s,a=t.input,r.debug(`handler type for ${t.id} is ${s?.constructor?.name??"none"}`),!s)throw new u("No task handler registered for type: "+t.classification);e=await s.run(t.input,n),await n.flush(),r.verbose("handler finished for "+t.id)}t.status=Ie.SUCCEEDED,t.output=e,t.error=void 0,t.leaseOwner=void 0,t.leaseExpiry=void 0;const s=await this.tasks.update(t,n);Object.assign(t,s),n.logger.info(`task ${t.id} success state ${t.status}`),r.info(`task ${t.id} success state ${t.status} attempt ${t.attempt}`),await this.emitStatus(n,t,Ie.SUCCEEDED,e)}catch(e){try{await n.flush()}catch{}try{const e=await this.tasks.read(t.id,n);Object.assign(t,e)}catch{}if(e instanceof Ks)return void await this.handleTaskStateChange(e.request,t,n);try{await(o?.catch?.(a,e,n))}catch(t){r.error("task handler catch() hook failed",t)}if(r.error("task execution error",e),t.atomicity===$e.COMPOSITE){const e=this.normalizeStepResults(t.stepResults);if(t.stepResults=e,null==t.currentStep){const r=e.findIndex(t=>t.status===Ie.FAILED);0>r||(t.currentStep=r)}}const s=(t.attempt??0)+1,i=Js(e);if(s<t.maxAttempts){const o=Ws(s,this.normalizeBackoff(t.backoff)),a=new Date(Date.now()+o);t.attempt=s,t.status=Ie.WAITING_RETRY,t.nextRunAt=a,t.error=i,t.leaseOwner=void 0,t.leaseExpiry=void 0;const c=await this.tasks.update(t,n);Object.assign(t,c),r.warn(`task ${t.id} waiting retry state ${t.status} attempt ${t.attempt}`),await n.pipe(G.warn,"Retry scheduled",{nextRunAt:a,delayMs:o,attempt:s}),await this.emitStatus(n,t,Ie.WAITING_RETRY,i,e)}else{t.attempt=s,t.status=Ie.FAILED,t.error=i,t.leaseOwner=void 0,t.leaseExpiry=void 0;const o=await this.tasks.update(t,n);Object.assign(t,o),r.error(`task ${t.id} failed state ${t.status} attempt ${t.attempt}`),await n.pipe(G.error,"Task failed (max attempts reached)",{maxAttempts:t.maxAttempts}),await this.emitStatus(n,t,Ie.FAILED,i,e)}}}async handleTaskStateChange(t,e,r){switch(e.leaseOwner=void 0,e.leaseExpiry=void 0,t.status){case Ie.CANCELED:{const s=t.error??new Bs({message:`Task ${e.id} canceled`});return e.status=Ie.CANCELED,e.error=s,e.nextRunAt=void 0,e.scheduledTo=void 0,e=await this.tasks.update(e,r),await this.emitStatus(r,e,Ie.CANCELED,s),void await r.pipe(G.warn,"Task canceled via context")}case Ie.WAITING_RETRY:{const s=(e.attempt??0)+1,i=Ws(s,this.normalizeBackoff(e.backoff)),n=t.scheduledTo instanceof Date?t.scheduledTo:new Date(Date.now()+i),o=t.error??new Bs({message:`Task ${e.id} requested retry`});return e.status=Ie.WAITING_RETRY,e.attempt=s,e.error=o,e.nextRunAt=n,e.scheduledTo=void 0,e=await this.tasks.update(e,r),await this.emitStatus(r,e,Ie.WAITING_RETRY,o),void await r.pipe(G.warn,"Retry requested",{nextRunAt:n,delayMs:i,attempt:s})}case Ie.SCHEDULED:{if(!t.scheduledTo)throw new u("Scheduled state requires a target date");const s=t.error??new Bs({message:`Task ${e.id} rescheduled`});return e.status=Ie.SCHEDULED,e.scheduledTo=t.scheduledTo,e.error=s,e.nextRunAt=void 0,e=await this.tasks.update(e,r),await this.emitStatus(r,e,Ie.SCHEDULED,s),void await r.pipe(G.info,"Task rescheduled",{scheduledTo:t.scheduledTo.toISOString()})}default:throw new u("Unsupported task state change requested: "+t.status)}}async runComposite(t,e){const{ctx:r}=(await this.logCtx([e],t.classification,!0)).for(this.runComposite);let s=this.normalizeSteps(t.steps),i=t.currentStep??0;const n=this.normalizeStepResults(t.stepResults),o=(t,s)=>{e.cacheResult(t,s),r instanceof Zs&&r!==e&&r.cacheResult(t,s)};for(let e=0;e<n.length;e+=1){const r=n[e];if(r?.status===Ie.SUCCEEDED){const i=s[e];if(!i)continue;const n=`${t.id}:step:${e}`;o(i.classification,r.output),o(n,r.output)}}for(;i<s.length;){e.setStep(i);const a=s[i],c=this.registry.get(a.classification);if(!c)throw Error("No task handler registered for composite step: "+a.classification);const l=this.normalizeDependencies(a.dependsOn);await this.areDependenciesSatisfied(l,e)||e.reschedule(new Date(Date.now()+this.config.pollMsIdle),`Waiting dependencies for step ${i} (${a.classification})`),await this.hasLockConflict(t,i,e)&&e.reschedule(new Date(Date.now()+this.config.pollMsIdle),`Waiting lock for step ${i} (${a.classification})`),t.currentStep=i;const u=await this.tasks.update(t);Object.assign(t,u),await e.progress({currentStep:i,totalSteps:s.length});const d=i;e.cache.put("scheduleCompositeSteps",async r=>{const i=this.normalizeSteps(r);if(!i.length)return;const n=this.normalizeSteps(t.steps),o=Math.min(d+1,n.length);n.splice(o,0,...i),t.steps=n;const a=await this.tasks.update(t,e);Object.assign(t,a),s=this.normalizeSteps(t.steps);const c=await this.persistEvent(e,t.id,Re.UPDATE,{status:"update",currentStep:d,totalSteps:s.length,output:{added:i.length,insertionIndex:o}});this.bus.emit(c,e)}),await e.pipe([G.info,`Composite step ${i+1}/${s.length}: ${a.classification}`]);try{const r=await c.run(a.input,e);await e.flush();const l=new Date;n[d]=new Ls({status:Ie.SUCCEEDED,output:r,createdAt:l,updatedAt:l});const u=`${t.id}:step:${d}`;o(a.classification,r),o(u,r),i=d+1,t.stepResults=n,t.currentStep=i;const h=await this.tasks.update(t);Object.assign(t,h),await this.emitProgress(e,t.id,{currentStep:i,totalSteps:s.length,output:r})}catch(s){try{await(c.catch?.(a.input,s,e))}catch(t){r.logger.warn("composite step catch() hook failed",{error:t})}const o=new Date;n[i]=new Ls({status:Ie.FAILED,error:Js(s),createdAt:o,updatedAt:o}),t.stepResults=n,t.currentStep=i,t.error=Js(s);const l=await this.tasks.update(t);throw Object.assign(t,l),s}}return{stepResults:n}}normalizeBackoff(t){if(t instanceof Is)return t;let e=t??{};if("string"==typeof e)try{e=JSON.parse(e)}catch{e={}}return new Is(e)}normalizeSteps(t){if(!t)return[];let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{return[]}return e instanceof Set&&(e=Array.from(e)),Array.isArray(e)?e.map(t=>{if(t instanceof Ms)return t;let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{e={}}return new Ms(e)}):[]}normalizeStepResults(t){if(!t)return[];let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{return[]}return e instanceof Set&&(e=Array.from(e)),Array.isArray(e)?e.map(t=>{if(t instanceof Ls)return t;let e=t;if("string"==typeof e)try{e=JSON.parse(e)}catch{e={}}return new Ls(e)}):[]}async appendLog(t,e,r){const s=Array.isArray(r)&&Array.isArray(r[0]),i=e.atomicity===$e.COMPOSITE?t instanceof Zs?t.step??e.currentStep:e.currentStep:void 0,n=(s?r:[r]).map(([t,e,r])=>new $s({level:t,msg:e,meta:r,step:i})),o=[...e.logTail??[],...n].slice(-this.config.logTailMax);e.logTail=o;try{return[await this.tasks.update(e,t),n]}catch{return[e,[]]}}async emitStatus(t,e,r,s,i){t instanceof Zs&&await t.flush();const n={status:r};s&&s instanceof Bs?n.error=s:s&&(n.output=s),e.nextRunAt&&(n.nextRunAt=e.nextRunAt),e.scheduledTo&&(n.scheduledTo=e.scheduledTo);const o=await this.persistEvent(t,e.id,Re.STATUS,n),a=void 0!==i?Object.assign({},n,{originalError:i}):n,c=new Ps({...o,payload:a});this.bus.emit(c,t)}async emitLog(t,e,r){const s=await this.persistEvent(t,e,Re.LOG,r.map(t=>({ts:t.ts,level:t.level,msg:t.msg,meta:t.meta,step:t.step})));this.bus.emit(s,t)}normalizePipeArgs(t){if(!t.length)return[];if(1===t.length){const e=t[0];return Array.isArray(e)?0===e.length?[]:Array.isArray(e[0])?e.filter(Array.isArray):[e]:[]}const[e,r,s]=t;return"string"!=typeof e||"string"!=typeof r?[]:[[e,r,s]]}async emitProgress(t,e,r){const s=await this.persistEvent(t,e,Re.PROGRESS,r);this.bus.emit(s,t)}async persistEvent(t,e,r,s){const i=new Ps({taskId:e,classification:r,payload:s});return await this.events.create(i,t)}toString(){return`TaskEngine<${this.config.adapter.alias}>`}async context(t,e,...r){return this.adapter.context(t,e,Fs,...r)}}class ui extends Es{constructor(){super(Ps)}get repo(){return this._repository||(this._repository=hs.get(Fs).events),this._repository}}class di extends ps{get adapter(){return this.client.adapter}get tasks(){return this.client.tasks}get events(){return this.client.events}constructor(){super()}async initialize(...t){const e=t.shift();if(!e||e instanceof Rt)throw new u("No/invalid config provided");if(!e.adapter)throw new u("No adapter provided");return{client:new(e.engine||li)(e),config:e}}async push(t,e=!1,...r){const{ctxArgs:s}=(await this.logCtx(r,a.CREATE,!0)).for(this.push),i=await this.client.push(t,e,...s);return await this.client.isRunning()||this.client.start(),i}async track(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.CREATE,!0)).for(this.push);return this.client.track(t,...r)}select(t){return this.tasks.select(t)}async create(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.CREATE,!0)).for(this.create),s=await this.tasks.create(t,...r);return await this.client.isRunning()||this.client.start(),s}async createAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.CREATE_ALL,!0)).for(this.createAll),s=await this.tasks.createAll(t,...r);return await this.client.isRunning()||this.client.start(),s}async delete(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.DELETE,!0)).for(this.delete);return this.tasks.delete(t,...r)}async deleteAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.DELETE_ALL,!0)).for(this.deleteAll);return this.tasks.deleteAll(t,...r)}async read(t,...e){const{ctxArgs:r}=(await this.logCtx(e,a.READ,!0)).for(this.read);return this.tasks.read(t,...r)}async readAll(t,...e){const{ctxArgs:r}=(await this.logCtx(e,c.READ_ALL,!0)).for(this.readAll);return this.tasks.readAll(t,...r)}async query(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.QUERY,!0)).for(this.query),s=this.tasks?.[t];if("function"!=typeof s)throw new u(`Method "${t}" is not implemented`);return s.apply(this.tasks,r)}async update(t,...e){throw new Mt("Updates to tasks are not available")}async updateAll(t,...e){throw new Mt("Updates to tasks are not available")}async listBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.LIST_BY,!0)).for(this.listBy);return this.tasks.listBy(t,e,...s)}async paginateBy(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.PAGE_BY,!0)).for(this.paginateBy);return this.tasks.paginateBy(t,e,r,...i)}async findOneBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_ONE_BY,!0)).for(this.findOneBy);return this.tasks.findOneBy(t,e,...s)}async findBy(t,e,...r){const{ctxArgs:s}=(await this.logCtx(r,kt.FIND_BY,!0)).for(this.findBy);return this.tasks.findBy(t,e,...s)}async findByPaginate(t,e,r,...s){const{ctxArgs:i}=(await this.logCtx(s,kt.FIND_BY_PAGINATE,!0)).for(this.findByPaginate);return this.tasks.findByPaginate(t,e,r,...i)}async statement(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.STATEMENT,!0)).for(this.statement);return this.tasks.statement(t,...r)}refresh(t,e,r,...s){return this.tasks.refresh(t,e,r,...s)}observe(t,e){return this.tasks.observe(t,e)}unObserve(t){return this.tasks.unObserve(t)}updateObservers(t,e,r,...s){return this.tasks.updateObservers(t,e,r,...s)}logCtx(t,e,r=!1){const s=this.tasks._adapter.logCtx([this.tasks.class,...t],e,r,this.tasks._overrides||{});function i(t){return t.ctxArgs.shift(),t}return s instanceof Promise?s.then(i):i(s)}async shutdown(...t){const{ctxArgs:e,ctx:r,log:s}=(await this.logCtx(t,Ct.SHUTDOWN,!0)).for(this.shutdown);await super.shutdown(...e),s.info("attempting to gracefully shutdown task runner"),await this.client.stop(r),s.verbose("gracefully shutdown task runner")}}function hi(t={count:1},e=0){return function r(s,i,n){return gt(ft(dt.key(Ct.THROTTLE,i),t),(s,i,n)=>{n.value=new Proxy(n.value,{async apply(s,n,o){const a=o,c=(()=>{try{return"function"==typeof t?t(...a):t}catch(t){throw new u("Failed to obtain throttling configuration from handler: "+t)}})(),{log:l,ctx:d}=(await n.logCtx(o,Ct.THROTTLE,!0)).for(r),h=(t=>{const e=(Array.isArray(t)?t:[t]).map(t=>{if(!Number.isFinite(t)||0>t)throw new u("@throttling() argument indexes must be non-negative integers");return t});return Array.from(new Set(e)).sort((t,e)=>t-e)})(e);if(!h.length)throw new u("@throttling() expects at least one argument index to throttle");h.forEach(t=>{if(t>=a.length)throw new u(`@throttling() requires argument index ${t} but only ${a.length} provided`);if(!Array.isArray(a[t]))throw new u(`@throttling() expects argument at index ${t} to be an array`)});const p=h.map(t=>a[t]),g=p[0].length;if(!p.every(t=>t.length===g))throw new u("@throttling() requires all targeted arguments to have the same length");if(0===g)return s.apply(n,a);const f=((t,e,r)=>{if("count"in r){if(0>=r.count)throw new u("@throttling() configuration 'count' must be greater than zero");const e=[];for(let s=0;t>s;s+=r.count)e.push({start:s,end:Math.min(t,s+r.count)});return e}if("bufferSize"in r){if(0>=r.bufferSize)throw new u("@throttling() configuration 'bufferSize' must be greater than zero");const s=[];let i=0,n=0;for(let o=0;t>o;o++){const t=pi(e,o);n>0&&n+t>r.bufferSize?(s.push({start:i,end:o}),i=o,n=t):n+=t}return i>=t&&s.length||s.push({start:i,end:t}),s}return[{start:0,end:t}]})(g,p,c),y=f.map(({start:t,end:e})=>a.map((r,s)=>{const i=h.indexOf(s);return-1===i?r:p[i].slice(t,e)})),m=d.get("breakOnSingleFailureInBulk")??!0,w=[],v=[];for(const t of y){try{gi(await s.apply(n,t),w)}catch(t){if(m)throw t;v.push(t)}c.delayMs&&await new Promise(t=>setTimeout(t,c.delayMs))}if(v.length){l.warn(`${i+""} throttled execution continued with ${v.length} failure(s)`);const t=new AggregateError(v,`Throttled ${i+""} failed for ${v.length} chunk(s)`);throw t.results=w,t}return w}})})(s,i,n)}}function pi(t,e){return t.reduce((t,r)=>t+(t=>{if(null==t)return 0;try{return Buffer.byteLength(JSON.stringify(t))}catch{return 0}})(r[e]),0)}function gi(t,e){Array.isArray(t)?e.push(...t):void 0!==t&&e.push(t)}i([fs(),n("design:type",Function),n("design:paramtypes",[Fs,void 0]),n("design:returntype",Promise)],di.prototype,"create",null),i([fs(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"createAll",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],di.prototype,"delete",null),i([ws(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"deleteAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Object,void 0]),n("design:returntype",Promise)],di.prototype,"read",null),i([ys(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"readAll",null),i([ys(),n("design:type",Function),n("design:paramtypes",[String,void 0]),n("design:returntype",Promise)],di.prototype,"query",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Fs,void 0]),n("design:returntype",Promise)],di.prototype,"update",null),i([ms(),n("design:type",Function),n("design:paramtypes",[Array,void 0]),n("design:returntype",Promise)],di.prototype,"updateAll",null);const fi=Object.assign({},Nt,{persistMigrationSteps:!0});class yi{constructor(t="migration-task"){this.builder=(new Ys).setClassification("migration-composite").setName(t).setMaxAttempts(1)}addMigrationStep(t){return this.builder.addStep("migration",t),this}addStep(t,e){return this.builder.addStep(t,e),this}build(){return this.builder.build()}}class mi{isVersionHint(t){return!!t}normalize(t,e){return e&&t&&(t.includes(e)||t===e)?e:t||e||"migration"}compare(t,e){return t.localeCompare(e)}gt(t,e){return this.compare(t,e)>0}lte(t,e){return 0>=this.compare(t,e)}}class wi extends ps{constructor(){super(),this.versioning=new mi,this.queuedTaskChain=[],this.reference=wi.name,this.precedence=null}static async migrateAdapters(t,e={},...r){const s=e.flavours?.length?new Set(e.flavours):void 0,i=t.filter(t=>!s||s.has(t.alias)),n=new Set(t.map(t=>t.alias).filter(Boolean)),o=e.taskService?.client,a=o?.adapter?.alias||o?.adapter?.flavour;if(a&&n.has(a))throw new u(`TaskEngine adapter alias "${a}" cannot participate in the migration targets`);const c=[];for(const t of i){const s=t.alias,n=e.handlers?.[s]||e.handlers?.[t.flavour]||{},o=new wi;c.push(o),await o.boot({persistenceFlavour:s,targetVersion:e.toVersion,taskMode:!!e.taskMode,includeGenericInTaskMode:!(e.taskMode&&i.length>1),retrieveLastVersion:n.retrieveLastVersion,setCurrentVersion:n.setCurrentVersion,taskService:e.taskService}),e.taskMode?await o.migrateViaTasks(void 0,void 0,...r):await o.migrateNormally(void 0,void 0,...r)}return c}async initialize(...t){const{log:e,ctx:r}=(await this.logCtx(t,Ct.INITIALIZATION,!0)).for(this.initialize);try{hs.get(Ct.PERSISTENCE)}catch(t){r.get("ignoreDevSafeGuards")||e.warn("Persistence service not available. this may indicate poor initialization of the persistence layer (or not)")}const s=Object.assign({},t.length?t[0]:fi,fi);return this.versioning=s.versioning||new mi,this.transaction=s.persistMigrationSteps,{config:s,client:s.persistenceFlavour?re.get(s.persistenceFlavour):void 0}}async down(t,e,...r){const{log:s}=this.logCtx(r,this.down);s.verbose(Y("Cleaning up after all migrations").green.bold)}normalizeVersion(t,e){return this.versioning.normalize(t,e)}extractPrecedenceTokens(t){const e=t.precedence;return e?(Array.isArray(e)?e:[e]).map(t=>{if(t&&"string"!=typeof t)return"function"==typeof t?t.name:"string"==typeof t.reference?t.reference:t.constructor?.name?t.constructor.name:void 0}).filter(t=>!!t):[]}referencesMigration(t,e){const r=this.extractPrecedenceTokens(t);return!!r.length&&(r.includes(e.reference)||r.includes(e.migration?.constructor?.name))}precedenceHint(t){return"string"==typeof t.precedence?t.precedence:void 0}compareByPrecedence(t,e){const r=t.migration,s=e.migration,i=this.referencesMigration(r,e),n=this.referencesMigration(s,t);if(i&&!n)return 1;if(n&&!i)return-1;const o=this.extractPrecedenceTokens(r),a=this.extractPrecedenceTokens(s);return o.length!==a.length?o.length-a.length:0}sort(t){const e=[...t].sort((t,e)=>{const r=this.versioning.compare(t.version,e.version);if(0!==r)return r;const s=this.compareByPrecedence(t,e);if(0!==s)return s;const i=t.flavour.localeCompare(e.flavour);return 0!==i?i:t.reference.localeCompare(e.reference)});for(let t=0;t<e.length;t++){const r=e[t],s=e[t+1];if(r&&s&&r.version===s.version&&r.flavour===s.flavour&&0===this.compareByPrecedence(r,s))throw new u(`Unable to deterministically sort flavour migrations for version ${r.version} and flavour ${r.flavour}: ${r.reference} vs ${s.reference}`)}return e}resolveMigration(t){const e=dt.get(t.constructor,Ct.MIGRATION),r=e?.flavour||t.flavour||pt,s=e?.reference||t.reference,i=this.precedenceHint(t);return{migration:t,flavour:r,reference:s,version:this.normalizeVersion(s,i)}}shouldIncludeMigration(t,e,r=!0){return!e||t.flavour===e||r&&t.flavour===pt}collectMigrations(t,e=!0){const r=dt.migrations(),s=[];for(const[i,n]of r){let r;try{r=new n}catch(t){throw new u(`failed to create migration ${i}: ${t}`)}const o=this.resolveMigration(r);this.shouldIncludeMigration(o,t,e)&&s.push(o)}return s}buildExecutionPlan(t){const e=t?.fromVersion?this.normalizeVersion(t.fromVersion):void 0,r=t?.toVersion?this.normalizeVersion(t.toVersion):void 0;return this.sort(this.collectMigrations(t?.targetFlavour,t?.includeGeneric)).filter(t=>!(e&&!this.versioning.gt(t.version,e)||r&&!this.versioning.lte(t.version,r)))}async executeMigration(t,...e){const r=t.migration;let s,i;try{if(s=re.get(t.flavour),!s)throw new u(`failed to create migration ${r.reference}. did you call Service.boot() or use the Persistence Service??`);i=s.client}catch(t){throw new u(`Failed to load adapter to migrate ${r.reference}: ${t}`)}try{await r.up(i,s,...e)}catch(t){throw new jt(`failed to initialize migration ${r.reference}: ${t}`)}try{await r.migrate(i,s,...e)}catch(t){throw new jt(`failed to migrate ${r.reference}: ${t}`)}try{await r.down(i,s,...e)}catch(t){throw new jt(`failed to conclude migration ${r.reference}: ${t}`)}}buildMigrationTaskForPlan(t,...e){const r=[...e],s=new yi;return t.forEach(t=>{const e={reference:t.reference,args:r};s.addMigrationStep(e)}),s.build()}buildMigrationTasksForPlan(t,...e){const r=new Map;for(const e of t){const t=r.get(e.version)||[];t.push(e),r.set(e.version,t)}return[...r.entries()].map(([t,r])=>({version:t,task:this.buildMigrationTaskForPlan(r,...e)}))}createMigrationTask(t,e,...r){const s=this.config,i=!s.taskMode||(s.includeGenericInTaskMode??!0),n=this.buildExecutionPlan({toVersion:t||s.targetVersion,fromVersion:e,targetFlavour:s.persistenceFlavour,includeGeneric:i});return this.buildMigrationTaskForPlan(n,...r)}createMigrationTasks(t,e,...r){const s=this.config,i=!s.taskMode||(s.includeGenericInTaskMode??!0),n=this.buildExecutionPlan({toVersion:t||s.targetVersion,fromVersion:e,targetFlavour:s.persistenceFlavour,includeGeneric:i});return this.buildMigrationTasksForPlan(n,...r)}migrationTaskIdsFromContext(t,e){const r=e[e.length-1],s=r?.pending?.()||r?.pending||{},i=s?.[t];return Array.isArray(i)?i.filter(t=>"string"==typeof t):[]}async migrate(t,e,...r){this.config.taskMode?await this.migrateViaTasks(void 0,void 0,...r):await this.migrateNormally(void 0,void 0,...r)}async migrateNormally(t,e,...r){const{ctxArgs:s,log:i}=(await this.logCtx(r,Ct.MIGRATION,!0)).for(this.migrateNormally),n=this.config,o=n.persistenceFlavour,a=!n.taskMode||(n.includeGenericInTaskMode??!0),c=o?re.get(o):void 0;let l;if(n.retrieveLastVersion&&c){const t=await n.retrieveLastVersion(c,...s);t&&(l=this.normalizeVersion(t))}const u=this.buildExecutionPlan({fromVersion:l,toVersion:n.targetVersion,targetFlavour:o,includeGeneric:a});i.debug("sorted migration before execution: "+u.map(t=>`${t.reference}@${t.version}`));for(const t of u)await this.executeMigration(t,...s);if(n.setCurrentVersion&&c){const t=n.targetVersion||u[u.length-1]?.version||l||void 0;t&&await n.setCurrentVersion(this.normalizeVersion(t),c,...s)}}async migrateViaTasks(t,e,...r){const{ctx:s,ctxArgs:i,log:n}=(await this.logCtx(r,Ct.MIGRATION,!0)).for(this.migrateViaTasks),o=this.config,a=o.persistenceFlavour,c=o.includeGenericInTaskMode??!0,l=a?re.get(a):void 0;let u;if(o.retrieveLastVersion&&l){const t=await o.retrieveLastVersion(l,...i);t&&(u=this.normalizeVersion(t))}const d=this.buildExecutionPlan({fromVersion:u,toVersion:o.targetVersion,targetFlavour:a,includeGeneric:c});if(n.debug("sorted migration before execution: "+d.map(t=>`${t.reference}@${t.version}`)),this.queuedTaskChain=[],d.length){const t=this.buildMigrationTasksForPlan(d,...i);if(o.taskService){let e;for(const r of t){e&&(r.task.dependencies=[...r.task.dependencies||[],e]);const t=await o.taskService.push(r.task,!1,...i);e=t.id,this.queuedTaskChain.push({id:t.id,version:r.version}),t?.id||n.warn("TaskService.push returned missing id for version "+r.version),s.pushPending(Ct.MIGRATION,t.id)}}else{for(const t of d)await this.executeMigration(t,...i);if(o.setCurrentVersion&&l){const t=o.targetVersion||d[d.length-1]?.version||u||void 0;t&&await o.setCurrentVersion(this.normalizeVersion(t),l,...i)}}}}async track(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.MIGRATION,!0)).for(this.track),s=this.config;if(!s.taskService||!s.taskMode)return;const i="string"==typeof t?[t]:Array.isArray(t)?t:void 0,n=this.queuedTaskChain.map(t=>t.id),o=this.migrationTaskIdsFromContext(Ct.MIGRATION,r),a=i?.length?i:n.length?n:o;if(!a.length)return;const c=this.queuedTaskChain.reduce((t,e)=>(t[e.id]=e.version,t),{}),l=this.config.persistenceFlavour?re.get(this.config.persistenceFlavour):void 0;for(const t of a){const{tracker:e}=await s.taskService.track(t,...r);await e.wait(),s.setCurrentVersion&&l&&c[t]&&await s.setCurrentVersion(this.normalizeVersion(c[t]),l,...r)}}async retry(t,...e){const{ctxArgs:r}=(await this.logCtx(e,Ct.MIGRATION,!0)).for(this.retry),s=this.config;if(!s.taskMode||!s.taskService)return void await this.migrateNormally(void 0,void 0,...r);const i="string"==typeof t?[t]:Array.isArray(t)?t:void 0,n=this.queuedTaskChain.map(t=>t.id),o=this.migrationTaskIdsFromContext(Ct.MIGRATION,r),a=i?.length?i:n.length?n:o;if(!a.length)return void await this.migrateViaTasks(void 0,void 0,...r);const c=s.taskService.client.tasks,l="function"==typeof c?.override?c.override({ignoreHandlers:!0}):c;for(const t of a){const e=(await s.taskService.track(t,...r)).task;if(![Ie.FAILED,Ie.CANCELED].includes(e.status))continue;const i=new Fs({...e,status:Ie.PENDING,error:void 0,nextRunAt:void 0,scheduledTo:void 0,leaseOwner:void 0,leaseExpiry:void 0});await l.update(i,...r)}}async up(t,e,...r){const{log:s}=this.logCtx(r,this.down);s.verbose(Y("Setting up migration process").yellow.bold)}}const vi=dt.innerGet(Symbol.for(Ct.MIGRATION),pt)||[];function bi(t,e,r,s){return ht.for(Ct.MIGRATION).define({decorator:(e,r,s)=>i=>{const n=e&&"object"==typeof e&&!("name"in e)?e:void 0,o=n?.precedence,a=n?.flavour,c=n?.rules,l=n?o:e,u=n?a:r,d=n?c:s,h=n?void 0!==o:void 0!==l&&("string"!=typeof l||"string"==typeof l&&"string"==typeof u);let p,g,f=l;"string"==typeof l?"string"==typeof u?(f=l,p=u,g=d):Array.isArray(u)?(f=void 0,p=l,g=u):(f=void 0,p=l,g=d):Array.isArray(u)?g=u:(p=u,g=d),void 0===f&&null!==f&&(f=wi);const y=dt.flavourOf(i)||pt,m=(h&&f===wi&&t&&t!==p?t:p)||y,w=dt.innerGet(Symbol.for([Ct.MIGRATION,Ct.BY_KEY].join("-")),m||pt)||[];return dt.set([Ct.MIGRATION,Ct.BY_KEY].join("-"),m||pt,[...w,{class:i}]),dt.set(Ct.MIGRATION,t,i),vt(Ct.MIGRATION,{reference:t||i.name,precedence:f,flavour:m||pt,rules:g})(i)},args:[e,r,s]}).apply()}dt.set(Ct.MIGRATION,pt,[...vi,wi]);class Ai extends Ft{get reference(){if(!this._reference){const t=dt.get(this.constructor,Ct.MIGRATION);if(this._reference=t.reference,!this._reference)throw new u(`No precedence defined for ${this.constructor.name}. did you use @migration()?`)}return this._reference}get precedence(){if(void 0===this._precedence){const t=dt.get(this.constructor,Ct.MIGRATION);if(this._precedence=t.precedence,!this._precedence)throw new u(`No precedence defined for ${this.constructor.name}. did you use @migration()?`)}return this._precedence}constructor(){super(),this.transaction=!0,[this.up,this.down].forEach(t=>{const e=t.name;Qt(this,t,this.prefix(e))})}get adapter(){const t=dt.get(this.constructor,Ct.MIGRATION);if(!t)throw new u("No migration metadata for "+this.constructor.name);const e=t.flavour;return re.get(e)}async enforceRules(t,e,r){const s=dt.get(this.constructor,Ct.MIGRATION)?.rules;if(!s||!s.length)return!0;for(const i of s)if(!await i(t,e,r))return!1;return!0}prefix(t){return async function(e){let r;e instanceof re?r=this.getQueryRunner(e.client):(r=e,e=this.adapter);const{ctx:s,log:i}=await this.logCtx([t],Ct.MIGRATION,!0);if(!await this.enforceRules(r,e,s))throw i.verbose(`Skipping migration ${this.constructor.name} due to rules`),new Ut("Migration skipped for rule enforcement");return[r,e,s]}.bind(this)}}let Si=class extends zs{async run(t,e){e.logger.info("Executing migration "+t.reference);const r=dt.migrations().find(([,e])=>{const r=e?.name,s=dt.get(e,Ct.MIGRATION)?.reference;return r===t.reference||s===t.reference});if(!r)throw new u(`Migration ${t.reference} is not registered with the metadata layer`);const s=r[1];let i;try{i=new s}catch(e){throw new u(`Failed to instantiate migration ${t.reference}: ${e}`)}const n=dt.get(i.constructor,Ct.MIGRATION),o=n?.flavour||i.flavour,a=re.get(o);if(!a)throw new u("Unable to resolve adapter for migration "+t.reference);const c=a.client,l=t.args??[];try{await i.up(c,a,...l,e)}catch(r){throw e.logger.error(`Up phase for ${t.reference} failed: ${r}`),new jt(`Up phase for ${t.reference} failed: ${r}`)}try{await i.migrate(c,a,...l,e)}catch(r){throw e.logger.error(`migration phase for ${t.reference} failed: ${r}`),new jt(`Migration phase for ${t.reference} failed: ${r}`)}try{await i.down(c,a,...l,e)}catch(r){throw e.logger.error(`down phase for ${t.reference} failed: ${r}`),new jt(`Down phase for ${t.reference} failed: ${r}`)}e.logger.info(`migration ${t.reference} completed`)}};Si=i([qs("migration")],Si),e.setRegistry(new Me);const xi="##VERSION##",Ei="##PACKAGE##";dt.registerLibrary(Ei,xi);export{Ft as AbsContextual,Ai as AbsMigration,re as Adapter,Xt as AdapterTransaction,ze as AuthKeys,Nr as AuthorizationError,Be as BackoffStrategy,es as BaseModel,Je as BigIntSequence,ae as Cascade,Hs as CleanUpTask,ps as ClientBasedService,Ys as CompositeTaskBuilder,ne as Condition,_r as ConnectionError,Rt as Context,Kt as ContextLock,$t as ContextualLoggedClass,Nt as DefaultAdapterFlags,ce as DefaultCascade,Tt as DefaultContextFlags,fi as DefaultMigrationConfig,Ee as DefaultRepositoryFilters,Qe as DefaultSequenceOptions,Ue as DefaultTaskEngineConfig,Os as Dispatch,Dr as ForbiddenError,Ot as GroupOperator,Me as InjectablesRegistry,Pe as JitterStrategy,de as MethodQueryBuilder,jt as MigrationError,Ut as MigrationRuleError,wi as MigrationService,Si as MigrationTask,yi as MigrationTaskBuilder,Es as ModelService,Bt as MultipleSelectOperationKeys,_t as NonTransactionOperationKeys,Ve as NoneSequenceOptions,We as NumericSequence,Ye as ObserverError,Lt as ObserverHandler,Et as Operator,le as OperatorsMap,oe as OrderDirection,Ei as PACKAGE_NAME,Pt as PaginationOperationKeys,ss as Paginator,ie as PagingError,Ct as PersistenceKeys,_s as PersistenceService,kt as PreparedStatementKeys,xt as QueryClause,se as QueryError,Fe as Repository,It as SelectOperationKeys,Ts as Sequence,rs as SequenceModel,Jt as Serial,hs as Service,mi as StandardMigrationVersioning,ds as Statement,js as TaskBackoffBuilder,Is as TaskBackoffModel,Us as TaskBuilder,oi as TaskCancelError,Zs as TaskContext,si as TaskControlError,li as TaskEngine,Bs as TaskErrorModel,ei as TaskEventBus,Ps as TaskEventModel,ui as TaskEventService,Re as TaskEventType,ii as TaskFailError,zs as TaskHandler,ti as TaskHandlerRegistry,Rs as TaskIOSerializer,$s as TaskLogEntryModel,Vs as TaskLogger,Fs as TaskModel,ai as TaskRescheduleError,ni as TaskRetryError,di as TaskService,Ie as TaskStatus,Ls as TaskStepResultModel,Gs as TaskStepSpecBuilder,Ms as TaskStepSpecModel,ci as TaskTracker,$e as TaskType,je as TasksKey,Dt as TransactionOperationKeys,Wt as UUID,Mt as UnsupportedError,xi as VERSION,qe as allowIf,fe as applyViewDecorator,bs as auth,He as blockIf,Er as cacheModelForPopulate,kr as cascadeDelete,Br as column,Ws as computeBackoffMs,fs as create,or as createOrUpdate,Mr as createdAt,Fr as createdBy,$r as createdByOnCreateUpdate,he as defaultQueryAttr,ws as del,Le as generateInjectableNameForRepository,Ns as getAdapterTransaction,vr as getAndConstructJunctionTable,Ds as getContextLock,Oe as getFilters,Qs as getLogPipe,qr as getPkTypes,Sr as getPopulateKey,xr as getTagForDeleteKey,Xe as index,Gt as injectableServiceKey,Ht as isOperationBlocked,ri as isTaskError,Wr as manyToMany,mr as manyToManyOnCreate,Ar as manyToManyOnDelete,br as manyToManyOnUpdate,Qr as manyToOne,pr as manyToOneOnCreate,yr as manyToOneOnDelete,fr as manyToOneOnUpdate,bi as migration,Jr as noValidateOn,Xr as noValidateOnCreate,Zr as noValidateOnCreateUpdate,Kr as noValidateOnUpdate,Vt as normalizeImport,Vr as oneToMany,ur as oneToManyOnCreateUpdate,hr as oneToManyOnDelete,dr as oneToManyOnUpdate,Hr as oneToOne,ar as oneToOneOnCreate,lr as oneToOneOnDelete,cr as oneToOneOnUpdate,Se as onlyOnBulk,me as onlyOnCreate,ve as onlyOnDelete,xe as onlyOnFilter,Ae as onlyOnSingle,be as onlyOnTransactional,we as onlyOnUpdate,Yr as persistentVersion,ir as pk,rr as pkDec,tr as pkOnCreate,Or as populate,Qt as prefixMethod,pe as prepared,Yt as promiseSequence,ge as query,ys as read,ts as relation,Ge as repository,Tr as repositoryFromTypeMetadata,ee as resolveBulkSequenceResult,As as roles,Ss as route,nr as sequence,sr as sequenceDec,er as sequenceOnCreateUpdate,Js as serializeError,vs as service,Xs as sleep,Ir as table,qs as task,hi as throttle,Rr as unique,Pr as uniqueOnCreateUpdate,ms as update,jr as updatedAt,Lr as updatedBy,Cs as uuid,ks as uuidCreateUpdateHandler,gr as validBidirectionalRelation,zr as version,ye as view};
2
2
  //# sourceMappingURL=core.js.map