b23-lib 1.12.0 → 2.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (151) hide show
  1. package/README.md +0 -0
  2. package/dist/Auth/index.js +1 -1
  3. package/dist/Auth/index.js.map +1 -1
  4. package/dist/Auth/index.mjs +1 -1
  5. package/dist/Auth/index.mjs.map +1 -1
  6. package/dist/Classes/Address.d.mts +1 -1
  7. package/dist/Classes/Address.d.ts +1 -1
  8. package/dist/Classes/Address.js.map +1 -1
  9. package/dist/Classes/Address.mjs +1 -1
  10. package/dist/Classes/Base.d.mts +5 -5
  11. package/dist/Classes/Base.d.ts +5 -5
  12. package/dist/Classes/Base.js.map +1 -1
  13. package/dist/Classes/Base.mjs +1 -1
  14. package/dist/Classes/Cart.d.mts +27 -12
  15. package/dist/Classes/Cart.d.ts +27 -12
  16. package/dist/Classes/Cart.js +1 -1
  17. package/dist/Classes/Cart.js.map +1 -1
  18. package/dist/Classes/Cart.mjs +1 -1
  19. package/dist/Classes/Cart.mjs.map +1 -1
  20. package/dist/Classes/Common.d.mts +2 -93
  21. package/dist/Classes/Common.d.ts +2 -93
  22. package/dist/Classes/Coupon.d.mts +33 -15
  23. package/dist/Classes/Coupon.d.ts +33 -15
  24. package/dist/Classes/Coupon.js +1 -1
  25. package/dist/Classes/Coupon.js.map +1 -1
  26. package/dist/Classes/Coupon.mjs +1 -1
  27. package/dist/Classes/Customer.d.mts +2 -2
  28. package/dist/Classes/Customer.d.ts +2 -2
  29. package/dist/Classes/Customer.js.map +1 -1
  30. package/dist/Classes/Customer.mjs +1 -1
  31. package/dist/Classes/Customer.mjs.map +1 -1
  32. package/dist/Classes/CustomerAddress.d.mts +1 -1
  33. package/dist/Classes/CustomerAddress.d.ts +1 -1
  34. package/dist/Classes/CustomerAddress.js.map +1 -1
  35. package/dist/Classes/CustomerAddress.mjs +1 -1
  36. package/dist/Classes/Enum.d.mts +43 -2
  37. package/dist/Classes/Enum.d.ts +43 -2
  38. package/dist/Classes/Enum.js +1 -1
  39. package/dist/Classes/Enum.js.map +1 -1
  40. package/dist/Classes/Enum.mjs +1 -1
  41. package/dist/Classes/Error.d.mts +59 -0
  42. package/dist/Classes/Error.d.ts +59 -0
  43. package/dist/Classes/Error.js +2 -0
  44. package/dist/Classes/Error.js.map +1 -0
  45. package/dist/Classes/Error.mjs +2 -0
  46. package/dist/Classes/Error.mjs.map +1 -0
  47. package/dist/Classes/ImageInfo.js +1 -1
  48. package/dist/Classes/ImageInfo.js.map +1 -1
  49. package/dist/Classes/ImageInfo.mjs +1 -1
  50. package/dist/Classes/Inventory.d.mts +25 -6
  51. package/dist/Classes/Inventory.d.ts +25 -6
  52. package/dist/Classes/Inventory.js +1 -1
  53. package/dist/Classes/Inventory.js.map +1 -1
  54. package/dist/Classes/Inventory.mjs +1 -1
  55. package/dist/Classes/Inventory.mjs.map +1 -1
  56. package/dist/Classes/LineItem.d.mts +140 -58
  57. package/dist/Classes/LineItem.d.ts +140 -58
  58. package/dist/Classes/LineItem.js +1 -1
  59. package/dist/Classes/LineItem.js.map +1 -1
  60. package/dist/Classes/LineItem.mjs +1 -1
  61. package/dist/Classes/Order.d.mts +7 -51
  62. package/dist/Classes/Order.d.ts +7 -51
  63. package/dist/Classes/Order.js +1 -1
  64. package/dist/Classes/Order.js.map +1 -1
  65. package/dist/Classes/Order.mjs +1 -1
  66. package/dist/Classes/Order.mjs.map +1 -1
  67. package/dist/Classes/Payment.d.mts +4 -4
  68. package/dist/Classes/Payment.d.ts +4 -4
  69. package/dist/Classes/Payment.js.map +1 -1
  70. package/dist/Classes/Payment.mjs +1 -1
  71. package/dist/Classes/Payment.mjs.map +1 -1
  72. package/dist/Classes/Price.d.mts +1 -82
  73. package/dist/Classes/Price.d.ts +1 -82
  74. package/dist/Classes/Price.js +1 -1
  75. package/dist/Classes/Price.js.map +1 -1
  76. package/dist/Classes/Price.mjs +1 -1
  77. package/dist/Classes/Product.d.mts +103 -85
  78. package/dist/Classes/Product.d.ts +103 -85
  79. package/dist/Classes/Product.js +1 -1
  80. package/dist/Classes/Product.js.map +1 -1
  81. package/dist/Classes/Product.mjs +1 -1
  82. package/dist/Classes/Product.mjs.map +1 -1
  83. package/dist/Classes/ShoppingContainer.d.mts +79 -63
  84. package/dist/Classes/ShoppingContainer.d.ts +79 -63
  85. package/dist/Classes/ShoppingContainer.js +1 -1
  86. package/dist/Classes/ShoppingContainer.js.map +1 -1
  87. package/dist/Classes/ShoppingContainer.mjs +1 -1
  88. package/dist/Classes/TaxRule.d.mts +63 -0
  89. package/dist/Classes/TaxRule.d.ts +63 -0
  90. package/dist/Classes/TaxRule.js +2 -0
  91. package/dist/Classes/TaxRule.js.map +1 -0
  92. package/dist/Classes/TaxRule.mjs +2 -0
  93. package/dist/Classes/TaxRule.mjs.map +1 -0
  94. package/dist/Classes/TieredPrice.d.mts +75 -0
  95. package/dist/Classes/TieredPrice.d.ts +75 -0
  96. package/dist/Classes/TieredPrice.js +2 -0
  97. package/dist/Classes/TieredPrice.js.map +1 -0
  98. package/dist/Classes/TieredPrice.mjs +2 -0
  99. package/dist/Classes/TieredPrice.mjs.map +1 -0
  100. package/dist/Common-D-UoxwM0.d.ts +210 -0
  101. package/dist/Common-FbQ5-3QN.d.mts +210 -0
  102. package/dist/chunk-2SGUPNWZ.mjs +2 -0
  103. package/dist/chunk-2SGUPNWZ.mjs.map +1 -0
  104. package/dist/chunk-54RUAXYE.mjs +2 -0
  105. package/dist/chunk-54RUAXYE.mjs.map +1 -0
  106. package/dist/{chunk-ATUUYYQT.mjs → chunk-55SOBG62.mjs} +2 -2
  107. package/dist/chunk-55SOBG62.mjs.map +1 -0
  108. package/dist/{chunk-H5GPM4LA.mjs → chunk-5KD2EW7O.mjs} +2 -2
  109. package/dist/{chunk-H5GPM4LA.mjs.map → chunk-5KD2EW7O.mjs.map} +1 -1
  110. package/dist/chunk-72DR3HF2.mjs +2 -0
  111. package/dist/chunk-72DR3HF2.mjs.map +1 -0
  112. package/dist/chunk-AMIRIUMH.mjs +2 -0
  113. package/dist/chunk-AMIRIUMH.mjs.map +1 -0
  114. package/dist/chunk-CEGQFFYZ.mjs +2 -0
  115. package/dist/chunk-CEGQFFYZ.mjs.map +1 -0
  116. package/dist/chunk-EP7WVZXC.mjs +2 -0
  117. package/dist/chunk-EP7WVZXC.mjs.map +1 -0
  118. package/dist/chunk-KWH7GE23.mjs +2 -0
  119. package/dist/chunk-KWH7GE23.mjs.map +1 -0
  120. package/dist/chunk-LNIZAPER.mjs +2 -0
  121. package/dist/chunk-LNIZAPER.mjs.map +1 -0
  122. package/dist/chunk-NJKSUUOB.mjs +2 -0
  123. package/dist/chunk-NJKSUUOB.mjs.map +1 -0
  124. package/dist/chunk-NUTKOIGY.mjs +2 -0
  125. package/dist/chunk-NUTKOIGY.mjs.map +1 -0
  126. package/dist/chunk-RBROVHJ4.mjs +2 -0
  127. package/dist/chunk-RBROVHJ4.mjs.map +1 -0
  128. package/dist/index.d.mts +9 -6
  129. package/dist/index.d.ts +9 -6
  130. package/dist/index.js +2 -2
  131. package/dist/index.js.map +1 -1
  132. package/dist/index.mjs +2 -2
  133. package/dist/index.mjs.map +1 -1
  134. package/package.json +35 -4
  135. package/dist/chunk-6PDP4ETM.mjs +0 -2
  136. package/dist/chunk-6PDP4ETM.mjs.map +0 -1
  137. package/dist/chunk-ATUUYYQT.mjs.map +0 -1
  138. package/dist/chunk-CKUUUEWT.mjs +0 -2
  139. package/dist/chunk-CKUUUEWT.mjs.map +0 -1
  140. package/dist/chunk-DKI6BDWK.mjs +0 -2
  141. package/dist/chunk-DKI6BDWK.mjs.map +0 -1
  142. package/dist/chunk-K3AXPTGG.mjs +0 -2
  143. package/dist/chunk-K3AXPTGG.mjs.map +0 -1
  144. package/dist/chunk-LMMJSJTO.mjs +0 -2
  145. package/dist/chunk-LMMJSJTO.mjs.map +0 -1
  146. package/dist/chunk-RWBNLNQ6.mjs +0 -2
  147. package/dist/chunk-RWBNLNQ6.mjs.map +0 -1
  148. package/dist/chunk-V4H3X4PI.mjs +0 -2
  149. package/dist/chunk-V4H3X4PI.mjs.map +0 -1
  150. package/dist/chunk-WOMA746Z.mjs +0 -2
  151. package/dist/chunk-WOMA746Z.mjs.map +0 -1
@@ -1,2 +1,2 @@
1
- import {b,c as c$1,a as a$1,e,d}from'../chunk-CKUUUEWT.mjs';import {importPKCS8,SignJWT,importSPKI,jwtVerify,decodeJwt}from'jose';import a from'assert';var c=class l{static instance=null;id;type;token;initializedAt;lambdaName;requestId;constructor(e,t,i,s){this.id=e,this.type=t,this.token=i,this.lambdaName=process.env.AWS_LAMBDA_FUNCTION_NAME,this.initializedAt=new Date;}static getInstance(){return a(l.instance,b.AUTH_CONTEXT_NOT_INITIALIZED),l.instance}static init(e,t,i,s){return l.instance=new l(e,t,i,s),l.instance}static uninit(){l.instance=null;}getId(){return this.id}getType(){return this.type}getToken(){return this.token}getLambdaName(){return this.lambdaName}getRequestId(){return this.requestId}getInitializedAt(){return this.initializedAt}getSystemID(e){let t=this.lambdaName||e;return this.requestId?`${t} - ${this.requestId}`:t}};var K={userTokenAge:"30 days",userPrivateKeys:"[]",userPublicKeys:"[]",anonymousTokenAge:"30 days",anonymousPrivateKeys:"[]",anonymousPublicKeys:"[]",systemTokenAge:"5 min",systemPrivateKeys:"[]",systemPublicKeys:"[]",adminTokenAge:"30 days",adminPrivateKeys:"[]",adminPublicKeys:"[]",cdnKeys:"[]"},U=(n=>(n.ANON="Anon",n.USER="User",n.SYSTEM="System",n.ADMIN="Admin",n.CDN="CDN",n))(U||{}),v={allowAnonymous:!1,allowSystem:!0,allowUser:!0,allowCDN:!1},N=class{userTokenAge;userPrivateKeys;userPublicKeys;anonymousTokenAge;anonymousPrivateKeys;anonymousPublicKeys;systemTokenAge;systemPrivateKeys;systemPublicKeys;adminTokenAge;adminPrivateKeys;adminPublicKeys;cdnKeys;constructor(e=K){let{userTokenAge:t,userPrivateKeys:i,userPublicKeys:s,anonymousTokenAge:n,anonymousPrivateKeys:g,anonymousPublicKeys:h,systemTokenAge:m,systemPrivateKeys:T,systemPublicKeys:A,adminTokenAge:u,adminPrivateKeys:d,adminPublicKeys:S,cdnKeys:f}={...K,...e};this.userTokenAge=t,this.userPrivateKeys=this.parseKeyArray(i,"user private"),this.userPublicKeys=this.parseKeyArray(s,"user public"),this.anonymousTokenAge=n,this.anonymousPrivateKeys=this.parseKeyArray(g,"anonymous private"),this.anonymousPublicKeys=this.parseKeyArray(h,"anonymous public"),this.systemTokenAge=m,this.systemPrivateKeys=this.parseKeyArray(T,"system private"),this.systemPublicKeys=this.parseKeyArray(A,"system public"),this.adminTokenAge=u,this.adminPrivateKeys=this.parseKeyArray(d,"admin private"),this.adminPublicKeys=this.parseKeyArray(S,"admin public"),this.cdnKeys=this.parseKeyArray(f,"cdn"),this.logWarnings();}parseKeyArray(e,t){try{let i=JSON.parse(e);return !Array.isArray(i)||!i.every(s=>typeof s=="string")?(c$1.logError("AuthUtility",`Invalid format for ${t} keys in config: Expected stringified array of strings.`),[]):i}catch(i){return c$1.logError("AuthUtility",`Failed to parse ${t} keys from config: ${i}`),[]}}logWarnings(){let e=(t,i,s)=>i.length>s&&c$1.logWarning("AuthUtility",`More than ${s} ${t} keys provided. This is not recommended.`);e("user private",this.userPrivateKeys,3),e("user public",this.userPublicKeys,3),e("anonymous private",this.anonymousPrivateKeys,1),e("anonymous public",this.anonymousPublicKeys,3),e("system private",this.systemPrivateKeys,1),e("system public",this.systemPublicKeys,3),e("admin private",this.adminPrivateKeys,1),e("admin public",this.adminPublicKeys,3);}async createSignedJWT(e,t,i){let s=await importPKCS8(t,"RS256");return await new SignJWT(e).setProtectedHeader({alg:"RS256"}).setExpirationTime(i).setIssuedAt().sign(s)}async verifySignedJWT(e,t,i){for(let s=t.length-1;s>=0;s--)try{let n=await importSPKI(t[s],"RS256");return (await jwtVerify(e,n,{clockTolerance:30,maxTokenAge:i})).payload}catch(n){if(s===0)throw n;continue}throw new Error(b.INVALID_TOKEN)}async createAnonymousToken(e,t){a(this.anonymousPrivateKeys.length,b.ANONYMOUS_PRIVATE_KEY_NOT_FOUND),a(a$1.isUUID(e),b.INVALID_UUID);let i={id:e,type:"Anon",...t};return await this.createSignedJWT(i,this.anonymousPrivateKeys[this.anonymousPrivateKeys.length-1],this.anonymousTokenAge)}async verifyAnonymousToken(e){a(this.anonymousPublicKeys.length,b.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.anonymousPublicKeys,this.anonymousTokenAge);return a(t.type==="Anon",b.INVALID_AUTH_TYPE),t}async createUserToken(e,t){a(this.userPrivateKeys.length,b.USER_PRIVATE_KEY_NOT_FOUND),a(a$1.isUUID(e),b.INVALID_UUID);let i={id:e,type:"User",...t};return await this.createSignedJWT(i,this.userPrivateKeys[this.userPrivateKeys.length-1],this.userTokenAge)}async verifyUserToken(e){a(this.userPublicKeys.length,b.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.userPublicKeys,this.userTokenAge);return a(t.type==="User",b.INVALID_AUTH_TYPE),t}async createSystemToken(e,t){a(this.systemPrivateKeys.length,b.SYSTEM_PRIVATE_KEY_NOT_FOUND);let i={id:e,type:"System",...t};return await this.createSignedJWT(i,this.systemPrivateKeys[this.systemPrivateKeys.length-1],this.systemTokenAge)}async verifySystemToken(e){a(this.systemPublicKeys.length,b.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.systemPublicKeys,this.systemTokenAge);return a(t.type==="System",b.INVALID_AUTH_TYPE),t}async createAdminToken(e,t,i){a(this.adminPrivateKeys.length,b.ADMIN_PRIVATE_KEY_NOT_FOUND),a(a$1.isEmail(e),b.INVALID_EMAIL),a(a$1.isURL(t),b.INVALID_VERIFIER);let s={id:e,type:"Admin",verifier:t,...i};return await this.createSignedJWT(s,this.adminPrivateKeys[this.adminPrivateKeys.length-1],this.adminTokenAge)}async verifyAdminToken(e$1,t,i){a(this.adminPublicKeys.length,b.ADMIN_PUBLIC_KEY_NOT_FOUND);let s=await this.verifySignedJWT(e$1,this.adminPublicKeys,this.adminTokenAge);if(a(s.type==="Admin",b.INVALID_AUTH_TYPE),i){let n=await e(s.verifier,"","POST",{},{token:e$1,permissions:t});if(a(n.data.isTokenValid===!0,b.INVALID_TOKEN),n.data.hasPermissions!==!0)throw d.generateError(403,b.INVALID_PERMISSIONS)}return s}async verifyCDNToken(e){return a(this.cdnKeys.includes(e),b.INVALID_TOKEN),{id:e,type:"CDN"}}AuthMiddleware(e=v,t=[]){let{allowAnonymous:i,allowSystem:s,allowUser:n,allowCDN:g}={...v,...e};return async(h,m,T)=>{try{let[A,u]=h.get("Authorization")?.split(" ")||[];if(!u)throw new Error(b.INVALID_TOKEN);let d$1;switch(A){case"Anon":if(!i)throw d.generateError(403,b.ANONYMOUS_SESSION_NOT_ALLOWED);d$1=await this.verifyAnonymousToken(u);break;case"User":if(!n)throw d.generateError(403,b.USER_SESSION_NOT_ALLOWED);d$1=await this.verifyUserToken(u);break;case"System":if(!s)throw d.generateError(403,b.SYSTEM_SESSION_NOT_ALLOWED);d$1=await this.verifySystemToken(u);break;case"Admin":d$1=await this.verifyAdminToken(u,t,!0);break;case"CDN":if(!g)throw d.generateError(403,b.CDN_SESSION_NOT_ALLOWED);d$1=await this.verifyCDNToken(u);break;default:throw d.generateError(403,b.INVALID_AUTH_TYPE)}T();}catch(A){c$1.logError("AuthMiddleware",A),d.handleException("AuthMiddleware",d.generateError(401,A.error||b.TOKEN_EXPIRED,!0),m);}}}decodeJWTPayloadWithJose(e){if(!e||typeof e!="string")return c$1.logError("AuthContextMiddleware","Invalid token provided for decoding."),null;try{return decodeJwt(e)}catch(t){return c$1.logError("AuthContextMiddleware",`Failed to decode JWT payload: ${t}`),null}}AuthContextMiddleware(){return async(e,t,i)=>{try{let[s,n]=e.get("Authorization")?.split(" ")||[],g=s==="CDN"?{id:n,type:"CDN"}:this.decodeJWTPayloadWithJose(n),h=c.init(g?.id||n,g?.type||s,n,e.get("x-request-id"));c$1.logMessage("AuthContextMiddleware",`AuthContext initialized: ${h.getType()||"No-Type"} - ${h.getId()||"No-Id"}`),t.on("finish",()=>{c$1.logMessage("AuthContextMiddleware","Uninitializing AuthContext"),c.uninit();}),i();}catch(s){c$1.logError("AuthContextMiddleware",s),d.handleException("AuthContextMiddleware",d.generateError(500,s.error||b.INTERNAL_SERVER_ERROR,!0),t);}}}},j=N;export{c as AuthContext,U as AuthType,v as DefaultAuthMiddlewareConfig,K as DefaultAuthUtilityConfig,j as default};//# sourceMappingURL=index.mjs.map
1
+ import {a as a$1,b,d,c as c$1}from'../chunk-AMIRIUMH.mjs';import {a as a$2}from'../chunk-LNIZAPER.mjs';import'../chunk-KWH7GE23.mjs';import'../chunk-54RUAXYE.mjs';import'../chunk-72DR3HF2.mjs';import'../chunk-NUTKOIGY.mjs';import'../chunk-NJKSUUOB.mjs';import'../chunk-55SOBG62.mjs';import {importPKCS8,SignJWT,importSPKI,jwtVerify,decodeJwt}from'jose';import a from'assert';var c=class l{static instance=null;id;type;token;initializedAt;lambdaName;requestId;constructor(e,t,i,r){this.id=e,this.type=t,this.token=i,this.lambdaName=process.env.AWS_LAMBDA_FUNCTION_NAME,this.initializedAt=new Date;}static getInstance(){return a(l.instance,a$1.AUTH_CONTEXT_NOT_INITIALIZED),l.instance}static init(e,t,i,r){return l.instance=new l(e,t,i,r),l.instance}static uninit(){l.instance=null;}getId(){return this.id}getType(){return this.type}getToken(){return this.token}getLambdaName(){return this.lambdaName}getRequestId(){return this.requestId}getInitializedAt(){return this.initializedAt}getSystemID(e){let t=this.lambdaName||e;return this.requestId?`${t} - ${this.requestId}`:t}};var K={userTokenAge:"30 days",userPrivateKeys:"[]",userPublicKeys:"[]",anonymousTokenAge:"30 days",anonymousPrivateKeys:"[]",anonymousPublicKeys:"[]",systemTokenAge:"5 min",systemPrivateKeys:"[]",systemPublicKeys:"[]",adminTokenAge:"30 days",adminPrivateKeys:"[]",adminPublicKeys:"[]",cdnKeys:"[]"},U=(n=>(n.ANON="Anon",n.USER="User",n.SYSTEM="System",n.ADMIN="Admin",n.CDN="CDN",n))(U||{}),v={allowAnonymous:!1,allowSystem:!0,allowUser:!0,allowCDN:!1},N=class{userTokenAge;userPrivateKeys;userPublicKeys;anonymousTokenAge;anonymousPrivateKeys;anonymousPublicKeys;systemTokenAge;systemPrivateKeys;systemPublicKeys;adminTokenAge;adminPrivateKeys;adminPublicKeys;cdnKeys;constructor(e=K){let{userTokenAge:t,userPrivateKeys:i,userPublicKeys:r,anonymousTokenAge:n,anonymousPrivateKeys:g,anonymousPublicKeys:h,systemTokenAge:m,systemPrivateKeys:T,systemPublicKeys:A,adminTokenAge:u,adminPrivateKeys:d,adminPublicKeys:S,cdnKeys:f}={...K,...e};this.userTokenAge=t,this.userPrivateKeys=this.parseKeyArray(i,"user private"),this.userPublicKeys=this.parseKeyArray(r,"user public"),this.anonymousTokenAge=n,this.anonymousPrivateKeys=this.parseKeyArray(g,"anonymous private"),this.anonymousPublicKeys=this.parseKeyArray(h,"anonymous public"),this.systemTokenAge=m,this.systemPrivateKeys=this.parseKeyArray(T,"system private"),this.systemPublicKeys=this.parseKeyArray(A,"system public"),this.adminTokenAge=u,this.adminPrivateKeys=this.parseKeyArray(d,"admin private"),this.adminPublicKeys=this.parseKeyArray(S,"admin public"),this.cdnKeys=this.parseKeyArray(f,"cdn"),this.logWarnings();}parseKeyArray(e,t){try{let i=JSON.parse(e);return !Array.isArray(i)||!i.every(r=>typeof r=="string")?(b.logError("AuthUtility",`Invalid format for ${t} keys in config: Expected stringified array of strings.`),[]):i}catch(i){return b.logError("AuthUtility",`Failed to parse ${t} keys from config: ${i}`),[]}}logWarnings(){let e=(t,i,r)=>i.length>r&&b.logWarning("AuthUtility",`More than ${r} ${t} keys provided. This is not recommended.`);e("user private",this.userPrivateKeys,3),e("user public",this.userPublicKeys,3),e("anonymous private",this.anonymousPrivateKeys,1),e("anonymous public",this.anonymousPublicKeys,3),e("system private",this.systemPrivateKeys,1),e("system public",this.systemPublicKeys,3),e("admin private",this.adminPrivateKeys,1),e("admin public",this.adminPublicKeys,3);}async createSignedJWT(e,t,i){let r=await importPKCS8(t,"RS256");return await new SignJWT(e).setProtectedHeader({alg:"RS256"}).setExpirationTime(i).setIssuedAt().sign(r)}async verifySignedJWT(e,t,i){for(let r=t.length-1;r>=0;r--)try{let n=await importSPKI(t[r],"RS256");return (await jwtVerify(e,n,{clockTolerance:30,maxTokenAge:i})).payload}catch(n){if(r===0)throw n;continue}throw new Error(a$1.INVALID_TOKEN)}async createAnonymousToken(e,t){a(this.anonymousPrivateKeys.length,a$1.ANONYMOUS_PRIVATE_KEY_NOT_FOUND),a(a$2.isUUID(e),a$1.INVALID_UUID);let i={id:e,type:"Anon",...t};return await this.createSignedJWT(i,this.anonymousPrivateKeys[this.anonymousPrivateKeys.length-1],this.anonymousTokenAge)}async verifyAnonymousToken(e){a(this.anonymousPublicKeys.length,a$1.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.anonymousPublicKeys,this.anonymousTokenAge);return a(t.type==="Anon",a$1.INVALID_AUTH_TYPE),t}async createUserToken(e,t){a(this.userPrivateKeys.length,a$1.USER_PRIVATE_KEY_NOT_FOUND),a(a$2.isUUID(e),a$1.INVALID_UUID);let i={id:e,type:"User",...t};return await this.createSignedJWT(i,this.userPrivateKeys[this.userPrivateKeys.length-1],this.userTokenAge)}async verifyUserToken(e){a(this.userPublicKeys.length,a$1.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.userPublicKeys,this.userTokenAge);return a(t.type==="User",a$1.INVALID_AUTH_TYPE),t}async createSystemToken(e,t){a(this.systemPrivateKeys.length,a$1.SYSTEM_PRIVATE_KEY_NOT_FOUND);let i={id:e,type:"System",...t};return await this.createSignedJWT(i,this.systemPrivateKeys[this.systemPrivateKeys.length-1],this.systemTokenAge)}async verifySystemToken(e){a(this.systemPublicKeys.length,a$1.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.systemPublicKeys,this.systemTokenAge);return a(t.type==="System",a$1.INVALID_AUTH_TYPE),t}async createAdminToken(e,t,i){a(this.adminPrivateKeys.length,a$1.ADMIN_PRIVATE_KEY_NOT_FOUND),a(a$2.isEmail(e),a$1.INVALID_EMAIL),a(a$2.isURL(t),a$1.INVALID_VERIFIER);let r={id:e,type:"Admin",verifier:t,...i};return await this.createSignedJWT(r,this.adminPrivateKeys[this.adminPrivateKeys.length-1],this.adminTokenAge)}async verifyAdminToken(e,t,i){a(this.adminPublicKeys.length,a$1.ADMIN_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(e,this.adminPublicKeys,this.adminTokenAge);if(a(r.type==="Admin",a$1.INVALID_AUTH_TYPE),i){let n=await d(r.verifier,"","POST",{},{token:e,permissions:t});if(a(n.data.isTokenValid===!0,a$1.INVALID_TOKEN),n.data.hasPermissions!==!0)throw c$1.generateError(403,a$1.INVALID_PERMISSIONS)}return r}async verifyCDNToken(e){return a(this.cdnKeys.includes(e),a$1.INVALID_TOKEN),{id:e,type:"CDN"}}AuthMiddleware(e=v,t=[]){let{allowAnonymous:i,allowSystem:r,allowUser:n,allowCDN:g}={...v,...e};return async(h,m,T)=>{try{let[A,u]=h.get("Authorization")?.split(" ")||[];if(!u)throw new Error(a$1.INVALID_TOKEN);let d;switch(A){case"Anon":if(!i)throw c$1.generateError(403,a$1.ANONYMOUS_SESSION_NOT_ALLOWED);d=await this.verifyAnonymousToken(u);break;case"User":if(!n)throw c$1.generateError(403,a$1.USER_SESSION_NOT_ALLOWED);d=await this.verifyUserToken(u);break;case"System":if(!r)throw c$1.generateError(403,a$1.SYSTEM_SESSION_NOT_ALLOWED);d=await this.verifySystemToken(u);break;case"Admin":d=await this.verifyAdminToken(u,t,!0);break;case"CDN":if(!g)throw c$1.generateError(403,a$1.CDN_SESSION_NOT_ALLOWED);d=await this.verifyCDNToken(u);break;default:throw c$1.generateError(403,a$1.INVALID_AUTH_TYPE)}T();}catch(A){b.logError("AuthMiddleware",A),c$1.handleException("AuthMiddleware",c$1.generateError(401,A.error||a$1.TOKEN_EXPIRED,!0),m);}}}decodeJWTPayloadWithJose(e){if(!e||typeof e!="string")return b.logError("AuthContextMiddleware","Invalid token provided for decoding."),null;try{return decodeJwt(e)}catch(t){return b.logError("AuthContextMiddleware",`Failed to decode JWT payload: ${t}`),null}}AuthContextMiddleware(){return async(e,t,i)=>{try{let[r,n]=e.get("Authorization")?.split(" ")||[],g=r==="CDN"?{id:n,type:"CDN"}:r?this.decodeJWTPayloadWithJose(n):{},h=c.init(g?.id||n,g?.type||r,n,e.get("x-request-id"));b.logMessage("AuthContextMiddleware",`AuthContext initialized: ${h.getType()||"No-Type"} - ${h.getId()||"No-Id"}`),t.on("finish",()=>{b.logMessage("AuthContextMiddleware","Uninitializing AuthContext"),c.uninit();}),i();}catch(r){b.logError("AuthContextMiddleware",r),c$1.handleException("AuthContextMiddleware",c$1.generateError(500,r.error||a$1.INTERNAL_SERVER_ERROR,!0),t);}}}},j=N;export{c as AuthContext,U as AuthType,v as DefaultAuthMiddlewareConfig,K as DefaultAuthUtilityConfig,j as default};//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Auth/AuthContext.ts","../../src/Auth/index.ts"],"names":["AuthContext","_AuthContext","id","type","token","requestId","assert","ErrorTypes_default","fallbackLambdaName","baseId","DefaultAuthUtilityConfig","AuthType","DefaultAuthMiddlewareConfig","AuthUtility","config","userTokenAge","userPrivateKeys","userPublicKeys","anonymousTokenAge","anonymousPrivateKeys","anonymousPublicKeys","systemTokenAge","systemPrivateKeys","systemPublicKeys","adminTokenAge","adminPrivateKeys","adminPublicKeys","cdnKeys","jsonString","keyType","parsed","item","Logger_default","error","warn","keys","limit","payload","privateKeyString","expiration","privateKey","importPKCS8","SignJWT","publicKeyString","i","publicKey","importSPKI","jwtVerify","additionalData","Utils_default","email","verifier","permissions","authenticate","response","fetch_default","response_default","allowAnonymous","allowSystem","allowUser","allowCDN","req","res","next","authType","decodeJwt","authContext","Auth_default"],"mappings":"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","file":"index.mjs","sourcesContent":["import assert from \"assert\";\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport { AuthType } from \"./index\";\r\n\r\nexport default class AuthContext {\r\n private static instance: AuthContext | null = null;\r\n private id: string;\r\n private type: AuthType;\r\n private token?: string;\r\n private initializedAt: Date;\r\n private lambdaName?: string;\r\n private requestId?: string;\r\n\r\n private constructor(id: string, type: AuthType, token: string, requestId: string) {\r\n this.id = id;\r\n this.type = type;\r\n this.token = token;\r\n this.lambdaName = process.env.AWS_LAMBDA_FUNCTION_NAME;\r\n this.initializedAt = new Date();\r\n }\r\n\r\n public static getInstance(): AuthContext {\r\n assert(AuthContext.instance, ErrorTypes.AUTH_CONTEXT_NOT_INITIALIZED);\r\n return AuthContext.instance;\r\n }\r\n\r\n public static init(id: string, type: AuthType, token: string, requestId: string): AuthContext {\r\n AuthContext.instance = new AuthContext(id, type, token, requestId);\r\n return AuthContext.instance;\r\n }\r\n\r\n public static uninit() {\r\n AuthContext.instance = null;\r\n }\r\n\r\n public getId(): string {\r\n return this.id;\r\n }\r\n\r\n public getType(): AuthType {\r\n return this.type;\r\n }\r\n\r\n public getToken(): string | undefined {\r\n return this.token;\r\n }\r\n \r\n public getLambdaName(): string | undefined{\r\n return this.lambdaName;\r\n }\r\n\r\n public getRequestId(): string | undefined {\r\n return this.requestId;\r\n }\r\n\r\n public getInitializedAt(): Date {\r\n return this.initializedAt;\r\n }\r\n\r\n public getSystemID(fallbackLambdaName: string): string {\r\n let baseId = this.lambdaName || fallbackLambdaName;\r\n if (this.requestId) {\r\n return `${baseId} - ${this.requestId}`;\r\n }\r\n return baseId;\r\n }\r\n}","import { decodeJwt, importPKCS8, importSPKI, jwtVerify, SignJWT} from 'jose';\r\nimport ErrorTypes from '../enums/ErrorTypes';\r\nimport Logger from '../Logger';\r\nimport Utils from '../Utils';\r\nimport ResponseUtility from '../Utils/response';\r\nimport assert from 'assert';\r\nimport Fetch from '../Utils/fetch';\r\nimport AuthContext from './AuthContext';\r\n\r\ntype StringifiedJSONArray = string;\r\n\r\nexport type AuthPayloadData = {\r\n id: string;\r\n type: AuthType;\r\n verifier?: string;\r\n [key: string]: any;\r\n}\r\n\r\nexport interface AuthUtilityConfig {\r\n userTokenAge: string;\r\n userPrivateKeys: StringifiedJSONArray;\r\n userPublicKeys: StringifiedJSONArray;\r\n anonymousTokenAge: string;\r\n anonymousPrivateKeys: StringifiedJSONArray;\r\n anonymousPublicKeys: StringifiedJSONArray;\r\n systemTokenAge: string;\r\n systemPrivateKeys: StringifiedJSONArray;\r\n systemPublicKeys: StringifiedJSONArray;\r\n adminTokenAge: string;\r\n adminPrivateKeys: StringifiedJSONArray;\r\n adminPublicKeys: StringifiedJSONArray;\r\n cdnKeys: StringifiedJSONArray;\r\n}\r\n\r\nexport const DefaultAuthUtilityConfig: Readonly<AuthUtilityConfig> = {\r\n userTokenAge: '30 days',\r\n userPrivateKeys: '[]',\r\n userPublicKeys: '[]',\r\n anonymousTokenAge: '30 days',\r\n anonymousPrivateKeys: '[]',\r\n anonymousPublicKeys: '[]',\r\n systemTokenAge: '5 min',\r\n systemPrivateKeys: '[]',\r\n systemPublicKeys: '[]',\r\n adminTokenAge: '30 days',\r\n adminPrivateKeys: '[]',\r\n adminPublicKeys: '[]',\r\n cdnKeys: '[]',\r\n};\r\n\r\nexport enum AuthType {\r\n ANON = 'Anon',\r\n USER = 'User',\r\n SYSTEM = 'System',\r\n ADMIN = 'Admin',\r\n CDN = 'CDN'\r\n}\r\n\r\nexport interface AuthMiddlewareConfig {\r\n allowAnonymous: boolean;\r\n allowSystem: boolean;\r\n allowUser: boolean;\r\n allowCDN: boolean;\r\n}\r\n\r\nexport const DefaultAuthMiddlewareConfig: Readonly<AuthMiddlewareConfig> = {\r\n allowAnonymous: false,\r\n allowSystem: true,\r\n allowUser: true,\r\n allowCDN: false\r\n};\r\n\r\n/**\r\n * A utility class for JWT authentication and authorization.\r\n */\r\nclass AuthUtility {\r\n private userTokenAge: string;\r\n private userPrivateKeys: string[];\r\n private userPublicKeys: string[];\r\n\r\n private anonymousTokenAge: string;\r\n private anonymousPrivateKeys: string[];\r\n private anonymousPublicKeys: string[];\r\n\r\n private systemTokenAge: string;\r\n private systemPrivateKeys: string[];\r\n private systemPublicKeys: string[];\r\n\r\n private adminTokenAge: string;\r\n private adminPrivateKeys: string[];\r\n private adminPublicKeys: string[];\r\n\r\n private cdnKeys: string[];\r\n\r\n /**\r\n * Initializes the AuthUtility class with a configuration.\r\n * @param config The configuration for the utility (optional).\r\n */\r\n constructor(config: Partial<AuthUtilityConfig> = DefaultAuthUtilityConfig) {\r\n const {\r\n userTokenAge,\r\n userPrivateKeys,\r\n userPublicKeys,\r\n anonymousTokenAge,\r\n anonymousPrivateKeys,\r\n anonymousPublicKeys,\r\n systemTokenAge,\r\n systemPrivateKeys,\r\n systemPublicKeys,\r\n adminTokenAge,\r\n adminPrivateKeys,\r\n adminPublicKeys,\r\n cdnKeys\r\n } = { ...DefaultAuthUtilityConfig, ...config };\r\n\r\n this.userTokenAge = userTokenAge;\r\n this.userPrivateKeys = this.parseKeyArray(userPrivateKeys, 'user private');\r\n this.userPublicKeys = this.parseKeyArray(userPublicKeys, 'user public');\r\n\r\n this.anonymousTokenAge = anonymousTokenAge;\r\n this.anonymousPrivateKeys = this.parseKeyArray(anonymousPrivateKeys, 'anonymous private');\r\n this.anonymousPublicKeys = this.parseKeyArray(anonymousPublicKeys, 'anonymous public');\r\n\r\n this.systemTokenAge = systemTokenAge;\r\n this.systemPrivateKeys = this.parseKeyArray(systemPrivateKeys, 'system private');\r\n this.systemPublicKeys = this.parseKeyArray(systemPublicKeys, 'system public');\r\n\r\n this.adminTokenAge = adminTokenAge;\r\n this.adminPrivateKeys = this.parseKeyArray(adminPrivateKeys, 'admin private');\r\n this.adminPublicKeys = this.parseKeyArray(adminPublicKeys, 'admin public');\r\n\r\n this.cdnKeys = this.parseKeyArray(cdnKeys, 'cdn');\r\n\r\n this.logWarnings();\r\n }\r\n\r\n private parseKeyArray(jsonString: string, keyType: string): string[] {\r\n try {\r\n const parsed = JSON.parse(jsonString);\r\n if (!Array.isArray(parsed) || !parsed.every(item => typeof item === 'string')) {\r\n Logger.logError('AuthUtility', `Invalid format for ${keyType} keys in config: Expected stringified array of strings.`);\r\n return [];\r\n }\r\n return parsed;\r\n } catch (error) {\r\n Logger.logError('AuthUtility', `Failed to parse ${keyType} keys from config: ${error}`);\r\n return [];\r\n }\r\n }\r\n\r\n /**\r\n * Logs warnings if the number of keys exceeds recommended limits.\r\n */\r\n private logWarnings() {\r\n const warn = (type: string, keys: string[], limit: number) =>\r\n keys.length > limit &&\r\n Logger.logWarning(\r\n 'AuthUtility',\r\n `More than ${limit} ${type} keys provided. This is not recommended.`\r\n );\r\n\r\n warn('user private', this.userPrivateKeys, 3);\r\n warn('user public', this.userPublicKeys, 3);\r\n warn('anonymous private', this.anonymousPrivateKeys, 1);\r\n warn('anonymous public', this.anonymousPublicKeys, 3);\r\n warn('system private', this.systemPrivateKeys, 1);\r\n warn('system public', this.systemPublicKeys, 3);\r\n warn('admin private', this.adminPrivateKeys, 1);\r\n warn('admin public', this.adminPublicKeys, 3);\r\n }\r\n\r\n private async createSignedJWT(payload: AuthPayloadData, privateKeyString: string, expiration: string){\r\n const privateKey = await importPKCS8(privateKeyString, 'RS256');\r\n const token = await new SignJWT(payload)\r\n .setProtectedHeader({ alg: 'RS256' })\r\n .setExpirationTime(expiration)\r\n .setIssuedAt()\r\n .sign(privateKey);\r\n\r\n return token;\r\n }\r\n\r\n private async verifySignedJWT(token: string, publicKeyString: string[], expiration: string): Promise<AuthPayloadData> {\r\n for(let i = publicKeyString.length - 1; i >= 0 ; i--){\r\n try { \r\n const publicKey = await importSPKI(publicKeyString[i], 'RS256')\r\n const jwt = await jwtVerify(token, publicKey, { clockTolerance: 30, maxTokenAge: expiration });\r\n return jwt.payload as AuthPayloadData;\r\n } catch (error) {\r\n if (i === 0) {\r\n throw error;\r\n }\r\n // Try with the next oldest key\r\n continue;\r\n }\r\n }\r\n throw new Error(ErrorTypes.INVALID_TOKEN);\r\n }\r\n\r\n \r\n /**\r\n * Creates an anonymous token with the given ID and additional data.\r\n *\r\n * @param id - The unique identifier for the token. Must be a valid UUID.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT as a string.\r\n * @throws Will throw an error if no anonymous private keys are found or if the ID is not a valid UUID.\r\n */\r\n async createAnonymousToken(id: string, additionalData?: object): Promise<string> {\r\n assert(this.anonymousPrivateKeys.length, ErrorTypes.ANONYMOUS_PRIVATE_KEY_NOT_FOUND);\r\n\r\n assert(Utils.isUUID(id), ErrorTypes.INVALID_UUID);\r\n const payload = {\r\n id,\r\n type: AuthType.ANON,\r\n ...additionalData\r\n };\r\n\r\n return await this.createSignedJWT(payload, this.anonymousPrivateKeys[this.anonymousPrivateKeys.length - 1], this.anonymousTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies an anonymous token by checking its signature and payload type.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @returns The payload of the verified token.\r\n * @throws Will throw an error if no anonymous public keys are found or if the token type is invalid.\r\n */\r\n async verifyAnonymousToken(token: string){\r\n assert(this.anonymousPublicKeys.length, ErrorTypes.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.anonymousPublicKeys, this.anonymousTokenAge);\r\n assert(payload.type === AuthType.ANON, ErrorTypes.INVALID_AUTH_TYPE);\r\n return payload;\r\n }\r\n\r\n /**\r\n * Creates a signed JWT token for a user.\r\n *\r\n * @param id - The UUID of the user.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT token as a string.\r\n * @throws Will throw an error if no user private keys are found or if the provided id is not a valid UUID.\r\n */\r\n async createUserToken(id: string, additionalData?: object): Promise<string> {\r\n assert(this.userPrivateKeys.length, ErrorTypes.USER_PRIVATE_KEY_NOT_FOUND);\r\n assert(Utils.isUUID(id), ErrorTypes.INVALID_UUID);\r\n\r\n const payload = {\r\n id,\r\n type: AuthType.USER,\r\n ...additionalData\r\n };\r\n return await this.createSignedJWT(payload, this.userPrivateKeys[this.userPrivateKeys.length - 1], this.userTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies the provided user token by checking its signature and payload.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @returns The payload of the verified token if valid.\r\n * @throws Will throw an error if no user public keys are found or if the token type is invalid.\r\n */\r\n async verifyUserToken(token: string){\r\n assert(this.userPublicKeys.length, ErrorTypes.USER_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.userPublicKeys, this.userTokenAge);\r\n assert(payload.type === AuthType.USER, ErrorTypes.INVALID_AUTH_TYPE);\r\n return payload;\r\n }\r\n\r\n /**\r\n * Creates a signed JWT (JSON Web Token) for a system with the given ID and optional additional data.\r\n *\r\n * @param id - The unique identifier for the system.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT as a string.\r\n * @throws Will throw an error if no system private keys are found.\r\n */\r\n async createSystemToken(id: string, additionalData?: object): Promise<string> {\r\n assert(this.systemPrivateKeys.length, ErrorTypes.SYSTEM_PRIVATE_KEY_NOT_FOUND);\r\n\r\n const payload = {\r\n id,\r\n type: AuthType.SYSTEM,\r\n ...additionalData\r\n };\r\n return await this.createSignedJWT(payload, this.systemPrivateKeys[this.systemPrivateKeys.length - 1], this.systemTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies a system token by checking its signature and payload type.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @returns The payload of the verified token.\r\n * @throws Will throw an error if no system public keys are found or if the token type is not 'System'.\r\n */\r\n async verifySystemToken(token: string){\r\n assert(this.systemPublicKeys.length, ErrorTypes.USER_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.systemPublicKeys, this.systemTokenAge);\r\n assert(payload.type === AuthType.SYSTEM, ErrorTypes.INVALID_AUTH_TYPE);\r\n return payload;\r\n }\r\n\r\n /**\r\n * Creates a signed JWT token for an admin user.\r\n *\r\n * @param email - The email of the admin user.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT token string.\r\n * @throws Will throw an error if no admin private keys are found or if the provided id is not a valid UUID.\r\n */\r\n async createAdminToken(email: string, verifier: string, additionalData?: object): Promise<string> {\r\n assert(this.adminPrivateKeys.length, ErrorTypes.ADMIN_PRIVATE_KEY_NOT_FOUND);\r\n\r\n assert(Utils.isEmail(email), ErrorTypes.INVALID_EMAIL);\r\n assert(Utils.isURL(verifier), ErrorTypes.INVALID_VERIFIER);\r\n const payload = {\r\n id: email,\r\n type: AuthType.ADMIN,\r\n verifier: verifier,\r\n ...additionalData\r\n };\r\n return await this.createSignedJWT(payload, this.adminPrivateKeys[this.adminPrivateKeys.length - 1], this.adminTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies the provided admin token by checking its signature and payload.\r\n * Ensures that the token is signed with one of the known admin public keys\r\n * and that the payload type is 'Admin'.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @param permissions - The permissions required for the admin user.\r\n * @param authenticate - Whether to authenticate the token with the verifier.\r\n * @returns The payload of the verified token.\r\n * @throws Will throw an error if no admin public keys are found or if the token is invalid or if the admin doesn't have proper permissions.\r\n */\r\n async verifyAdminToken(token: string, permissions: string[], authenticate: boolean){\r\n assert(this.adminPublicKeys.length, ErrorTypes.ADMIN_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.adminPublicKeys, this.adminTokenAge);\r\n assert(payload.type === AuthType.ADMIN, ErrorTypes.INVALID_AUTH_TYPE);\r\n\r\n if(authenticate) {\r\n const response = await Fetch(payload.verifier as string, '', 'POST', {}, { token, permissions });\r\n assert(response.data.isTokenValid === true, ErrorTypes.INVALID_TOKEN);\r\n \r\n if(response.data.hasPermissions !== true){\r\n throw ResponseUtility.generateError(403, ErrorTypes.INVALID_PERMISSIONS)\r\n }\r\n }\r\n\r\n return payload;\r\n }\r\n\r\n async verifyCDNToken(token: string) {\r\n assert(this.cdnKeys.includes(token), ErrorTypes.INVALID_TOKEN);\r\n\r\n const payload: AuthPayloadData = {\r\n id: token,\r\n type: AuthType.CDN,\r\n };\r\n\r\n return payload;\r\n }\r\n\r\n /**\r\n * Middleware function to handle authentication based on different token types.\r\n * It verifies the token and sets the authentication details in the response locals.\r\n *\r\n * @param {Partial<AuthMiddlewareConfig>} [config=DefaultAuthMiddlewareConfig] - Configuration object to customize the middleware behavior.\r\n * @returns Middleware function to handle authentication.\r\n */\r\n AuthMiddleware(config: Partial<AuthMiddlewareConfig> = DefaultAuthMiddlewareConfig, permissions: string[] = []) {\r\n const { allowAnonymous, allowSystem, allowUser, allowCDN } = { ...DefaultAuthMiddlewareConfig, ...config };\r\n return async (req: any, res: any, next: any) => {\r\n try {\r\n const [authType, token] = req.get('Authorization')?.split(' ') || [];\r\n if (!token) throw new Error(ErrorTypes.INVALID_TOKEN);\r\n\r\n let payload;\r\n switch (authType as AuthType) {\r\n case AuthType.ANON:\r\n if (!allowAnonymous) throw ResponseUtility.generateError(403, ErrorTypes.ANONYMOUS_SESSION_NOT_ALLOWED);\r\n payload = await this.verifyAnonymousToken(token);\r\n break;\r\n case AuthType.USER:\r\n if (!allowUser) throw ResponseUtility.generateError(403, ErrorTypes.USER_SESSION_NOT_ALLOWED);\r\n payload = await this.verifyUserToken(token);\r\n break;\r\n case AuthType.SYSTEM:\r\n if (!allowSystem) throw ResponseUtility.generateError(403, ErrorTypes.SYSTEM_SESSION_NOT_ALLOWED);\r\n payload = await this.verifySystemToken(token);\r\n break;\r\n case AuthType.ADMIN:\r\n payload = await this.verifyAdminToken(token, permissions, true);\r\n break;\r\n case AuthType.CDN:\r\n if (!allowCDN) throw ResponseUtility.generateError(403, ErrorTypes.CDN_SESSION_NOT_ALLOWED);\r\n payload = await this.verifyCDNToken(token);\r\n\r\n break;\r\n default:\r\n throw ResponseUtility.generateError(403, ErrorTypes.INVALID_AUTH_TYPE);\r\n }\r\n\r\n next();\r\n } catch (error: any) {\r\n Logger.logError('AuthMiddleware', error);\r\n ResponseUtility.handleException(\r\n 'AuthMiddleware',\r\n ResponseUtility.generateError(401, error.error || ErrorTypes.TOKEN_EXPIRED, true),\r\n res\r\n );\r\n }\r\n };\r\n }\r\n\r\n /**\r\n * Decodes the payload of a JWT using jose.decodeJwt without verifying\r\n * the signature or expiration.\r\n * WARNING: This is insecure as it doesn't validate the token's integrity.\r\n * Use only when you understand the risks and have a specific need.\r\n *\r\n * @param token - The JWT string.\r\n * @returns The decoded payload object, or null if the token format is invalid or decoding fails.\r\n */\r\n decodeJWTPayloadWithJose(token: string): Record<string, any> | null {\r\n if (!token || typeof token !== 'string') {\r\n Logger.logError(\"AuthContextMiddleware\", \"Invalid token provided for decoding.\");\r\n return null;\r\n }\r\n\r\n try {\r\n const payload = decodeJwt(token);\r\n return payload;\r\n } catch (error) {\r\n Logger.logError(\"AuthContextMiddleware\", `Failed to decode JWT payload: ${error}`);\r\n return null;\r\n }\r\n }\r\n\r\n AuthContextMiddleware() {\r\n return async (req: any, res: any, next: any) => {\r\n try {\r\n const [authType, token] = req.get('Authorization')?.split(' ') || [];\r\n let payload = authType === AuthType.CDN ? { id: token, type: AuthType.CDN } : this.decodeJWTPayloadWithJose(token);\r\n\r\n const authContext = AuthContext.init(payload?.id || token, payload?.type || authType, token, req.get('x-request-id'));\r\n Logger.logMessage('AuthContextMiddleware', `AuthContext initialized: ${authContext.getType() || 'No-Type'} - ${authContext.getId() || 'No-Id'}`);\r\n\r\n res.on('finish', () => {\r\n Logger.logMessage('AuthContextMiddleware', 'Uninitializing AuthContext');\r\n AuthContext.uninit();\r\n });\r\n\r\n next();\r\n } catch (error: any) {\r\n Logger.logError('AuthContextMiddleware', error);\r\n ResponseUtility.handleException(\r\n 'AuthContextMiddleware',\r\n ResponseUtility.generateError(500, error.error || ErrorTypes.INTERNAL_SERVER_ERROR, true),\r\n res\r\n );\r\n }\r\n };\r\n }\r\n}\r\n\r\nexport default AuthUtility;\r\nexport { AuthContext };\r\n\r\n"]}
1
+ {"version":3,"sources":["../../src/Auth/AuthContext.ts","../../src/Auth/index.ts"],"names":["AuthContext","_AuthContext","id","type","token","requestId","assert","ErrorTypes_default","fallbackLambdaName","baseId","DefaultAuthUtilityConfig","AuthType","DefaultAuthMiddlewareConfig","AuthUtility","config","userTokenAge","userPrivateKeys","userPublicKeys","anonymousTokenAge","anonymousPrivateKeys","anonymousPublicKeys","systemTokenAge","systemPrivateKeys","systemPublicKeys","adminTokenAge","adminPrivateKeys","adminPublicKeys","cdnKeys","jsonString","keyType","parsed","item","Logger_default","error","warn","keys","limit","payload","privateKeyString","expiration","privateKey","importPKCS8","SignJWT","publicKeyString","i","publicKey","importSPKI","jwtVerify","additionalData","Utils_default","email","verifier","permissions","authenticate","response","fetch_default","response_default","allowAnonymous","allowSystem","allowUser","allowCDN","req","res","next","authType","decodeJwt","authContext","Auth_default"],"mappings":"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","file":"index.mjs","sourcesContent":["import assert from \"assert\";\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport { AuthType } from \"./index\";\r\n\r\nexport default class AuthContext {\r\n private static instance: AuthContext | null = null;\r\n private id: string;\r\n private type: AuthType;\r\n private token?: string;\r\n private initializedAt: Date;\r\n private lambdaName?: string;\r\n private requestId?: string;\r\n\r\n private constructor(id: string, type: AuthType, token: string, requestId: string) {\r\n this.id = id;\r\n this.type = type;\r\n this.token = token;\r\n this.lambdaName = process.env.AWS_LAMBDA_FUNCTION_NAME;\r\n this.initializedAt = new Date();\r\n }\r\n\r\n public static getInstance(): AuthContext {\r\n assert(AuthContext.instance, ErrorTypes.AUTH_CONTEXT_NOT_INITIALIZED);\r\n return AuthContext.instance;\r\n }\r\n\r\n public static init(id: string, type: AuthType, token: string, requestId: string): AuthContext {\r\n AuthContext.instance = new AuthContext(id, type, token, requestId);\r\n return AuthContext.instance;\r\n }\r\n\r\n public static uninit() {\r\n AuthContext.instance = null;\r\n }\r\n\r\n public getId(): string {\r\n return this.id;\r\n }\r\n\r\n public getType(): AuthType {\r\n return this.type;\r\n }\r\n\r\n public getToken(): string | undefined {\r\n return this.token;\r\n }\r\n \r\n public getLambdaName(): string | undefined{\r\n return this.lambdaName;\r\n }\r\n\r\n public getRequestId(): string | undefined {\r\n return this.requestId;\r\n }\r\n\r\n public getInitializedAt(): Date {\r\n return this.initializedAt;\r\n }\r\n\r\n public getSystemID(fallbackLambdaName: string): string {\r\n let baseId = this.lambdaName || fallbackLambdaName;\r\n if (this.requestId) {\r\n return `${baseId} - ${this.requestId}`;\r\n }\r\n return baseId;\r\n }\r\n}","import { decodeJwt, importPKCS8, importSPKI, jwtVerify, SignJWT} from 'jose';\r\nimport ErrorTypes from '../enums/ErrorTypes';\r\nimport Logger from '../Logger';\r\nimport Utils from '../Utils';\r\nimport ResponseUtility from '../Utils/response';\r\nimport assert from 'assert';\r\nimport Fetch from '../Utils/fetch';\r\nimport AuthContext from './AuthContext';\r\n\r\ntype StringifiedJSONArray = string;\r\n\r\nexport type AuthPayloadData = {\r\n id: string;\r\n type: AuthType;\r\n verifier?: string;\r\n [key: string]: any;\r\n}\r\n\r\nexport interface AuthUtilityConfig {\r\n userTokenAge: string;\r\n userPrivateKeys: StringifiedJSONArray;\r\n userPublicKeys: StringifiedJSONArray;\r\n anonymousTokenAge: string;\r\n anonymousPrivateKeys: StringifiedJSONArray;\r\n anonymousPublicKeys: StringifiedJSONArray;\r\n systemTokenAge: string;\r\n systemPrivateKeys: StringifiedJSONArray;\r\n systemPublicKeys: StringifiedJSONArray;\r\n adminTokenAge: string;\r\n adminPrivateKeys: StringifiedJSONArray;\r\n adminPublicKeys: StringifiedJSONArray;\r\n cdnKeys: StringifiedJSONArray;\r\n}\r\n\r\nexport const DefaultAuthUtilityConfig: Readonly<AuthUtilityConfig> = {\r\n userTokenAge: '30 days',\r\n userPrivateKeys: '[]',\r\n userPublicKeys: '[]',\r\n anonymousTokenAge: '30 days',\r\n anonymousPrivateKeys: '[]',\r\n anonymousPublicKeys: '[]',\r\n systemTokenAge: '5 min',\r\n systemPrivateKeys: '[]',\r\n systemPublicKeys: '[]',\r\n adminTokenAge: '30 days',\r\n adminPrivateKeys: '[]',\r\n adminPublicKeys: '[]',\r\n cdnKeys: '[]',\r\n};\r\n\r\nexport enum AuthType {\r\n ANON = 'Anon',\r\n USER = 'User',\r\n SYSTEM = 'System',\r\n ADMIN = 'Admin',\r\n CDN = 'CDN'\r\n}\r\n\r\nexport interface AuthMiddlewareConfig {\r\n allowAnonymous: boolean;\r\n allowSystem: boolean;\r\n allowUser: boolean;\r\n allowCDN: boolean;\r\n}\r\n\r\nexport const DefaultAuthMiddlewareConfig: Readonly<AuthMiddlewareConfig> = {\r\n allowAnonymous: false,\r\n allowSystem: true,\r\n allowUser: true,\r\n allowCDN: false\r\n};\r\n\r\n/**\r\n * A utility class for JWT authentication and authorization.\r\n */\r\nclass AuthUtility {\r\n private userTokenAge: string;\r\n private userPrivateKeys: string[];\r\n private userPublicKeys: string[];\r\n\r\n private anonymousTokenAge: string;\r\n private anonymousPrivateKeys: string[];\r\n private anonymousPublicKeys: string[];\r\n\r\n private systemTokenAge: string;\r\n private systemPrivateKeys: string[];\r\n private systemPublicKeys: string[];\r\n\r\n private adminTokenAge: string;\r\n private adminPrivateKeys: string[];\r\n private adminPublicKeys: string[];\r\n\r\n private cdnKeys: string[];\r\n\r\n /**\r\n * Initializes the AuthUtility class with a configuration.\r\n * @param config The configuration for the utility (optional).\r\n */\r\n constructor(config: Partial<AuthUtilityConfig> = DefaultAuthUtilityConfig) {\r\n const {\r\n userTokenAge,\r\n userPrivateKeys,\r\n userPublicKeys,\r\n anonymousTokenAge,\r\n anonymousPrivateKeys,\r\n anonymousPublicKeys,\r\n systemTokenAge,\r\n systemPrivateKeys,\r\n systemPublicKeys,\r\n adminTokenAge,\r\n adminPrivateKeys,\r\n adminPublicKeys,\r\n cdnKeys\r\n } = { ...DefaultAuthUtilityConfig, ...config };\r\n\r\n this.userTokenAge = userTokenAge;\r\n this.userPrivateKeys = this.parseKeyArray(userPrivateKeys, 'user private');\r\n this.userPublicKeys = this.parseKeyArray(userPublicKeys, 'user public');\r\n\r\n this.anonymousTokenAge = anonymousTokenAge;\r\n this.anonymousPrivateKeys = this.parseKeyArray(anonymousPrivateKeys, 'anonymous private');\r\n this.anonymousPublicKeys = this.parseKeyArray(anonymousPublicKeys, 'anonymous public');\r\n\r\n this.systemTokenAge = systemTokenAge;\r\n this.systemPrivateKeys = this.parseKeyArray(systemPrivateKeys, 'system private');\r\n this.systemPublicKeys = this.parseKeyArray(systemPublicKeys, 'system public');\r\n\r\n this.adminTokenAge = adminTokenAge;\r\n this.adminPrivateKeys = this.parseKeyArray(adminPrivateKeys, 'admin private');\r\n this.adminPublicKeys = this.parseKeyArray(adminPublicKeys, 'admin public');\r\n\r\n this.cdnKeys = this.parseKeyArray(cdnKeys, 'cdn');\r\n\r\n this.logWarnings();\r\n }\r\n\r\n private parseKeyArray(jsonString: string, keyType: string): string[] {\r\n try {\r\n const parsed = JSON.parse(jsonString);\r\n if (!Array.isArray(parsed) || !parsed.every(item => typeof item === 'string')) {\r\n Logger.logError('AuthUtility', `Invalid format for ${keyType} keys in config: Expected stringified array of strings.`);\r\n return [];\r\n }\r\n return parsed;\r\n } catch (error) {\r\n Logger.logError('AuthUtility', `Failed to parse ${keyType} keys from config: ${error}`);\r\n return [];\r\n }\r\n }\r\n\r\n /**\r\n * Logs warnings if the number of keys exceeds recommended limits.\r\n */\r\n private logWarnings() {\r\n const warn = (type: string, keys: string[], limit: number) =>\r\n keys.length > limit &&\r\n Logger.logWarning(\r\n 'AuthUtility',\r\n `More than ${limit} ${type} keys provided. This is not recommended.`\r\n );\r\n\r\n warn('user private', this.userPrivateKeys, 3);\r\n warn('user public', this.userPublicKeys, 3);\r\n warn('anonymous private', this.anonymousPrivateKeys, 1);\r\n warn('anonymous public', this.anonymousPublicKeys, 3);\r\n warn('system private', this.systemPrivateKeys, 1);\r\n warn('system public', this.systemPublicKeys, 3);\r\n warn('admin private', this.adminPrivateKeys, 1);\r\n warn('admin public', this.adminPublicKeys, 3);\r\n }\r\n\r\n private async createSignedJWT(payload: AuthPayloadData, privateKeyString: string, expiration: string){\r\n const privateKey = await importPKCS8(privateKeyString, 'RS256');\r\n const token = await new SignJWT(payload)\r\n .setProtectedHeader({ alg: 'RS256' })\r\n .setExpirationTime(expiration)\r\n .setIssuedAt()\r\n .sign(privateKey);\r\n\r\n return token;\r\n }\r\n\r\n private async verifySignedJWT(token: string, publicKeyString: string[], expiration: string): Promise<AuthPayloadData> {\r\n for(let i = publicKeyString.length - 1; i >= 0 ; i--){\r\n try { \r\n const publicKey = await importSPKI(publicKeyString[i], 'RS256')\r\n const jwt = await jwtVerify(token, publicKey, { clockTolerance: 30, maxTokenAge: expiration });\r\n return jwt.payload as AuthPayloadData;\r\n } catch (error) {\r\n if (i === 0) {\r\n throw error;\r\n }\r\n // Try with the next oldest key\r\n continue;\r\n }\r\n }\r\n throw new Error(ErrorTypes.INVALID_TOKEN);\r\n }\r\n\r\n \r\n /**\r\n * Creates an anonymous token with the given ID and additional data.\r\n *\r\n * @param id - The unique identifier for the token. Must be a valid UUID.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT as a string.\r\n * @throws Will throw an error if no anonymous private keys are found or if the ID is not a valid UUID.\r\n */\r\n async createAnonymousToken(id: string, additionalData?: object): Promise<string> {\r\n assert(this.anonymousPrivateKeys.length, ErrorTypes.ANONYMOUS_PRIVATE_KEY_NOT_FOUND);\r\n\r\n assert(Utils.isUUID(id), ErrorTypes.INVALID_UUID);\r\n const payload = {\r\n id,\r\n type: AuthType.ANON,\r\n ...additionalData\r\n };\r\n\r\n return await this.createSignedJWT(payload, this.anonymousPrivateKeys[this.anonymousPrivateKeys.length - 1], this.anonymousTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies an anonymous token by checking its signature and payload type.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @returns The payload of the verified token.\r\n * @throws Will throw an error if no anonymous public keys are found or if the token type is invalid.\r\n */\r\n async verifyAnonymousToken(token: string){\r\n assert(this.anonymousPublicKeys.length, ErrorTypes.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.anonymousPublicKeys, this.anonymousTokenAge);\r\n assert(payload.type === AuthType.ANON, ErrorTypes.INVALID_AUTH_TYPE);\r\n return payload;\r\n }\r\n\r\n /**\r\n * Creates a signed JWT token for a user.\r\n *\r\n * @param id - The UUID of the user.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT token as a string.\r\n * @throws Will throw an error if no user private keys are found or if the provided id is not a valid UUID.\r\n */\r\n async createUserToken(id: string, additionalData?: object): Promise<string> {\r\n assert(this.userPrivateKeys.length, ErrorTypes.USER_PRIVATE_KEY_NOT_FOUND);\r\n assert(Utils.isUUID(id), ErrorTypes.INVALID_UUID);\r\n\r\n const payload = {\r\n id,\r\n type: AuthType.USER,\r\n ...additionalData\r\n };\r\n return await this.createSignedJWT(payload, this.userPrivateKeys[this.userPrivateKeys.length - 1], this.userTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies the provided user token by checking its signature and payload.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @returns The payload of the verified token if valid.\r\n * @throws Will throw an error if no user public keys are found or if the token type is invalid.\r\n */\r\n async verifyUserToken(token: string){\r\n assert(this.userPublicKeys.length, ErrorTypes.USER_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.userPublicKeys, this.userTokenAge);\r\n assert(payload.type === AuthType.USER, ErrorTypes.INVALID_AUTH_TYPE);\r\n return payload;\r\n }\r\n\r\n /**\r\n * Creates a signed JWT (JSON Web Token) for a system with the given ID and optional additional data.\r\n *\r\n * @param id - The unique identifier for the system.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT as a string.\r\n * @throws Will throw an error if no system private keys are found.\r\n */\r\n async createSystemToken(id: string, additionalData?: object): Promise<string> {\r\n assert(this.systemPrivateKeys.length, ErrorTypes.SYSTEM_PRIVATE_KEY_NOT_FOUND);\r\n\r\n const payload = {\r\n id,\r\n type: AuthType.SYSTEM,\r\n ...additionalData\r\n };\r\n return await this.createSignedJWT(payload, this.systemPrivateKeys[this.systemPrivateKeys.length - 1], this.systemTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies a system token by checking its signature and payload type.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @returns The payload of the verified token.\r\n * @throws Will throw an error if no system public keys are found or if the token type is not 'System'.\r\n */\r\n async verifySystemToken(token: string){\r\n assert(this.systemPublicKeys.length, ErrorTypes.USER_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.systemPublicKeys, this.systemTokenAge);\r\n assert(payload.type === AuthType.SYSTEM, ErrorTypes.INVALID_AUTH_TYPE);\r\n return payload;\r\n }\r\n\r\n /**\r\n * Creates a signed JWT token for an admin user.\r\n *\r\n * @param email - The email of the admin user.\r\n * @param additionalData - Optional additional data to include in the token payload.\r\n * @returns A promise that resolves to the signed JWT token string.\r\n * @throws Will throw an error if no admin private keys are found or if the provided id is not a valid UUID.\r\n */\r\n async createAdminToken(email: string, verifier: string, additionalData?: object): Promise<string> {\r\n assert(this.adminPrivateKeys.length, ErrorTypes.ADMIN_PRIVATE_KEY_NOT_FOUND);\r\n\r\n assert(Utils.isEmail(email), ErrorTypes.INVALID_EMAIL);\r\n assert(Utils.isURL(verifier), ErrorTypes.INVALID_VERIFIER);\r\n const payload = {\r\n id: email,\r\n type: AuthType.ADMIN,\r\n verifier: verifier,\r\n ...additionalData\r\n };\r\n return await this.createSignedJWT(payload, this.adminPrivateKeys[this.adminPrivateKeys.length - 1], this.adminTokenAge);\r\n }\r\n\r\n /**\r\n * Verifies the provided admin token by checking its signature and payload.\r\n * Ensures that the token is signed with one of the known admin public keys\r\n * and that the payload type is 'Admin'.\r\n *\r\n * @param token - The JWT token to be verified.\r\n * @param permissions - The permissions required for the admin user.\r\n * @param authenticate - Whether to authenticate the token with the verifier.\r\n * @returns The payload of the verified token.\r\n * @throws Will throw an error if no admin public keys are found or if the token is invalid or if the admin doesn't have proper permissions.\r\n */\r\n async verifyAdminToken(token: string, permissions: string[], authenticate: boolean){\r\n assert(this.adminPublicKeys.length, ErrorTypes.ADMIN_PUBLIC_KEY_NOT_FOUND);\r\n const payload = await this.verifySignedJWT(token, this.adminPublicKeys, this.adminTokenAge);\r\n assert(payload.type === AuthType.ADMIN, ErrorTypes.INVALID_AUTH_TYPE);\r\n\r\n if(authenticate) {\r\n const response = await Fetch(payload.verifier as string, '', 'POST', {}, { token, permissions });\r\n assert(response.data.isTokenValid === true, ErrorTypes.INVALID_TOKEN);\r\n \r\n if(response.data.hasPermissions !== true){\r\n throw ResponseUtility.generateError(403, ErrorTypes.INVALID_PERMISSIONS)\r\n }\r\n }\r\n\r\n return payload;\r\n }\r\n\r\n async verifyCDNToken(token: string) {\r\n assert(this.cdnKeys.includes(token), ErrorTypes.INVALID_TOKEN);\r\n\r\n const payload: AuthPayloadData = {\r\n id: token,\r\n type: AuthType.CDN,\r\n };\r\n\r\n return payload;\r\n }\r\n\r\n /**\r\n * Middleware function to handle authentication based on different token types.\r\n * It verifies the token and sets the authentication details in the response locals.\r\n *\r\n * @param {Partial<AuthMiddlewareConfig>} [config=DefaultAuthMiddlewareConfig] - Configuration object to customize the middleware behavior.\r\n * @returns Middleware function to handle authentication.\r\n */\r\n AuthMiddleware(config: Partial<AuthMiddlewareConfig> = DefaultAuthMiddlewareConfig, permissions: string[] = []) {\r\n const { allowAnonymous, allowSystem, allowUser, allowCDN } = { ...DefaultAuthMiddlewareConfig, ...config };\r\n return async (req: any, res: any, next: any) => {\r\n try {\r\n const [authType, token] = req.get('Authorization')?.split(' ') || [];\r\n if (!token) throw new Error(ErrorTypes.INVALID_TOKEN);\r\n\r\n let payload;\r\n switch (authType as AuthType) {\r\n case AuthType.ANON:\r\n if (!allowAnonymous) throw ResponseUtility.generateError(403, ErrorTypes.ANONYMOUS_SESSION_NOT_ALLOWED);\r\n payload = await this.verifyAnonymousToken(token);\r\n break;\r\n case AuthType.USER:\r\n if (!allowUser) throw ResponseUtility.generateError(403, ErrorTypes.USER_SESSION_NOT_ALLOWED);\r\n payload = await this.verifyUserToken(token);\r\n break;\r\n case AuthType.SYSTEM:\r\n if (!allowSystem) throw ResponseUtility.generateError(403, ErrorTypes.SYSTEM_SESSION_NOT_ALLOWED);\r\n payload = await this.verifySystemToken(token);\r\n break;\r\n case AuthType.ADMIN:\r\n payload = await this.verifyAdminToken(token, permissions, true);\r\n break;\r\n case AuthType.CDN:\r\n if (!allowCDN) throw ResponseUtility.generateError(403, ErrorTypes.CDN_SESSION_NOT_ALLOWED);\r\n payload = await this.verifyCDNToken(token);\r\n\r\n break;\r\n default:\r\n throw ResponseUtility.generateError(403, ErrorTypes.INVALID_AUTH_TYPE);\r\n }\r\n\r\n next();\r\n } catch (error: any) {\r\n Logger.logError('AuthMiddleware', error);\r\n ResponseUtility.handleException(\r\n 'AuthMiddleware',\r\n ResponseUtility.generateError(401, error.error || ErrorTypes.TOKEN_EXPIRED, true),\r\n res\r\n );\r\n }\r\n };\r\n }\r\n\r\n /**\r\n * Decodes the payload of a JWT using jose.decodeJwt without verifying\r\n * the signature or expiration.\r\n * WARNING: This is insecure as it doesn't validate the token's integrity.\r\n * Use only when you understand the risks and have a specific need.\r\n *\r\n * @param token - The JWT string.\r\n * @returns The decoded payload object, or null if the token format is invalid or decoding fails.\r\n */\r\n decodeJWTPayloadWithJose(token: string): Record<string, any> | null {\r\n if (!token || typeof token !== 'string') {\r\n Logger.logError(\"AuthContextMiddleware\", \"Invalid token provided for decoding.\");\r\n return null;\r\n }\r\n\r\n try {\r\n const payload = decodeJwt(token);\r\n return payload;\r\n } catch (error) {\r\n Logger.logError(\"AuthContextMiddleware\", `Failed to decode JWT payload: ${error}`);\r\n return null;\r\n }\r\n }\r\n\r\n AuthContextMiddleware() {\r\n return async (req: any, res: any, next: any) => {\r\n try {\r\n const [authType, token] = req.get('Authorization')?.split(' ') || [];\r\n let payload = authType === AuthType.CDN ? { id: token, type: AuthType.CDN } : (authType ? this.decodeJWTPayloadWithJose(token) : {});\r\n\r\n const authContext = AuthContext.init(payload?.id || token, payload?.type || authType, token, req.get('x-request-id'));\r\n Logger.logMessage('AuthContextMiddleware', `AuthContext initialized: ${authContext.getType() || 'No-Type'} - ${authContext.getId() || 'No-Id'}`);\r\n\r\n res.on('finish', () => {\r\n Logger.logMessage('AuthContextMiddleware', 'Uninitializing AuthContext');\r\n AuthContext.uninit();\r\n });\r\n\r\n next();\r\n } catch (error: any) {\r\n Logger.logError('AuthContextMiddleware', error);\r\n ResponseUtility.handleException(\r\n 'AuthContextMiddleware',\r\n ResponseUtility.generateError(500, error.error || ErrorTypes.INTERNAL_SERVER_ERROR, true),\r\n res\r\n );\r\n }\r\n };\r\n }\r\n}\r\n\r\nexport default AuthUtility;\r\nexport { AuthContext };\r\n\r\n"]}
@@ -1,6 +1,6 @@
1
1
  import BaseModel, { BaseAttributes } from './Base.mjs';
2
2
  import '../Auth/index.mjs';
3
- import './Common.mjs';
3
+ import '../Common-FbQ5-3QN.mjs';
4
4
  import './Enum.mjs';
5
5
 
6
6
  declare enum AddressType {
@@ -1,6 +1,6 @@
1
1
  import BaseModel, { BaseAttributes } from './Base.js';
2
2
  import '../Auth/index.js';
3
- import './Common.js';
3
+ import '../Common-D-UoxwM0.js';
4
4
  import './Enum.js';
5
5
 
6
6
  declare enum AddressType {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Classes/Base.ts","../../src/Classes/Address.ts"],"names":["BaseModel","data","date","id","authType","requestId","lambdaName","fieldName","value","AddressType","AddressModel","addressType"],"mappings":"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","file":"Address.js","sourcesContent":["import { AuthType } from \"../Auth\";\r\nimport { ISODateTime } from \"./Common\";\r\n\r\nexport interface CustomFields {\r\n [key: string]: any;\r\n}\r\n\r\nexport type ModifiedBy = {\r\n id?: string;\r\n authType?: string;\r\n requestId?: string;\r\n lambdaName?: string;\r\n}\r\n\r\nexport type BaseAttributes = {\r\n customFields?: CustomFields;\r\n version?: number;\r\n createdAt?: ISODateTime;\r\n modifiedAt?: ISODateTime;\r\n modifiedBy?: ModifiedBy;\r\n};\r\n\r\nexport type BaseData = Required<BaseAttributes>;\r\n\r\n/**\r\n * Provides common foundational properties and methods for other data models.\r\n * Handles tracking of custom fields, versioning, and timestamps.\r\n */\r\nexport default class BaseModel {\r\n protected customFields: CustomFields;\r\n protected version: number;\r\n protected createdAt: ISODateTime;\r\n protected modifiedAt: ISODateTime;\r\n protected modifiedBy: ModifiedBy;\r\n\r\n /**\r\n * Creates an instance of BaseModel.\r\n * Initializes common properties like timestamps, version, and custom fields.\r\n * @param data - Optional initial attributes for the base model.\r\n * @param date - Optional date object to use for default timestamps (defaults to current time).\r\n */\r\n constructor(data: BaseAttributes, date: Date = new Date()) {\r\n this.customFields = { ...data.customFields };\r\n this.version = data.version ?? 1;\r\n this.createdAt = data.createdAt && !isNaN(Date.parse(data.createdAt))\r\n ?\r\n new Date(data.createdAt).toISOString()\r\n :\r\n date.toISOString();\r\n this.modifiedAt = data.modifiedAt && !isNaN(Date.parse(data.modifiedAt))\r\n ? new Date(data.modifiedAt).toISOString()\r\n : date.toISOString();\r\n\r\n this.modifiedBy = { ...data.modifiedBy };\r\n }\r\n\r\n /**\r\n * Gets a plain data object representing the base model's current state.\r\n * @returns BaseData object containing common properties.\r\n */\r\n getDetails(): BaseData {\r\n return {\r\n customFields: this.getAllCustomFields(), // Use getter to return a copy\r\n version: this.getVersion(),\r\n createdAt: this.getCreatedAt(),\r\n modifiedAt: this.getModifiedAt(),\r\n modifiedBy: this.getModifiedBy(),\r\n }\r\n }\r\n\r\n /**\r\n * Gets the current version number of the model instance.\r\n * @returns The version number.\r\n */\r\n getVersion(): number {\r\n return this.version;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as an ISO 8601 string.\r\n * @returns The creation timestamp string.\r\n */\r\n getCreatedAt(): string {\r\n return this.createdAt;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as a Unix epoch time (milliseconds).\r\n * @returns The creation time in milliseconds since the epoch.\r\n */\r\n getCreatedAtTime(): number {\r\n return new Date(this.createdAt).getTime();\r\n }\r\n\r\n\r\n /**\r\n * Gets the last modification timestamp as an ISO 8601 string.\r\n * @returns The last modification timestamp string.\r\n */\r\n getModifiedAt(): string {\r\n return this.modifiedAt;\r\n }\r\n\r\n /**\r\n * Gets the last modification timestamp as a Unix epoch time (milliseconds).\r\n * @returns The last modification time in milliseconds since the epoch.\r\n */\r\n getModifiedAtTime(): number {\r\n return new Date(this.modifiedAt).getTime();\r\n }\r\n\r\n /**\r\n * Gets the identifier of the user or process that last modified the instance.\r\n * @returns\r\n */\r\n getModifiedBy(): ModifiedBy {\r\n return { ...this.modifiedBy };\r\n }\r\n\r\n /**\r\n * Sets the identifier of the user or process that last modified the instance.\r\n * @param modifiedBy - The identifier string.\r\n */\r\n setModifiedBy(id?: string, authType?: AuthType, requestId?: string, lambdaName?: string): void {\r\n this.modifiedBy = {\r\n id,\r\n authType,\r\n requestId,\r\n lambdaName,\r\n };\r\n }\r\n\r\n /**\r\n * Retrieves the value of a specific custom field.\r\n * @param fieldName - The name (key) of the custom field to retrieve.\r\n * @returns The value of the custom field, or null if the field does not exist.\r\n */\r\n getCustomField(fieldName: string): any {\r\n return this.customFields[fieldName] ?? null;\r\n }\r\n\r\n /**\r\n * Sets the value of a specific custom field.\r\n * Also updates the modification timestamp and increments the version.\r\n * @param fieldName - The name (key) of the custom field to set.\r\n * @param value - The value to assign to the custom field.\r\n */\r\n setCustomField(fieldName: string, value: any): void {\r\n this.customFields[fieldName] = value;\r\n }\r\n\r\n /**\r\n * Retrieves a shallow copy of all custom fields associated with the instance.\r\n * @returns An object containing all custom fields.\r\n */\r\n getAllCustomFields(): CustomFields {\r\n return { ...this.customFields };\r\n }\r\n}\r\n","import BaseModel, { BaseAttributes } from \"./Base\";\r\n\r\nexport enum AddressType {\r\n BILLING = \"billing\",\r\n SHIPPING = \"shipping\",\r\n BILLING_AND_SHIPPING = \"billing&shipping\",\r\n NONE = \"none\",\r\n}\r\n\r\nexport type AddressAttributes = BaseAttributes & {\r\n id: string;\r\n firstName: string;\r\n lastName?: string;\r\n company?: string;\r\n phone: string;\r\n email: string;\r\n addressLine1: string;\r\n addressLine2?: string;\r\n city: string;\r\n postalCode: string\r\n state: string;\r\n country: string;\r\n isBillingAddress: boolean;\r\n isShippingAddress: boolean;\r\n};\r\n\r\nexport type AddressData = Required<AddressAttributes>;\r\n\r\n/**\r\n * Represents a physical address associated with a customer or order.\r\n * Handles both billing and shipping address types.\r\n */\r\nexport default class AddressModel extends BaseModel {\r\n protected id: string;\r\n protected firstName: string;\r\n protected lastName: string;\r\n protected company: string;\r\n protected phone: string;\r\n protected email: string;\r\n protected addressLine1: string;\r\n protected addressLine2: string;\r\n protected city: string;\r\n protected postalCode: string\r\n protected state: string;\r\n protected country: string;\r\n protected isBillingAddress: boolean;\r\n protected isShippingAddress: boolean;\r\n\r\n /**\r\n * Creates an instance of AddressModel.\r\n * @param data - The initial address attributes.\r\n * @param date - Optional date for setting creation/modification times (defaults to now).\r\n */\r\n constructor(data: AddressAttributes, date: Date = new Date()) {\r\n super(data, date);\r\n this.id = data.id;\r\n this.firstName = data.firstName;\r\n this.lastName = data.lastName || '';\r\n this.company = data.company || '';\r\n this.phone = data.phone;\r\n this.email = data.email;\r\n this.addressLine1 = data.addressLine1;\r\n this.addressLine2 = data.addressLine2 || '';\r\n this.city = data.city;\r\n this.postalCode = data.postalCode;\r\n this.state = data.state;\r\n this.country = data.country;\r\n this.isBillingAddress = data.isBillingAddress;\r\n this.isShippingAddress = data.isShippingAddress;\r\n }\r\n\r\n /**\r\n * Gets a plain data object representing the address's current state.\r\n * Includes all address fields and base model fields.\r\n * @returns AddressData object suitable for serialization or API responses.\r\n */\r\n getDetails(): AddressData {\r\n return {\r\n ...super.getDetails(),\r\n id: this.getId(),\r\n firstName: this.getFirstName(),\r\n lastName: this.getLastName(),\r\n company: this.getCompany(),\r\n phone: this.getPhone(),\r\n email: this.getEmail(),\r\n addressLine1: this.getAddressLine1(),\r\n addressLine2: this.getAddressLine2(),\r\n city: this.getCity(),\r\n postalCode: this.getPostalCode(),\r\n state: this.getState(),\r\n country: this.getCountry(),\r\n isBillingAddress: this.getIsBillingAddress(),\r\n isShippingAddress: this.getIsShippingAddress(),\r\n }\r\n }\r\n\r\n /**\r\n * Gets the unique identifier for the address.\r\n * @returns The address ID.\r\n */\r\n getId(): string {\r\n return this.id;\r\n }\r\n\r\n /**\r\n * Gets the first name associated with the address.\r\n * @returns The first name.\r\n */\r\n getFirstName(): string {\r\n return this.firstName;\r\n }\r\n\r\n /**\r\n * Gets the last name associated with the address.\r\n * @returns The last name.\r\n */\r\n getLastName(): string {\r\n return this.lastName;\r\n }\r\n\r\n /**\r\n * Gets the company name associated with the address.\r\n * @returns The company name.\r\n */\r\n getCompany(): string {\r\n return this.company;\r\n }\r\n\r\n /**\r\n * Gets the phone number associated with the address.\r\n * @returns The phone number.\r\n */\r\n getPhone(): string {\r\n return this.phone;\r\n }\r\n\r\n /**\r\n * Gets the email address associated with the address.\r\n * @returns The email address.\r\n */\r\n getEmail(): string {\r\n return this.email;\r\n }\r\n\r\n /**\r\n * Gets the primary address line (e.g., street address).\r\n * @returns The first address line.\r\n */\r\n getAddressLine1(): string {\r\n return this.addressLine1;\r\n }\r\n\r\n /**\r\n * Gets the secondary address line (e.g., apartment, suite).\r\n * Returns an empty string if not provided.\r\n * @returns The second address line or an empty string.\r\n */\r\n getAddressLine2(): string {\r\n return this.addressLine2;\r\n }\r\n\r\n /**\r\n * Gets the city name.\r\n * @returns The city.\r\n */\r\n getCity(): string {\r\n return this.city;\r\n }\r\n\r\n /**\r\n * Gets the postal code (e.g., ZIP code).\r\n * @returns The postal code.\r\n */\r\n getPostalCode(): string {\r\n return this.postalCode;\r\n }\r\n\r\n /**\r\n * Gets the state, province, or region.\r\n * @returns The state.\r\n */\r\n getState(): string {\r\n return this.state;\r\n }\r\n\r\n /**\r\n * Gets the country name or code.\r\n * @returns The country.\r\n */\r\n getCountry(): string {\r\n return this.country;\r\n }\r\n\r\n /**\r\n * Checks if this address is designated as a billing address.\r\n * @returns True if it's a billing address, false otherwise.\r\n */\r\n getIsBillingAddress(): boolean {\r\n return this.isBillingAddress;\r\n }\r\n\r\n /**\r\n * Checks if this address is designated as a shipping address.\r\n * @returns True if it's a shipping address, false otherwise.\r\n */\r\n getIsShippingAddress(): boolean {\r\n return this.isShippingAddress;\r\n }\r\n\r\n /**\r\n * Determines the type of the address based on its billing and shipping flags.\r\n * @returns The AddressType enum value representing the address's role.\r\n */\r\n getAddressType(): AddressType {\r\n if (this.isBillingAddress && this.isShippingAddress) {\r\n return AddressType.BILLING_AND_SHIPPING;\r\n } else if (this.isBillingAddress) {\r\n return AddressType.BILLING;\r\n } else if (this.isShippingAddress) {\r\n return AddressType.SHIPPING;\r\n } else {\r\n return AddressType.NONE;\r\n }\r\n }\r\n\r\n /**\r\n * Static method to check if a given AddressType includes shipping.\r\n * @param addressType - The address type to check.\r\n * @returns True if the type is SHIPPING or BILLING_AND_SHIPPING.\r\n */\r\n static checkIfShippingAddress(addressType: AddressType): boolean {\r\n return addressType === AddressType.SHIPPING || addressType === AddressType.BILLING_AND_SHIPPING;\r\n }\r\n\r\n /**\r\n * Static method to check if a given AddressType includes billing.\r\n * @param addressType - The address type to check.\r\n * @returns True if the type is BILLING or BILLING_AND_SHIPPING.\r\n */\r\n static checkIfBillingAddress(addressType: AddressType): boolean {\r\n return addressType === AddressType.BILLING || addressType === AddressType.BILLING_AND_SHIPPING;\r\n }\r\n}"]}
1
+ {"version":3,"sources":["../../src/Classes/Base.ts","../../src/Classes/Address.ts"],"names":["BaseModel","data","date","id","authType","requestId","lambdaName","fieldName","value","AddressType","AddressModel","addressType"],"mappings":"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","file":"Address.js","sourcesContent":["import { AuthType } from \"../Auth\";\r\nimport { ISODateTimeUTC } from \"./Common\";\r\n\r\nexport interface CustomFields {\r\n [key: string]: any;\r\n}\r\n\r\nexport type ModifiedBy = {\r\n id?: string;\r\n authType?: string;\r\n requestId?: string;\r\n lambdaName?: string;\r\n}\r\n\r\nexport type BaseAttributes = {\r\n customFields?: CustomFields;\r\n version?: number;\r\n createdAt?: ISODateTimeUTC;\r\n modifiedAt?: ISODateTimeUTC;\r\n modifiedBy?: ModifiedBy;\r\n};\r\n\r\nexport type BaseData = Required<BaseAttributes>;\r\n\r\n/**\r\n * Provides common foundational properties and methods for other data models.\r\n * Handles tracking of custom fields, versioning, and timestamps.\r\n */\r\nexport default class BaseModel {\r\n protected customFields: CustomFields;\r\n protected version: number;\r\n protected createdAt: ISODateTimeUTC;\r\n protected modifiedAt: ISODateTimeUTC;\r\n protected modifiedBy: ModifiedBy;\r\n\r\n /**\r\n * Creates an instance of BaseModel.\r\n * Initializes common properties like timestamps, version, and custom fields.\r\n * @param data - Optional initial attributes for the base model.\r\n * @param date - Optional date object to use for default timestamps (defaults to current time).\r\n */\r\n constructor(data: BaseAttributes, date: Date = new Date()) {\r\n this.customFields = { ...data.customFields };\r\n this.version = data.version ?? 1;\r\n this.createdAt = data.createdAt && !isNaN(Date.parse(data.createdAt))\r\n ?\r\n new Date(data.createdAt).toISOString()\r\n :\r\n date.toISOString();\r\n this.modifiedAt = data.modifiedAt && !isNaN(Date.parse(data.modifiedAt))\r\n ? new Date(data.modifiedAt).toISOString()\r\n : date.toISOString();\r\n\r\n this.modifiedBy = { ...data.modifiedBy };\r\n }\r\n\r\n /**\r\n * Gets a plain data object representing the base model's current state.\r\n * @returns BaseData object containing common properties.\r\n */\r\n getDetails(): BaseData {\r\n return {\r\n customFields: this.getAllCustomFields(), // Use getter to return a copy\r\n version: this.getVersion(),\r\n createdAt: this.getCreatedAt(),\r\n modifiedAt: this.getModifiedAt(),\r\n modifiedBy: this.getModifiedBy(),\r\n }\r\n }\r\n\r\n /**\r\n * Gets the current version number of the model instance.\r\n * @returns The version number.\r\n */\r\n getVersion(): number {\r\n return this.version;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as an ISO 8601 string.\r\n * @returns The creation timestamp string.\r\n */\r\n getCreatedAt(): string {\r\n return this.createdAt;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as a Unix epoch time (milliseconds).\r\n * @returns The creation time in milliseconds since the epoch.\r\n */\r\n getCreatedAtTime(): number {\r\n return new Date(this.createdAt).getTime();\r\n }\r\n\r\n\r\n /**\r\n * Gets the last modification timestamp as an ISO 8601 string.\r\n * @returns The last modification timestamp string.\r\n */\r\n getModifiedAt(): string {\r\n return this.modifiedAt;\r\n }\r\n\r\n /**\r\n * Gets the last modification timestamp as a Unix epoch time (milliseconds).\r\n * @returns The last modification time in milliseconds since the epoch.\r\n */\r\n getModifiedAtTime(): number {\r\n return new Date(this.modifiedAt).getTime();\r\n }\r\n\r\n /**\r\n * Gets the identifier of the user or process that last modified the instance.\r\n * @returns\r\n */\r\n getModifiedBy(): ModifiedBy {\r\n return { ...this.modifiedBy };\r\n }\r\n\r\n /**\r\n * Sets the identifier of the user or process that last modified the instance.\r\n * @param modifiedBy - The identifier string.\r\n */\r\n setModifiedBy(id?: string, authType?: AuthType, requestId?: string, lambdaName?: string): void {\r\n this.modifiedBy = {\r\n id,\r\n authType,\r\n requestId,\r\n lambdaName,\r\n };\r\n }\r\n\r\n /**\r\n * Retrieves the value of a specific custom field.\r\n * @param fieldName - The name (key) of the custom field to retrieve.\r\n * @returns The value of the custom field, or null if the field does not exist.\r\n */\r\n getCustomField(fieldName: string): any {\r\n return this.customFields[fieldName] ?? null;\r\n }\r\n\r\n /**\r\n * Sets the value of a specific custom field.\r\n * Also updates the modification timestamp and increments the version.\r\n * @param fieldName - The name (key) of the custom field to set.\r\n * @param value - The value to assign to the custom field.\r\n */\r\n setCustomField(fieldName: string, value: any): void {\r\n this.customFields[fieldName] = value;\r\n }\r\n\r\n /**\r\n * Retrieves a shallow copy of all custom fields associated with the instance.\r\n * @returns An object containing all custom fields.\r\n */\r\n getAllCustomFields(): CustomFields {\r\n return { ...this.customFields };\r\n }\r\n}\r\n","import BaseModel, { BaseAttributes } from \"./Base\";\r\n\r\nexport enum AddressType {\r\n BILLING = \"billing\",\r\n SHIPPING = \"shipping\",\r\n BILLING_AND_SHIPPING = \"billing&shipping\",\r\n NONE = \"none\",\r\n}\r\n\r\nexport type AddressAttributes = BaseAttributes & {\r\n id: string;\r\n firstName: string;\r\n lastName?: string;\r\n company?: string;\r\n phone: string;\r\n email: string;\r\n addressLine1: string;\r\n addressLine2?: string;\r\n city: string;\r\n postalCode: string\r\n state: string;\r\n country: string;\r\n isBillingAddress: boolean;\r\n isShippingAddress: boolean;\r\n};\r\n\r\nexport type AddressData = Required<AddressAttributes>;\r\n\r\n/**\r\n * Represents a physical address associated with a customer or order.\r\n * Handles both billing and shipping address types.\r\n */\r\nexport default class AddressModel extends BaseModel {\r\n protected id: string;\r\n protected firstName: string;\r\n protected lastName: string;\r\n protected company: string;\r\n protected phone: string;\r\n protected email: string;\r\n protected addressLine1: string;\r\n protected addressLine2: string;\r\n protected city: string;\r\n protected postalCode: string\r\n protected state: string;\r\n protected country: string;\r\n protected isBillingAddress: boolean;\r\n protected isShippingAddress: boolean;\r\n\r\n /**\r\n * Creates an instance of AddressModel.\r\n * @param data - The initial address attributes.\r\n * @param date - Optional date for setting creation/modification times (defaults to now).\r\n */\r\n constructor(data: AddressAttributes, date: Date = new Date()) {\r\n super(data, date);\r\n this.id = data.id;\r\n this.firstName = data.firstName;\r\n this.lastName = data.lastName || '';\r\n this.company = data.company || '';\r\n this.phone = data.phone;\r\n this.email = data.email;\r\n this.addressLine1 = data.addressLine1;\r\n this.addressLine2 = data.addressLine2 || '';\r\n this.city = data.city;\r\n this.postalCode = data.postalCode;\r\n this.state = data.state;\r\n this.country = data.country;\r\n this.isBillingAddress = data.isBillingAddress;\r\n this.isShippingAddress = data.isShippingAddress;\r\n }\r\n\r\n /**\r\n * Gets a plain data object representing the address's current state.\r\n * Includes all address fields and base model fields.\r\n * @returns AddressData object suitable for serialization or API responses.\r\n */\r\n getDetails(): AddressData {\r\n return {\r\n ...super.getDetails(),\r\n id: this.getId(),\r\n firstName: this.getFirstName(),\r\n lastName: this.getLastName(),\r\n company: this.getCompany(),\r\n phone: this.getPhone(),\r\n email: this.getEmail(),\r\n addressLine1: this.getAddressLine1(),\r\n addressLine2: this.getAddressLine2(),\r\n city: this.getCity(),\r\n postalCode: this.getPostalCode(),\r\n state: this.getState(),\r\n country: this.getCountry(),\r\n isBillingAddress: this.getIsBillingAddress(),\r\n isShippingAddress: this.getIsShippingAddress(),\r\n }\r\n }\r\n\r\n /**\r\n * Gets the unique identifier for the address.\r\n * @returns The address ID.\r\n */\r\n getId(): string {\r\n return this.id;\r\n }\r\n\r\n /**\r\n * Gets the first name associated with the address.\r\n * @returns The first name.\r\n */\r\n getFirstName(): string {\r\n return this.firstName;\r\n }\r\n\r\n /**\r\n * Gets the last name associated with the address.\r\n * @returns The last name.\r\n */\r\n getLastName(): string {\r\n return this.lastName;\r\n }\r\n\r\n /**\r\n * Gets the company name associated with the address.\r\n * @returns The company name.\r\n */\r\n getCompany(): string {\r\n return this.company;\r\n }\r\n\r\n /**\r\n * Gets the phone number associated with the address.\r\n * @returns The phone number.\r\n */\r\n getPhone(): string {\r\n return this.phone;\r\n }\r\n\r\n /**\r\n * Gets the email address associated with the address.\r\n * @returns The email address.\r\n */\r\n getEmail(): string {\r\n return this.email;\r\n }\r\n\r\n /**\r\n * Gets the primary address line (e.g., street address).\r\n * @returns The first address line.\r\n */\r\n getAddressLine1(): string {\r\n return this.addressLine1;\r\n }\r\n\r\n /**\r\n * Gets the secondary address line (e.g., apartment, suite).\r\n * Returns an empty string if not provided.\r\n * @returns The second address line or an empty string.\r\n */\r\n getAddressLine2(): string {\r\n return this.addressLine2;\r\n }\r\n\r\n /**\r\n * Gets the city name.\r\n * @returns The city.\r\n */\r\n getCity(): string {\r\n return this.city;\r\n }\r\n\r\n /**\r\n * Gets the postal code (e.g., ZIP code).\r\n * @returns The postal code.\r\n */\r\n getPostalCode(): string {\r\n return this.postalCode;\r\n }\r\n\r\n /**\r\n * Gets the state, province, or region.\r\n * @returns The state.\r\n */\r\n getState(): string {\r\n return this.state;\r\n }\r\n\r\n /**\r\n * Gets the country name or code.\r\n * @returns The country.\r\n */\r\n getCountry(): string {\r\n return this.country;\r\n }\r\n\r\n /**\r\n * Checks if this address is designated as a billing address.\r\n * @returns True if it's a billing address, false otherwise.\r\n */\r\n getIsBillingAddress(): boolean {\r\n return this.isBillingAddress;\r\n }\r\n\r\n /**\r\n * Checks if this address is designated as a shipping address.\r\n * @returns True if it's a shipping address, false otherwise.\r\n */\r\n getIsShippingAddress(): boolean {\r\n return this.isShippingAddress;\r\n }\r\n\r\n /**\r\n * Determines the type of the address based on its billing and shipping flags.\r\n * @returns The AddressType enum value representing the address's role.\r\n */\r\n getAddressType(): AddressType {\r\n if (this.isBillingAddress && this.isShippingAddress) {\r\n return AddressType.BILLING_AND_SHIPPING;\r\n } else if (this.isBillingAddress) {\r\n return AddressType.BILLING;\r\n } else if (this.isShippingAddress) {\r\n return AddressType.SHIPPING;\r\n } else {\r\n return AddressType.NONE;\r\n }\r\n }\r\n\r\n /**\r\n * Static method to check if a given AddressType includes shipping.\r\n * @param addressType - The address type to check.\r\n * @returns True if the type is SHIPPING or BILLING_AND_SHIPPING.\r\n */\r\n static checkIfShippingAddress(addressType: AddressType): boolean {\r\n return addressType === AddressType.SHIPPING || addressType === AddressType.BILLING_AND_SHIPPING;\r\n }\r\n\r\n /**\r\n * Static method to check if a given AddressType includes billing.\r\n * @param addressType - The address type to check.\r\n * @returns True if the type is BILLING or BILLING_AND_SHIPPING.\r\n */\r\n static checkIfBillingAddress(addressType: AddressType): boolean {\r\n return addressType === AddressType.BILLING || addressType === AddressType.BILLING_AND_SHIPPING;\r\n }\r\n}"]}
@@ -1,2 +1,2 @@
1
- export{a as AddressType,b as default}from'../chunk-H5GPM4LA.mjs';import'../chunk-ATUUYYQT.mjs';//# sourceMappingURL=Address.mjs.map
1
+ export{a as AddressType,b as default}from'../chunk-5KD2EW7O.mjs';import'../chunk-55SOBG62.mjs';//# sourceMappingURL=Address.mjs.map
2
2
  //# sourceMappingURL=Address.mjs.map
@@ -1,5 +1,5 @@
1
1
  import { AuthType } from '../Auth/index.mjs';
2
- import { ISODateTime } from './Common.mjs';
2
+ import { I as ISODateTimeUTC } from '../Common-FbQ5-3QN.mjs';
3
3
  import './Enum.mjs';
4
4
 
5
5
  interface CustomFields {
@@ -14,8 +14,8 @@ type ModifiedBy = {
14
14
  type BaseAttributes = {
15
15
  customFields?: CustomFields;
16
16
  version?: number;
17
- createdAt?: ISODateTime;
18
- modifiedAt?: ISODateTime;
17
+ createdAt?: ISODateTimeUTC;
18
+ modifiedAt?: ISODateTimeUTC;
19
19
  modifiedBy?: ModifiedBy;
20
20
  };
21
21
  type BaseData = Required<BaseAttributes>;
@@ -26,8 +26,8 @@ type BaseData = Required<BaseAttributes>;
26
26
  declare class BaseModel {
27
27
  protected customFields: CustomFields;
28
28
  protected version: number;
29
- protected createdAt: ISODateTime;
30
- protected modifiedAt: ISODateTime;
29
+ protected createdAt: ISODateTimeUTC;
30
+ protected modifiedAt: ISODateTimeUTC;
31
31
  protected modifiedBy: ModifiedBy;
32
32
  /**
33
33
  * Creates an instance of BaseModel.
@@ -1,5 +1,5 @@
1
1
  import { AuthType } from '../Auth/index.js';
2
- import { ISODateTime } from './Common.js';
2
+ import { I as ISODateTimeUTC } from '../Common-D-UoxwM0.js';
3
3
  import './Enum.js';
4
4
 
5
5
  interface CustomFields {
@@ -14,8 +14,8 @@ type ModifiedBy = {
14
14
  type BaseAttributes = {
15
15
  customFields?: CustomFields;
16
16
  version?: number;
17
- createdAt?: ISODateTime;
18
- modifiedAt?: ISODateTime;
17
+ createdAt?: ISODateTimeUTC;
18
+ modifiedAt?: ISODateTimeUTC;
19
19
  modifiedBy?: ModifiedBy;
20
20
  };
21
21
  type BaseData = Required<BaseAttributes>;
@@ -26,8 +26,8 @@ type BaseData = Required<BaseAttributes>;
26
26
  declare class BaseModel {
27
27
  protected customFields: CustomFields;
28
28
  protected version: number;
29
- protected createdAt: ISODateTime;
30
- protected modifiedAt: ISODateTime;
29
+ protected createdAt: ISODateTimeUTC;
30
+ protected modifiedAt: ISODateTimeUTC;
31
31
  protected modifiedBy: ModifiedBy;
32
32
  /**
33
33
  * Creates an instance of BaseModel.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Classes/Base.ts"],"names":["BaseModel","data","date","id","authType","requestId","lambdaName","fieldName","value"],"mappings":"aA4BqBA,IAAAA,CAAAA,CAArB,KAA+B,CACnB,YAAA,CACA,QACA,SACA,CAAA,UAAA,CACA,WAQV,WAAYC,CAAAA,CAAAA,CAAsBC,EAAa,IAAI,IAAA,CAAQ,CACzD,IAAK,CAAA,YAAA,CAAe,CAAE,GAAGD,CAAAA,CAAK,YAAa,CAAA,CAC3C,IAAK,CAAA,OAAA,CAAUA,EAAK,OAAW,EAAA,CAAA,CAC/B,KAAK,SAAYA,CAAAA,CAAAA,CAAK,WAAa,CAAC,KAAA,CAAM,IAAK,CAAA,KAAA,CAAMA,CAAK,CAAA,SAAS,CAAC,CAElE,CAAA,IAAI,KAAKA,CAAK,CAAA,SAAS,EAAE,WAAY,EAAA,CAErCC,CAAK,CAAA,WAAA,EACP,CAAA,IAAA,CAAK,WAAaD,CAAK,CAAA,UAAA,EAAc,CAAC,KAAM,CAAA,IAAA,CAAK,MAAMA,CAAK,CAAA,UAAU,CAAC,CACnE,CAAA,IAAI,KAAKA,CAAK,CAAA,UAAU,EAAE,WAAY,EAAA,CACtCC,EAAK,WAAY,EAAA,CAErB,IAAK,CAAA,UAAA,CAAa,CAAE,GAAGD,EAAK,UAAW,EACzC,CAMA,UAAuB,EAAA,CACrB,OAAO,CACL,YAAA,CAAc,IAAK,CAAA,kBAAA,EACnB,CAAA,OAAA,CAAS,KAAK,UAAW,EAAA,CACzB,UAAW,IAAK,CAAA,YAAA,GAChB,UAAY,CAAA,IAAA,CAAK,aAAc,EAAA,CAC/B,UAAY,CAAA,IAAA,CAAK,eACnB,CACF,CAMA,UAAqB,EAAA,CACnB,OAAO,IAAK,CAAA,OACd,CAMA,YAAuB,EAAA,CACrB,OAAO,IAAK,CAAA,SACd,CAMA,gBAA2B,EAAA,CACzB,OAAO,IAAI,IAAA,CAAK,IAAK,CAAA,SAAS,CAAE,CAAA,OAAA,EAClC,CAOA,aAAA,EAAwB,CACtB,OAAO,IAAA,CAAK,UACd,CAMA,iBAAA,EAA4B,CAC1B,OAAO,IAAI,IAAA,CAAK,KAAK,UAAU,CAAA,CAAE,SACnC,CAMA,eAA4B,CAC1B,OAAO,CAAE,GAAG,IAAK,CAAA,UAAW,CAC9B,CAMA,aAAA,CAAcE,EAAaC,CAAqBC,CAAAA,CAAAA,CAAoBC,EAA2B,CAC7F,IAAA,CAAK,WAAa,CAChB,EAAA,CAAAH,EACA,QAAAC,CAAAA,CAAAA,CACA,UAAAC,CACA,CAAA,UAAA,CAAAC,CACF,EACF,CAOA,cAAeC,CAAAA,CAAAA,CAAwB,CACrC,OAAO,KAAK,YAAaA,CAAAA,CAAS,GAAK,IACzC,CAQA,eAAeA,CAAmBC,CAAAA,CAAAA,CAAkB,CAClD,IAAA,CAAK,YAAaD,CAAAA,CAAS,EAAIC,EACjC,CAMA,oBAAmC,CACjC,OAAO,CAAE,GAAG,IAAA,CAAK,YAAa,CAChC,CACF","file":"Base.js","sourcesContent":["import { AuthType } from \"../Auth\";\r\nimport { ISODateTime } from \"./Common\";\r\n\r\nexport interface CustomFields {\r\n [key: string]: any;\r\n}\r\n\r\nexport type ModifiedBy = {\r\n id?: string;\r\n authType?: string;\r\n requestId?: string;\r\n lambdaName?: string;\r\n}\r\n\r\nexport type BaseAttributes = {\r\n customFields?: CustomFields;\r\n version?: number;\r\n createdAt?: ISODateTime;\r\n modifiedAt?: ISODateTime;\r\n modifiedBy?: ModifiedBy;\r\n};\r\n\r\nexport type BaseData = Required<BaseAttributes>;\r\n\r\n/**\r\n * Provides common foundational properties and methods for other data models.\r\n * Handles tracking of custom fields, versioning, and timestamps.\r\n */\r\nexport default class BaseModel {\r\n protected customFields: CustomFields;\r\n protected version: number;\r\n protected createdAt: ISODateTime;\r\n protected modifiedAt: ISODateTime;\r\n protected modifiedBy: ModifiedBy;\r\n\r\n /**\r\n * Creates an instance of BaseModel.\r\n * Initializes common properties like timestamps, version, and custom fields.\r\n * @param data - Optional initial attributes for the base model.\r\n * @param date - Optional date object to use for default timestamps (defaults to current time).\r\n */\r\n constructor(data: BaseAttributes, date: Date = new Date()) {\r\n this.customFields = { ...data.customFields };\r\n this.version = data.version ?? 1;\r\n this.createdAt = data.createdAt && !isNaN(Date.parse(data.createdAt))\r\n ?\r\n new Date(data.createdAt).toISOString()\r\n :\r\n date.toISOString();\r\n this.modifiedAt = data.modifiedAt && !isNaN(Date.parse(data.modifiedAt))\r\n ? new Date(data.modifiedAt).toISOString()\r\n : date.toISOString();\r\n\r\n this.modifiedBy = { ...data.modifiedBy };\r\n }\r\n\r\n /**\r\n * Gets a plain data object representing the base model's current state.\r\n * @returns BaseData object containing common properties.\r\n */\r\n getDetails(): BaseData {\r\n return {\r\n customFields: this.getAllCustomFields(), // Use getter to return a copy\r\n version: this.getVersion(),\r\n createdAt: this.getCreatedAt(),\r\n modifiedAt: this.getModifiedAt(),\r\n modifiedBy: this.getModifiedBy(),\r\n }\r\n }\r\n\r\n /**\r\n * Gets the current version number of the model instance.\r\n * @returns The version number.\r\n */\r\n getVersion(): number {\r\n return this.version;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as an ISO 8601 string.\r\n * @returns The creation timestamp string.\r\n */\r\n getCreatedAt(): string {\r\n return this.createdAt;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as a Unix epoch time (milliseconds).\r\n * @returns The creation time in milliseconds since the epoch.\r\n */\r\n getCreatedAtTime(): number {\r\n return new Date(this.createdAt).getTime();\r\n }\r\n\r\n\r\n /**\r\n * Gets the last modification timestamp as an ISO 8601 string.\r\n * @returns The last modification timestamp string.\r\n */\r\n getModifiedAt(): string {\r\n return this.modifiedAt;\r\n }\r\n\r\n /**\r\n * Gets the last modification timestamp as a Unix epoch time (milliseconds).\r\n * @returns The last modification time in milliseconds since the epoch.\r\n */\r\n getModifiedAtTime(): number {\r\n return new Date(this.modifiedAt).getTime();\r\n }\r\n\r\n /**\r\n * Gets the identifier of the user or process that last modified the instance.\r\n * @returns\r\n */\r\n getModifiedBy(): ModifiedBy {\r\n return { ...this.modifiedBy };\r\n }\r\n\r\n /**\r\n * Sets the identifier of the user or process that last modified the instance.\r\n * @param modifiedBy - The identifier string.\r\n */\r\n setModifiedBy(id?: string, authType?: AuthType, requestId?: string, lambdaName?: string): void {\r\n this.modifiedBy = {\r\n id,\r\n authType,\r\n requestId,\r\n lambdaName,\r\n };\r\n }\r\n\r\n /**\r\n * Retrieves the value of a specific custom field.\r\n * @param fieldName - The name (key) of the custom field to retrieve.\r\n * @returns The value of the custom field, or null if the field does not exist.\r\n */\r\n getCustomField(fieldName: string): any {\r\n return this.customFields[fieldName] ?? null;\r\n }\r\n\r\n /**\r\n * Sets the value of a specific custom field.\r\n * Also updates the modification timestamp and increments the version.\r\n * @param fieldName - The name (key) of the custom field to set.\r\n * @param value - The value to assign to the custom field.\r\n */\r\n setCustomField(fieldName: string, value: any): void {\r\n this.customFields[fieldName] = value;\r\n }\r\n\r\n /**\r\n * Retrieves a shallow copy of all custom fields associated with the instance.\r\n * @returns An object containing all custom fields.\r\n */\r\n getAllCustomFields(): CustomFields {\r\n return { ...this.customFields };\r\n }\r\n}\r\n"]}
1
+ {"version":3,"sources":["../../src/Classes/Base.ts"],"names":["BaseModel","data","date","id","authType","requestId","lambdaName","fieldName","value"],"mappings":"aA4BqBA,IAAAA,CAAAA,CAArB,KAA+B,CACnB,YAAA,CACA,QACA,SACA,CAAA,UAAA,CACA,WAQV,WAAYC,CAAAA,CAAAA,CAAsBC,EAAa,IAAI,IAAA,CAAQ,CACzD,IAAK,CAAA,YAAA,CAAe,CAAE,GAAGD,CAAAA,CAAK,YAAa,CAAA,CAC3C,IAAK,CAAA,OAAA,CAAUA,EAAK,OAAW,EAAA,CAAA,CAC/B,KAAK,SAAYA,CAAAA,CAAAA,CAAK,WAAa,CAAC,KAAA,CAAM,IAAK,CAAA,KAAA,CAAMA,CAAK,CAAA,SAAS,CAAC,CAElE,CAAA,IAAI,KAAKA,CAAK,CAAA,SAAS,EAAE,WAAY,EAAA,CAErCC,CAAK,CAAA,WAAA,EACP,CAAA,IAAA,CAAK,WAAaD,CAAK,CAAA,UAAA,EAAc,CAAC,KAAM,CAAA,IAAA,CAAK,MAAMA,CAAK,CAAA,UAAU,CAAC,CACnE,CAAA,IAAI,KAAKA,CAAK,CAAA,UAAU,EAAE,WAAY,EAAA,CACtCC,EAAK,WAAY,EAAA,CAErB,IAAK,CAAA,UAAA,CAAa,CAAE,GAAGD,EAAK,UAAW,EACzC,CAMA,UAAuB,EAAA,CACrB,OAAO,CACL,YAAA,CAAc,IAAK,CAAA,kBAAA,EACnB,CAAA,OAAA,CAAS,KAAK,UAAW,EAAA,CACzB,UAAW,IAAK,CAAA,YAAA,GAChB,UAAY,CAAA,IAAA,CAAK,aAAc,EAAA,CAC/B,UAAY,CAAA,IAAA,CAAK,eACnB,CACF,CAMA,UAAqB,EAAA,CACnB,OAAO,IAAK,CAAA,OACd,CAMA,YAAuB,EAAA,CACrB,OAAO,IAAK,CAAA,SACd,CAMA,gBAA2B,EAAA,CACzB,OAAO,IAAI,IAAA,CAAK,IAAK,CAAA,SAAS,CAAE,CAAA,OAAA,EAClC,CAOA,aAAA,EAAwB,CACtB,OAAO,IAAA,CAAK,UACd,CAMA,iBAAA,EAA4B,CAC1B,OAAO,IAAI,IAAA,CAAK,KAAK,UAAU,CAAA,CAAE,SACnC,CAMA,eAA4B,CAC1B,OAAO,CAAE,GAAG,IAAK,CAAA,UAAW,CAC9B,CAMA,aAAA,CAAcE,EAAaC,CAAqBC,CAAAA,CAAAA,CAAoBC,EAA2B,CAC7F,IAAA,CAAK,WAAa,CAChB,EAAA,CAAAH,EACA,QAAAC,CAAAA,CAAAA,CACA,UAAAC,CACA,CAAA,UAAA,CAAAC,CACF,EACF,CAOA,cAAeC,CAAAA,CAAAA,CAAwB,CACrC,OAAO,KAAK,YAAaA,CAAAA,CAAS,GAAK,IACzC,CAQA,eAAeA,CAAmBC,CAAAA,CAAAA,CAAkB,CAClD,IAAA,CAAK,YAAaD,CAAAA,CAAS,EAAIC,EACjC,CAMA,oBAAmC,CACjC,OAAO,CAAE,GAAG,IAAA,CAAK,YAAa,CAChC,CACF","file":"Base.js","sourcesContent":["import { AuthType } from \"../Auth\";\r\nimport { ISODateTimeUTC } from \"./Common\";\r\n\r\nexport interface CustomFields {\r\n [key: string]: any;\r\n}\r\n\r\nexport type ModifiedBy = {\r\n id?: string;\r\n authType?: string;\r\n requestId?: string;\r\n lambdaName?: string;\r\n}\r\n\r\nexport type BaseAttributes = {\r\n customFields?: CustomFields;\r\n version?: number;\r\n createdAt?: ISODateTimeUTC;\r\n modifiedAt?: ISODateTimeUTC;\r\n modifiedBy?: ModifiedBy;\r\n};\r\n\r\nexport type BaseData = Required<BaseAttributes>;\r\n\r\n/**\r\n * Provides common foundational properties and methods for other data models.\r\n * Handles tracking of custom fields, versioning, and timestamps.\r\n */\r\nexport default class BaseModel {\r\n protected customFields: CustomFields;\r\n protected version: number;\r\n protected createdAt: ISODateTimeUTC;\r\n protected modifiedAt: ISODateTimeUTC;\r\n protected modifiedBy: ModifiedBy;\r\n\r\n /**\r\n * Creates an instance of BaseModel.\r\n * Initializes common properties like timestamps, version, and custom fields.\r\n * @param data - Optional initial attributes for the base model.\r\n * @param date - Optional date object to use for default timestamps (defaults to current time).\r\n */\r\n constructor(data: BaseAttributes, date: Date = new Date()) {\r\n this.customFields = { ...data.customFields };\r\n this.version = data.version ?? 1;\r\n this.createdAt = data.createdAt && !isNaN(Date.parse(data.createdAt))\r\n ?\r\n new Date(data.createdAt).toISOString()\r\n :\r\n date.toISOString();\r\n this.modifiedAt = data.modifiedAt && !isNaN(Date.parse(data.modifiedAt))\r\n ? new Date(data.modifiedAt).toISOString()\r\n : date.toISOString();\r\n\r\n this.modifiedBy = { ...data.modifiedBy };\r\n }\r\n\r\n /**\r\n * Gets a plain data object representing the base model's current state.\r\n * @returns BaseData object containing common properties.\r\n */\r\n getDetails(): BaseData {\r\n return {\r\n customFields: this.getAllCustomFields(), // Use getter to return a copy\r\n version: this.getVersion(),\r\n createdAt: this.getCreatedAt(),\r\n modifiedAt: this.getModifiedAt(),\r\n modifiedBy: this.getModifiedBy(),\r\n }\r\n }\r\n\r\n /**\r\n * Gets the current version number of the model instance.\r\n * @returns The version number.\r\n */\r\n getVersion(): number {\r\n return this.version;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as an ISO 8601 string.\r\n * @returns The creation timestamp string.\r\n */\r\n getCreatedAt(): string {\r\n return this.createdAt;\r\n }\r\n\r\n /**\r\n * Gets the creation timestamp as a Unix epoch time (milliseconds).\r\n * @returns The creation time in milliseconds since the epoch.\r\n */\r\n getCreatedAtTime(): number {\r\n return new Date(this.createdAt).getTime();\r\n }\r\n\r\n\r\n /**\r\n * Gets the last modification timestamp as an ISO 8601 string.\r\n * @returns The last modification timestamp string.\r\n */\r\n getModifiedAt(): string {\r\n return this.modifiedAt;\r\n }\r\n\r\n /**\r\n * Gets the last modification timestamp as a Unix epoch time (milliseconds).\r\n * @returns The last modification time in milliseconds since the epoch.\r\n */\r\n getModifiedAtTime(): number {\r\n return new Date(this.modifiedAt).getTime();\r\n }\r\n\r\n /**\r\n * Gets the identifier of the user or process that last modified the instance.\r\n * @returns\r\n */\r\n getModifiedBy(): ModifiedBy {\r\n return { ...this.modifiedBy };\r\n }\r\n\r\n /**\r\n * Sets the identifier of the user or process that last modified the instance.\r\n * @param modifiedBy - The identifier string.\r\n */\r\n setModifiedBy(id?: string, authType?: AuthType, requestId?: string, lambdaName?: string): void {\r\n this.modifiedBy = {\r\n id,\r\n authType,\r\n requestId,\r\n lambdaName,\r\n };\r\n }\r\n\r\n /**\r\n * Retrieves the value of a specific custom field.\r\n * @param fieldName - The name (key) of the custom field to retrieve.\r\n * @returns The value of the custom field, or null if the field does not exist.\r\n */\r\n getCustomField(fieldName: string): any {\r\n return this.customFields[fieldName] ?? null;\r\n }\r\n\r\n /**\r\n * Sets the value of a specific custom field.\r\n * Also updates the modification timestamp and increments the version.\r\n * @param fieldName - The name (key) of the custom field to set.\r\n * @param value - The value to assign to the custom field.\r\n */\r\n setCustomField(fieldName: string, value: any): void {\r\n this.customFields[fieldName] = value;\r\n }\r\n\r\n /**\r\n * Retrieves a shallow copy of all custom fields associated with the instance.\r\n * @returns An object containing all custom fields.\r\n */\r\n getAllCustomFields(): CustomFields {\r\n return { ...this.customFields };\r\n }\r\n}\r\n"]}
@@ -1,2 +1,2 @@
1
- export{a as default}from'../chunk-ATUUYYQT.mjs';//# sourceMappingURL=Base.mjs.map
1
+ export{a as default}from'../chunk-55SOBG62.mjs';//# sourceMappingURL=Base.mjs.map
2
2
  //# sourceMappingURL=Base.mjs.map
@@ -1,13 +1,15 @@
1
1
  import LineItemModel from './LineItem.mjs';
2
+ import ProductModel from './Product.mjs';
2
3
  import BaseShoppingContainerModel, { BaseShoppingContainerAttributes, BaseShoppingContainerData } from './ShoppingContainer.mjs';
3
- import './Common.mjs';
4
+ import '../Common-FbQ5-3QN.mjs';
4
5
  import './Enum.mjs';
5
- import './ImageInfo.mjs';
6
- import './Product.mjs';
6
+ import './Coupon.mjs';
7
7
  import './Base.mjs';
8
8
  import '../Auth/index.mjs';
9
+ import './ImageInfo.mjs';
10
+ import './TaxRule.mjs';
11
+ import './TieredPrice.mjs';
9
12
  import './Address.mjs';
10
- import './Coupon.mjs';
11
13
 
12
14
  declare enum CartState {
13
15
  ACTIVE = "ACTIVE",
@@ -15,9 +17,6 @@ declare enum CartState {
15
17
  MERGED = "MERGED",
16
18
  ORDERED = "ORDERED"
17
19
  }
18
- declare class LineItemNotFoundError extends Error {
19
- constructor(lineItemId: string);
20
- }
21
20
  /**
22
21
  * Input attributes for creating or updating a CartModel.
23
22
  */
@@ -38,15 +37,31 @@ declare class CartModel extends BaseShoppingContainerModel {
38
37
  protected expireAt: number;
39
38
  protected config: CartConfig;
40
39
  constructor(data: CartAttributes, date?: Date, config?: CartConfig);
40
+ /**
41
+ * Gets the current state of the cart (e.g., ACTIVE, ORDERED).
42
+ * @returns The CartState enum value.
43
+ */
41
44
  getState(): CartState;
45
+ /**
46
+ * Gets the timestamp when the cart expires.
47
+ * @returns The expiration timestamp in seconds (Unix epoch).
48
+ */
42
49
  getExpireAt(): number;
50
+ /**
51
+ * Checks if the cart is currently active and not expired.
52
+ * @returns True if active and not expired, false otherwise.
53
+ */
43
54
  isActive(): boolean;
44
55
  /**
45
- * Recalculates all container totals (subtotal, mrpTotal, coupons, shipping, grandTotal).
46
- * Should be called whenever line items, coupons, or base shipping cost change.
47
- */
48
- updateCartTotals(): void;
56
+ * Clears all line items, coupons, and shipping details from the cart and resets totals.
57
+ */
49
58
  clearCartItems(): void;
59
+ /**
60
+ * Validates line items against the current product catalog.
61
+ * Updates product data for each item and removes invalid items.
62
+ * @param products - A record map of ProductModels keyed by product ID/key.
63
+ */
64
+ validateLineItems(products: Record<string, ProductModel>): void;
50
65
  /**
51
66
  * Adds a new line item or updates the quantity of an existing one.
52
67
  * @param newLineItem The LineItemModel to add.
@@ -72,4 +87,4 @@ declare class CartModel extends BaseShoppingContainerModel {
72
87
  getDetails(): CartData;
73
88
  }
74
89
 
75
- export { type CartAttributes, type CartConfig, type CartData, CartState, DEFAULT_CART_CONFIG, LineItemNotFoundError, CartModel as default };
90
+ export { type CartAttributes, type CartConfig, type CartData, CartState, DEFAULT_CART_CONFIG, CartModel as default };
@@ -1,13 +1,15 @@
1
1
  import LineItemModel from './LineItem.js';
2
+ import ProductModel from './Product.js';
2
3
  import BaseShoppingContainerModel, { BaseShoppingContainerAttributes, BaseShoppingContainerData } from './ShoppingContainer.js';
3
- import './Common.js';
4
+ import '../Common-D-UoxwM0.js';
4
5
  import './Enum.js';
5
- import './ImageInfo.js';
6
- import './Product.js';
6
+ import './Coupon.js';
7
7
  import './Base.js';
8
8
  import '../Auth/index.js';
9
+ import './ImageInfo.js';
10
+ import './TaxRule.js';
11
+ import './TieredPrice.js';
9
12
  import './Address.js';
10
- import './Coupon.js';
11
13
 
12
14
  declare enum CartState {
13
15
  ACTIVE = "ACTIVE",
@@ -15,9 +17,6 @@ declare enum CartState {
15
17
  MERGED = "MERGED",
16
18
  ORDERED = "ORDERED"
17
19
  }
18
- declare class LineItemNotFoundError extends Error {
19
- constructor(lineItemId: string);
20
- }
21
20
  /**
22
21
  * Input attributes for creating or updating a CartModel.
23
22
  */
@@ -38,15 +37,31 @@ declare class CartModel extends BaseShoppingContainerModel {
38
37
  protected expireAt: number;
39
38
  protected config: CartConfig;
40
39
  constructor(data: CartAttributes, date?: Date, config?: CartConfig);
40
+ /**
41
+ * Gets the current state of the cart (e.g., ACTIVE, ORDERED).
42
+ * @returns The CartState enum value.
43
+ */
41
44
  getState(): CartState;
45
+ /**
46
+ * Gets the timestamp when the cart expires.
47
+ * @returns The expiration timestamp in seconds (Unix epoch).
48
+ */
42
49
  getExpireAt(): number;
50
+ /**
51
+ * Checks if the cart is currently active and not expired.
52
+ * @returns True if active and not expired, false otherwise.
53
+ */
43
54
  isActive(): boolean;
44
55
  /**
45
- * Recalculates all container totals (subtotal, mrpTotal, coupons, shipping, grandTotal).
46
- * Should be called whenever line items, coupons, or base shipping cost change.
47
- */
48
- updateCartTotals(): void;
56
+ * Clears all line items, coupons, and shipping details from the cart and resets totals.
57
+ */
49
58
  clearCartItems(): void;
59
+ /**
60
+ * Validates line items against the current product catalog.
61
+ * Updates product data for each item and removes invalid items.
62
+ * @param products - A record map of ProductModels keyed by product ID/key.
63
+ */
64
+ validateLineItems(products: Record<string, ProductModel>): void;
50
65
  /**
51
66
  * Adds a new line item or updates the quantity of an existing one.
52
67
  * @param newLineItem The LineItemModel to add.
@@ -72,4 +87,4 @@ declare class CartModel extends BaseShoppingContainerModel {
72
87
  getDetails(): CartData;
73
88
  }
74
89
 
75
- export { type CartAttributes, type CartConfig, type CartData, CartState, DEFAULT_CART_CONFIG, LineItemNotFoundError, CartModel as default };
90
+ export { type CartAttributes, type CartConfig, type CartData, CartState, DEFAULT_CART_CONFIG, CartModel as default };