b23-lib 2.0.1 → 2.0.3

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 (48) hide show
  1. package/dist/Auth/index.js +1 -1
  2. package/dist/Auth/index.js.map +1 -1
  3. package/dist/Auth/index.mjs +1 -1
  4. package/dist/Classes/Cart.js +1 -1
  5. package/dist/Classes/Cart.js.map +1 -1
  6. package/dist/Classes/Cart.mjs +1 -1
  7. package/dist/Classes/Coupon.js +1 -1
  8. package/dist/Classes/Coupon.js.map +1 -1
  9. package/dist/Classes/Coupon.mjs +1 -1
  10. package/dist/Classes/Inventory.js +1 -1
  11. package/dist/Classes/Inventory.js.map +1 -1
  12. package/dist/Classes/Inventory.mjs +1 -1
  13. package/dist/Classes/LineItem.js +1 -1
  14. package/dist/Classes/LineItem.js.map +1 -1
  15. package/dist/Classes/LineItem.mjs +1 -1
  16. package/dist/Classes/Order.js +1 -1
  17. package/dist/Classes/Order.js.map +1 -1
  18. package/dist/Classes/Order.mjs +1 -1
  19. package/dist/Classes/Product.d.mts +8 -7
  20. package/dist/Classes/Product.d.ts +8 -7
  21. package/dist/Classes/Product.js +1 -1
  22. package/dist/Classes/Product.js.map +1 -1
  23. package/dist/Classes/Product.mjs +1 -1
  24. package/dist/Classes/ShoppingContainer.js +1 -1
  25. package/dist/Classes/ShoppingContainer.js.map +1 -1
  26. package/dist/Classes/ShoppingContainer.mjs +1 -1
  27. package/dist/Classes/TaxRule.js +1 -1
  28. package/dist/Classes/TaxRule.js.map +1 -1
  29. package/dist/Classes/TaxRule.mjs +1 -1
  30. package/dist/{chunk-RBROVHJ4.mjs → chunk-3DSTZDT6.mjs} +2 -2
  31. package/dist/{chunk-RBROVHJ4.mjs.map → chunk-3DSTZDT6.mjs.map} +1 -1
  32. package/dist/{chunk-EP7WVZXC.mjs → chunk-B7VG6LHU.mjs} +2 -2
  33. package/dist/{chunk-EP7WVZXC.mjs.map → chunk-B7VG6LHU.mjs.map} +1 -1
  34. package/dist/chunk-HUDDEQPH.mjs +2 -0
  35. package/dist/chunk-HUDDEQPH.mjs.map +1 -0
  36. package/dist/{chunk-2SGUPNWZ.mjs → chunk-V2IDNBA2.mjs} +2 -2
  37. package/dist/{chunk-2SGUPNWZ.mjs.map → chunk-V2IDNBA2.mjs.map} +1 -1
  38. package/dist/{chunk-CEGQFFYZ.mjs → chunk-X7DG44HI.mjs} +2 -2
  39. package/dist/{chunk-CEGQFFYZ.mjs.map → chunk-X7DG44HI.mjs.map} +1 -1
  40. package/dist/index.d.mts +38 -1
  41. package/dist/index.d.ts +38 -1
  42. package/dist/index.js +2 -2
  43. package/dist/index.js.map +1 -1
  44. package/dist/index.mjs +2 -2
  45. package/dist/index.mjs.map +1 -1
  46. package/package.json +1 -1
  47. package/dist/chunk-LNIZAPER.mjs +0 -2
  48. package/dist/chunk-LNIZAPER.mjs.map +0 -1
@@ -1,2 +1,2 @@
1
- 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var jose=require('jose'),se=require('util'),oe=require('crypto'),y=require('assert');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var se__default=/*#__PURE__*/_interopDefault(se);var oe__default=/*#__PURE__*/_interopDefault(oe);var y__default=/*#__PURE__*/_interopDefault(y);var a=Object.freeze({INVALID_UUID:"Invalid UUID",INVALID_EMAIL:"Invalid Email",INVALID_TOKEN:"Invalid Token",TOKEN_EXPIRED:"Token Expired",INVALID_VERIFIER:"Invalid Verifier",INVALID_PERMISSIONS:"Invalid Permissions",INVALID_AUTH_TYPE:"Invalid Authorization Type",USER_PRIVATE_KEY_NOT_FOUND:"User Private Key Not Found",USER_PUBLIC_KEY_NOT_FOUND:"User Public Key Not Found",ANONYMOUS_PRIVATE_KEY_NOT_FOUND:"Anonymous Private Key Not Found",ANONYMOUS_PUBLIC_KEY_NOT_FOUND:"Anonymous Public Key Not Found",SYSTEM_PRIVATE_KEY_NOT_FOUND:"System Private Key Not Found",SYSTEM_PUBLIC_KEY_NOT_FOUND:"System Public Key Not Found",ADMIN_PRIVATE_KEY_NOT_FOUND:"Admin Private Key Not Found",ADMIN_PUBLIC_KEY_NOT_FOUND:"Admin Public Key Not Found",SECRET_TOKEN_NOT_FOUND:"Secret Token Not Found",ANONYMOUS_SESSION_NOT_ALLOWED:"Anonymous Session Not Allowed",USER_SESSION_NOT_ALLOWED:"User Session Not Allowed",SYSTEM_SESSION_NOT_ALLOWED:"System Session Not Allowed",CDN_SESSION_NOT_ALLOWED:"CDN Session Not Allowed",INTERNAL_SERVER_ERROR:"Internal Server Error",SOMETHING_WENT_WRONG:"Something went wrong",AUTH_CONTEXT_NOT_INITIALIZED:"Auth Context not Initialized"});var E={logException:(r,e)=>{console.error(`Exception Occurred in Function: ${r}, Error: ${E.inspect(e)}`);},logError:(r,e)=>{console.error(`Error Occurred in Function: ${r}, Error: ${E.inspect(e)}`);},logWarning:(r,e)=>{console.warn(`Warning in Function: ${r} - ${E.inspect(e)}`);},logMessage:(r,e)=>{console.log(`Message in Function: ${r} - ${E.inspect(e)}`);},logInvalidPayload:(r,e)=>{console.error(`Invalid Payload received for Function: ${r}, Error: ${E.inspect(e)}`);},inspect:r=>typeof r=="string"?r:se__default.default.inspect(r)},g=E;var M=new Uint8Array(256),U=M.length;function z(){return U>M.length-16&&(oe__default.default.randomFillSync(M),U=0),M.slice(U,U+=16)}var Q=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;function ae(r){return typeof r=="string"&&Q.test(r)}var H=ae;var p=[];for(let r=0;r<256;++r)p.push((r+256).toString(16).slice(1));function L(r,e=0){return p[r[e+0]]+p[r[e+1]]+p[r[e+2]]+p[r[e+3]]+"-"+p[r[e+4]]+p[r[e+5]]+"-"+p[r[e+6]]+p[r[e+7]]+"-"+p[r[e+8]]+p[r[e+9]]+"-"+p[r[e+10]]+p[r[e+11]]+p[r[e+12]]+p[r[e+13]]+p[r[e+14]]+p[r[e+15]]}function ue(r){if(!H(r))throw TypeError("Invalid UUID");let e,t=new Uint8Array(16);return t[0]=(e=parseInt(r.slice(0,8),16))>>>24,t[1]=e>>>16&255,t[2]=e>>>8&255,t[3]=e&255,t[4]=(e=parseInt(r.slice(9,13),16))>>>8,t[5]=e&255,t[6]=(e=parseInt(r.slice(14,18),16))>>>8,t[7]=e&255,t[8]=(e=parseInt(r.slice(19,23),16))>>>8,t[9]=e&255,t[10]=(e=parseInt(r.slice(24,36),16))/1099511627776&255,t[11]=e/4294967296&255,t[12]=e>>>24&255,t[13]=e>>>16&255,t[14]=e>>>8&255,t[15]=e&255,t}var j=ue;function ce(r){r=unescape(encodeURIComponent(r));let e=[];for(let t=0;t<r.length;++t)e.push(r.charCodeAt(t));return e}var le="6ba7b810-9dad-11d1-80b4-00c04fd430c8",de="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function B(r,e,t){function i(n,s,u,m){var o;if(typeof n=="string"&&(n=ce(n)),typeof s=="string"&&(s=j(s)),((o=s)===null||o===void 0?void 0:o.length)!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let l=new Uint8Array(16+n.length);if(l.set(s),l.set(n,s.length),l=t(l),l[6]=l[6]&15|e,l[8]=l[8]&63|128,u){m=m||0;for(let h=0;h<16;++h)u[m+h]=l[h];return u}return L(l)}try{i.name=r;}catch{}return i.DNS=le,i.URL=de,i}var Y={randomUUID:oe__default.default.randomUUID};function ye(r,e,t){if(Y.randomUUID&&!e&&!r)return Y.randomUUID();r=r||{};let i=r.random||(r.rng||z)();if(i[6]=i[6]&15|64,i[8]=i[8]&63|128,e){t=t||0;for(let n=0;n<16;++n)e[t+n]=i[n];return e}return L(i)}var W=ye;function me(r){return Array.isArray(r)?r=Buffer.from(r):typeof r=="string"&&(r=Buffer.from(r,"utf8")),oe__default.default.createHash("sha1").update(r).digest()}var q=me;var he=B("v5",80,q),J=he;var v=class{customFields;version;createdAt;modifiedAt;modifiedBy;constructor(e,t=new Date){this.customFields={...e.customFields},this.version=e.version??1,this.createdAt=e.createdAt&&!isNaN(Date.parse(e.createdAt))?new Date(e.createdAt).toISOString():t.toISOString(),this.modifiedAt=e.modifiedAt&&!isNaN(Date.parse(e.modifiedAt))?new Date(e.modifiedAt).toISOString():t.toISOString(),this.modifiedBy={...e.modifiedBy};}getDetails(){return {customFields:this.getAllCustomFields(),version:this.getVersion(),createdAt:this.getCreatedAt(),modifiedAt:this.getModifiedAt(),modifiedBy:this.getModifiedBy()}}getVersion(){return this.version}getCreatedAt(){return this.createdAt}getCreatedAtTime(){return new Date(this.createdAt).getTime()}getModifiedAt(){return this.modifiedAt}getModifiedAtTime(){return new Date(this.modifiedAt).getTime()}getModifiedBy(){return {...this.modifiedBy}}setModifiedBy(e,t,i,n){this.modifiedBy={id:e,authType:t,requestId:i,lambdaName:n};}getCustomField(e){return this.customFields[e]??null}setCustomField(e,t){this.customFields[e]=t;}getAllCustomFields(){return {...this.customFields}}};var P={"en-IN":"en","kn-IN":"kn"};var X={INR:"\u20B9"},Z={INR:"en-IN"};var K=class extends Error{constructor(e="Failed to parse selection attributes key."){super(`SelectionAttributeParseError: ${e}`),this.name="SelectionAttributeParseError";}};var R=class extends Error{constructor(e="Tax category is not valid."){super(`InvalidTaxCategory: ${e}`),this.name="InvalidTaxCategoryError";}},_=class extends Error{constructor(e="Minimum quantity must be greater than zero."){super(`InvalidMinQuantity: ${e}`),this.name="InvalidMinQuantityError";}},k=class extends Error{constructor(e){super(`InvalidTieredPrice: ${e}`),this.name="InvalidTieredPriceError";}},F=class extends Error{constructor(e="Quantity must be greater than zero."){super(`InvalidQuantity: ${e}`),this.name="InvalidQuantityError";}},$=class extends Error{constructor(e){super(`NoApplicableTier: Quantity ${e} does not meet the minimum purchase requirement.`),this.name="NoApplicableTierError";}};var D=class extends Error{constructor(e="Amount cannot be negative."){super(`InvalidAmount: ${e}`),this.name="InvalidPriceAmountError";}},S=class extends Error{constructor(e="Currency code is required."){super(`InvalidCurrency: ${e}`),this.name="InvalidCurrencyCodeError";}},I=class extends Error{constructor(e="Cannot perform operation on prices with different currencies."){super(`CurrencyMismatch: ${e}`),this.name="CurrencyMismatchError";}},A=class extends Error{constructor(e){super(`InvalidArgument: ${e}`),this.name="InvalidArgumentError";}},w=class extends Error{constructor(e="Invalid image source configuration."){super(`InvalidImageSource: ${e}`),this.name="InvalidImageSourceError";}};var N=class{sources;alt;order;label;constructor(e){if(this.sources={...e.sources},this.alt=e.alt,this.order=e.order,this.label=e.label,!this.sources.original)throw new w("ImageInfoModel cannot be created without an 'original' source URL.")}getSources(){return {...this.sources}}getSource(e){return this.sources[e]||this.sources.original}getAlt(){return this.alt}getOrder(){return this.order}getLabel(){return this.label}setAlt(e){this.alt=e;}setOrder(e){this.order=e;}setLabel(e){this.label=e;}setSource(e,t){if(t===void 0){if(e==="original")throw new w("Cannot remove the 'original' image source.");delete this.sources[e];}else this.sources[e]=t;}getDetails(){return {sources:this.getSources(),alt:this.getAlt(),order:this.getOrder(),label:this.getLabel()}}};var x=class r{amount;currency;constructor(e){if(e.amount<0)throw new D("Amount cannot be negative.");if(!e.currency)throw new S("Currency code is required.");this.amount=e.amount,this.currency=e.currency;}getCurrency(){return this.currency}getAmount(){return this.amount}getDetails(){return {amount:this.amount,currency:this.currency}}compareTo(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot compare prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return this.amount-e.getAmount()}add(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot add prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return new r({amount:this.amount+e.getAmount(),currency:this.currency})}subtract(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot subtract prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return new r({amount:this.amount-e.getAmount(),currency:this.currency})}multiply(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot multiply prices in different currencies.");return new r({amount:this.amount*e.getAmount(),currency:this.currency})}else if(typeof e=="number"&&e>=0)return new r({amount:this.amount*e,currency:this.currency});throw new A("Must be a non-negative number.")}divide(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot divide prices in different currencies.");return new r({amount:this.amount/e.getAmount(),currency:this.currency})}else if(typeof e=="number"&&e>0)return new r({amount:this.amount/e,currency:this.currency});throw new A("Must be a positive number.")}min(...e){if(e.length===0)throw new A("Must provide at least one PriceModel.");return e.reduce((t,i)=>{if(i instanceof r){if(t.getCurrency()!==i.getCurrency())throw new I("Cannot compare prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return t.compareTo(i)<0?t:i})}max(...e){if(e.length===0)throw new A("Must provide at least one PriceModel.");return e.reduce((t,i)=>{if(i instanceof r){if(t.getCurrency()!==i.getCurrency())throw new I("Cannot compare prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return t.compareTo(i)>0?t:i})}zero(){return new r({currency:this.currency,amount:0})}isZero(){return this.amount===0}round(){return new r({currency:this.currency,amount:this.getRoundedAmount()})}getRoundedAmount(){return r.getRoundedAmount(this.amount,this.currency)}getFormattedString(){return r.getFormattedString(this.amount,this.currency)}static getFormattedString(e,t,i={displayAsInteger:!1,style:"currency",currencyDisplay:"symbol"}){let n=Z[t];if(!t||!n)throw new S("Invalid currency code for formatting.");let s=e,u=i.displayAsInteger?0:r.getDecimalPlaces(t),m={style:i.style??"currency",currency:t,signDisplay:"never",currencyDisplay:i.currencyDisplay,minimumFractionDigits:u,maximumFractionDigits:u};i.displayAsInteger&&(s=Math.ceil(s));try{return new Intl.NumberFormat(n,m).format(s)}catch(o){return console.error(`Error formatting price for currency "${t}" and locale "${n}":`,o),`${X[t]??t} ${r.addThousandSeparators(s.toFixed(u))}`}}static getDecimalPlaces(e){switch(e){case"INR":default:return 2}}static addThousandSeparators(e){let t=e.split("."),i=t[0],n=t.length>1?"."+t[1]:"";return i.replace(/\B(?=(\d{3})+(?!\d))/g,",")+n}static getRoundedAmount(e,t){if(e<0)throw new D("Amount cannot be negative for rounding.");if(t===void 0)throw new S("Invalid currency code for rounding.");let i=r.getDecimalPlaces(t),n=Math.pow(10,i);return Math.round(e*n)/n}};var V=class{baseUnitPrice;taxCategory;tiers;constructor(e){let t=new x(e.baseUnitPrice);if(!e.taxCategory)throw new R;let i=(e.tiers??[]).map(o=>({minQuantity:o.minQuantity,unitPrice:new x(o.unitPrice)})).sort((o,l)=>o.minQuantity-l.minQuantity);if(i.some(o=>o.minQuantity<=0))throw new _;let s=i.some(o=>o.unitPrice.getCurrency()!==t.getCurrency()),u=i.some((o,l)=>l>0&&o.unitPrice.compareTo(i[l-1].unitPrice)>0),m=i[0]?.unitPrice.compareTo(t)>0;if(s||u||m)throw new k("Tiers must share the same currency and must not increase in unit price.");this.baseUnitPrice=t,this.taxCategory=e.taxCategory,this.tiers=i;}getBaseUnitPrice(){return this.baseUnitPrice}getTaxCategory(){return this.taxCategory}getTiers(){return this.tiers}getDetails(){return {baseUnitPrice:this.baseUnitPrice.getDetails(),taxCategory:this.taxCategory,tiers:this.tiers.map(e=>({minQuantity:e.minQuantity,unitPrice:e.unitPrice.getDetails()}))}}getApplicableTier(e){if(e<=0)throw new F;for(let t=this.tiers.length-1;t>=0;t--)if(e>=this.tiers[t].minQuantity)return this.tiers[t];throw new $(e)}getMinQuantity(){return this.tiers[0]?.minQuantity??1}getMaxDiscountPercent(){if(!this.tiers.length)return 0;let e=this.tiers[this.tiers.length-1].unitPrice.getAmount(),t=this.baseUnitPrice.getAmount();return (t-e)/t*100}};var O=class r extends v{id;key;sku;name;description;slug;brand;pricing;variants;targetGender;attributes;specifications;categories;isActive;searchTags;static productKeyRegex=/^(?!\s)(?!.*\s$)[A-Z0-9-]{4,16}$/;static generateSelectionAttributesKey(e){return Object.keys(e).filter(i=>e[i]!==void 0&&i.toLowerCase()!=="size").sort().map(i=>e[i].name?`${i}:c+${e[i].name}`:`${i}:${e[i]}`).join("|")}static parseSelectionAttributesKey(e){try{let t={},i=e.split("|");for(let n of i){let[s,u]=n.split(":");u.startsWith("c+")?t[s]={name:u.slice(2)}:t[s]=u;}return t}catch(t){throw new K(t?.message)}}constructor(e,t=new Date){super(e,t),this.id=e.id,this.key=e.key,this.sku=e.sku,this.name={...e.name},this.description={...e.description},this.slug={...e.slug},this.brand=e.brand,this.pricing=Object.keys(e.pricing).reduce((i,n)=>(e.pricing[n]&&(i[n]=new V(e.pricing[n])),i),{}),this.targetGender=e.targetGender,this.attributes=d.deepClone(e.attributes),this.specifications=d.deepClone(e.specifications),this.categories=d.deepClone(e.categories),this.variants=(e.variants||[]).map(i=>({selectionAttributes:i.selectionAttributes,images:{primary:new N(i.images.primary),gallery:(i.images.gallery||[]).map(n=>new N(n))}})),this.isActive=e.isActive,this.searchTags=e.searchTags?d.deepClone(e.searchTags):{en:[]};}getId(){return this.id}getKey(){return this.key}getSku(){return this.sku}getName(e){return e?this.name[e]??this.name[P[e]]??this.name.en:d.deepClone(this.name)}getDescription(e){return e?this.description[e]??this.description[P[e]]??this.description.en:d.deepClone(this.description)}getSlug(e){return e?this.slug[e]??this.slug[P[e]]??this.slug.en:d.deepClone(this.slug)}getBrand(){return this.brand}getPriceDetails(e){return e?this.pricing[e]??null:this.pricing}getAttributes(){return d.deepClone(this.attributes)}getImagesBySelectionAttributes(e){let t=r.generateSelectionAttributesKey(e),i=this.variants.find(n=>r.generateSelectionAttributesKey(n.selectionAttributes)===t);return i?i.images:null}getImages(e,t){switch(t){case"PRIMARY":return this.getImagesBySelectionAttributes(e)?.primary??this.variants[0]?.images?.primary;case"GALLERY":return this.getImagesBySelectionAttributes(e)?.gallery??[];default:return this.getImagesBySelectionAttributes(e)??{primary:this.variants[0]?.images?.primary,gallery:[]}}}getIsActive(){return this.isActive}getTargetGender(){return this.targetGender}getCategories(){return d.deepClone(this.categories)}getSpecifications(e){return e?d.deepClone(this.specifications[e]??this.specifications[P[e]]??this.specifications.en):d.deepClone(this.specifications)}getSearchTags(e){return e?d.deepClone(this.searchTags[e]??this.searchTags[P[e]]??this.searchTags.en):d.deepClone(this.searchTags)}getDetails(){let e=super.getDetails();return {id:this.getId(),key:this.getKey(),sku:this.getSku(),name:this.getName(),description:this.getDescription(),slug:this.getSlug(),brand:this.getBrand(),pricing:Object.keys(this.pricing).reduce((t,i)=>(this.pricing[i]&&(t[i]=this.pricing[i]?.getDetails()),t),{}),attributes:this.getAttributes(),variants:this.variants.map(t=>({selectionAttributes:d.deepClone(t.selectionAttributes),images:{primary:t.images.primary.getDetails(),gallery:t.images.gallery.map(i=>i.getDetails())}})),isActive:this.getIsActive(),targetGender:this.getTargetGender(),categories:this.getCategories(),specifications:this.getSpecifications(),searchTags:this.getSearchTags(),...e}}validateSelectionAttribute(e){let t=r.generateSelectionAttributesKey(e);return this.variants.some(i=>r.generateSelectionAttributesKey(i.selectionAttributes)===t)}validateSize(e){return this.attributes.size.includes(e)}};var fe={isUUID:r=>/^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(r),isEmail:r=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(r),isURL:r=>/^(http|https):\/\/[^ "]+$/.test(r),generateUUID:(r,e)=>e&&r?J(r,e):W(),generateSearchId:(r,e)=>`${r}#${O.generateSelectionAttributesKey(e)}`,getKeyfromSearchId:r=>{let[e,t]=r.split("#");return {key:e,selectionAttribute:t}},deepClone(r){return structuredClone(r)}},d=fe;var Ae={handleException:(r,e,t)=>{e.knownError?(e.logError&&g.logError(r,e),t.status(e.status).json({status:e.status,error:e.error})):e.status&&e.error?(g.logException(r,e),t.status(e.status).json({error:e.errorMessage||JSON.stringify(e.error),status:e.status})):(g.logException(r,e),t.status(500).json({status:500,error:a.INTERNAL_SERVER_ERROR}));},generateResponse:(r,e,t)=>({status:r,data:e,error:t}),generateError:(r,e,t=!0,i=!1)=>({status:r,error:e,knownError:t,logError:i})},T=Ae;var Te=async(r,e,t="GET",i={},n)=>{let s={method:t,headers:{"Content-Type":"application/json",...i}};t!=="GET"&&n&&(s.body=JSON.stringify(n));let u=`${r}${e?"/"+e:""}`,m=u.includes("api.xetile.com")||u.includes("localhost");try{let o=await fetch(u,s);if(!o.ok){let h,f=await o.text();try{h=JSON.parse(f);}catch{h={status:o.status,error:f||o.statusText},g.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${u}. Raw text: ${f}`);}throw {status:o.status,statusText:o.statusText,error:h}}let l=await o.json();return g.logMessage("Fetch",`API call successful: URL-${u}, Status- ${o.status}`),{status:o.status,statusText:o.statusText,data:m?l.data:l}}catch(o){throw g.logError("Fetch",`API call failed: URL-${u}, Status- ${o.status||500}, Error- ${g.inspect(o.error||o)}`),{status:o.status||500,statusText:o.statusText||a.INTERNAL_SERVER_ERROR,error:o.error||{status:o.status||500,error:o.statusText||a.SOMETHING_WENT_WRONG}}}},ee=Te;var C=class r{static instance=null;id;type;token;initializedAt;lambdaName;requestId;constructor(e,t,i,n){this.id=e,this.type=t,this.token=i,this.lambdaName=process.env.AWS_LAMBDA_FUNCTION_NAME,this.initializedAt=new Date;}static getInstance(){return y__default.default(r.instance,a.AUTH_CONTEXT_NOT_INITIALIZED),r.instance}static init(e,t,i,n){return r.instance=new r(e,t,i,n),r.instance}static uninit(){r.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 te={userTokenAge:"30 days",userPrivateKeys:"[]",userPublicKeys:"[]",anonymousTokenAge:"30 days",anonymousPrivateKeys:"[]",anonymousPublicKeys:"[]",systemTokenAge:"5 min",systemPrivateKeys:"[]",systemPublicKeys:"[]",adminTokenAge:"30 days",adminPrivateKeys:"[]",adminPublicKeys:"[]",cdnKeys:"[]"},xe=(s=>(s.ANON="Anon",s.USER="User",s.SYSTEM="System",s.ADMIN="Admin",s.CDN="CDN",s))(xe||{}),re={allowAnonymous:!1,allowSystem:!0,allowUser:!0,allowCDN:!1},G=class{userTokenAge;userPrivateKeys;userPublicKeys;anonymousTokenAge;anonymousPrivateKeys;anonymousPublicKeys;systemTokenAge;systemPrivateKeys;systemPublicKeys;adminTokenAge;adminPrivateKeys;adminPublicKeys;cdnKeys;constructor(e=te){let{userTokenAge:t,userPrivateKeys:i,userPublicKeys:n,anonymousTokenAge:s,anonymousPrivateKeys:u,anonymousPublicKeys:m,systemTokenAge:o,systemPrivateKeys:l,systemPublicKeys:h,adminTokenAge:f,adminPrivateKeys:b,adminPublicKeys:ie,cdnKeys:ne}={...te,...e};this.userTokenAge=t,this.userPrivateKeys=this.parseKeyArray(i,"user private"),this.userPublicKeys=this.parseKeyArray(n,"user public"),this.anonymousTokenAge=s,this.anonymousPrivateKeys=this.parseKeyArray(u,"anonymous private"),this.anonymousPublicKeys=this.parseKeyArray(m,"anonymous public"),this.systemTokenAge=o,this.systemPrivateKeys=this.parseKeyArray(l,"system private"),this.systemPublicKeys=this.parseKeyArray(h,"system public"),this.adminTokenAge=f,this.adminPrivateKeys=this.parseKeyArray(b,"admin private"),this.adminPublicKeys=this.parseKeyArray(ie,"admin public"),this.cdnKeys=this.parseKeyArray(ne,"cdn"),this.logWarnings();}parseKeyArray(e,t){try{let i=JSON.parse(e);return !Array.isArray(i)||!i.every(n=>typeof n=="string")?(g.logError("AuthUtility",`Invalid format for ${t} keys in config: Expected stringified array of strings.`),[]):i}catch(i){return g.logError("AuthUtility",`Failed to parse ${t} keys from config: ${i}`),[]}}logWarnings(){let e=(t,i,n)=>i.length>n&&g.logWarning("AuthUtility",`More than ${n} ${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 n=await jose.importPKCS8(t,"RS256");return await new jose.SignJWT(e).setProtectedHeader({alg:"RS256"}).setExpirationTime(i).setIssuedAt().sign(n)}async verifySignedJWT(e,t,i){for(let n=t.length-1;n>=0;n--)try{let s=await jose.importSPKI(t[n],"RS256");return (await jose.jwtVerify(e,s,{clockTolerance:30,maxTokenAge:i})).payload}catch(s){if(n===0)throw s;continue}throw new Error(a.INVALID_TOKEN)}async createAnonymousToken(e,t){y__default.default(this.anonymousPrivateKeys.length,a.ANONYMOUS_PRIVATE_KEY_NOT_FOUND),y__default.default(d.isUUID(e),a.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){y__default.default(this.anonymousPublicKeys.length,a.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.anonymousPublicKeys,this.anonymousTokenAge);return y__default.default(t.type==="Anon",a.INVALID_AUTH_TYPE),t}async createUserToken(e,t){y__default.default(this.userPrivateKeys.length,a.USER_PRIVATE_KEY_NOT_FOUND),y__default.default(d.isUUID(e),a.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){y__default.default(this.userPublicKeys.length,a.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.userPublicKeys,this.userTokenAge);return y__default.default(t.type==="User",a.INVALID_AUTH_TYPE),t}async createSystemToken(e,t){y__default.default(this.systemPrivateKeys.length,a.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){y__default.default(this.systemPublicKeys.length,a.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.systemPublicKeys,this.systemTokenAge);return y__default.default(t.type==="System",a.INVALID_AUTH_TYPE),t}async createAdminToken(e,t,i){y__default.default(this.adminPrivateKeys.length,a.ADMIN_PRIVATE_KEY_NOT_FOUND),y__default.default(d.isEmail(e),a.INVALID_EMAIL),y__default.default(d.isURL(t),a.INVALID_VERIFIER);let n={id:e,type:"Admin",verifier:t,...i};return await this.createSignedJWT(n,this.adminPrivateKeys[this.adminPrivateKeys.length-1],this.adminTokenAge)}async verifyAdminToken(e,t,i){y__default.default(this.adminPublicKeys.length,a.ADMIN_PUBLIC_KEY_NOT_FOUND);let n=await this.verifySignedJWT(e,this.adminPublicKeys,this.adminTokenAge);if(y__default.default(n.type==="Admin",a.INVALID_AUTH_TYPE),i){let s=await ee(n.verifier,"","POST",{},{token:e,permissions:t});if(y__default.default(s.data.isTokenValid===!0,a.INVALID_TOKEN),s.data.hasPermissions!==!0)throw T.generateError(403,a.INVALID_PERMISSIONS)}return n}async verifyCDNToken(e){return y__default.default(this.cdnKeys.includes(e),a.INVALID_TOKEN),{id:e,type:"CDN"}}AuthMiddleware(e=re,t=[]){let{allowAnonymous:i,allowSystem:n,allowUser:s,allowCDN:u}={...re,...e};return async(m,o,l)=>{try{let[h,f]=m.get("Authorization")?.split(" ")||[];if(!f)throw new Error(a.INVALID_TOKEN);let b;switch(h){case"Anon":if(!i)throw T.generateError(403,a.ANONYMOUS_SESSION_NOT_ALLOWED);b=await this.verifyAnonymousToken(f);break;case"User":if(!s)throw T.generateError(403,a.USER_SESSION_NOT_ALLOWED);b=await this.verifyUserToken(f);break;case"System":if(!n)throw T.generateError(403,a.SYSTEM_SESSION_NOT_ALLOWED);b=await this.verifySystemToken(f);break;case"Admin":b=await this.verifyAdminToken(f,t,!0);break;case"CDN":if(!u)throw T.generateError(403,a.CDN_SESSION_NOT_ALLOWED);b=await this.verifyCDNToken(f);break;default:throw T.generateError(403,a.INVALID_AUTH_TYPE)}l();}catch(h){g.logError("AuthMiddleware",h),T.handleException("AuthMiddleware",T.generateError(401,h.error||a.TOKEN_EXPIRED,!0),o);}}}decodeJWTPayloadWithJose(e){if(!e||typeof e!="string")return g.logError("AuthContextMiddleware","Invalid token provided for decoding."),null;try{return jose.decodeJwt(e)}catch(t){return g.logError("AuthContextMiddleware",`Failed to decode JWT payload: ${t}`),null}}AuthContextMiddleware(){return async(e,t,i)=>{try{let[n,s]=e.get("Authorization")?.split(" ")||[],u=n==="CDN"?{id:s,type:"CDN"}:n?this.decodeJWTPayloadWithJose(s):{},m=C.init(u?.id||s,u?.type||n,s,e.get("x-request-id"));g.logMessage("AuthContextMiddleware",`AuthContext initialized: ${m.getType()||"No-Type"} - ${m.getId()||"No-Id"}`),t.on("finish",()=>{g.logMessage("AuthContextMiddleware","Uninitializing AuthContext"),C.uninit();}),i();}catch(n){g.logError("AuthContextMiddleware",n),T.handleException("AuthContextMiddleware",T.generateError(500,n.error||a.INTERNAL_SERVER_ERROR,!0),t);}}}},Ar=G;exports.AuthContext=C;exports.AuthType=xe;exports.DefaultAuthMiddlewareConfig=re;exports.DefaultAuthUtilityConfig=te;exports.default=Ar;//# sourceMappingURL=index.js.map
1
+ 'use strict';Object.defineProperty(exports,'__esModule',{value:true});var jose=require('jose'),se=require('util'),oe=require('crypto'),y=require('assert');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var se__default=/*#__PURE__*/_interopDefault(se);var oe__default=/*#__PURE__*/_interopDefault(oe);var y__default=/*#__PURE__*/_interopDefault(y);var a=Object.freeze({INVALID_UUID:"Invalid UUID",INVALID_EMAIL:"Invalid Email",INVALID_TOKEN:"Invalid Token",TOKEN_EXPIRED:"Token Expired",INVALID_VERIFIER:"Invalid Verifier",INVALID_PERMISSIONS:"Invalid Permissions",INVALID_AUTH_TYPE:"Invalid Authorization Type",USER_PRIVATE_KEY_NOT_FOUND:"User Private Key Not Found",USER_PUBLIC_KEY_NOT_FOUND:"User Public Key Not Found",ANONYMOUS_PRIVATE_KEY_NOT_FOUND:"Anonymous Private Key Not Found",ANONYMOUS_PUBLIC_KEY_NOT_FOUND:"Anonymous Public Key Not Found",SYSTEM_PRIVATE_KEY_NOT_FOUND:"System Private Key Not Found",SYSTEM_PUBLIC_KEY_NOT_FOUND:"System Public Key Not Found",ADMIN_PRIVATE_KEY_NOT_FOUND:"Admin Private Key Not Found",ADMIN_PUBLIC_KEY_NOT_FOUND:"Admin Public Key Not Found",SECRET_TOKEN_NOT_FOUND:"Secret Token Not Found",ANONYMOUS_SESSION_NOT_ALLOWED:"Anonymous Session Not Allowed",USER_SESSION_NOT_ALLOWED:"User Session Not Allowed",SYSTEM_SESSION_NOT_ALLOWED:"System Session Not Allowed",CDN_SESSION_NOT_ALLOWED:"CDN Session Not Allowed",INTERNAL_SERVER_ERROR:"Internal Server Error",SOMETHING_WENT_WRONG:"Something went wrong",AUTH_CONTEXT_NOT_INITIALIZED:"Auth Context not Initialized"});var E={logException:(r,e)=>{console.error(`Exception Occurred in Function: ${r}, Error: ${E.inspect(e)}`);},logError:(r,e)=>{console.error(`Error Occurred in Function: ${r}, Error: ${E.inspect(e)}`);},logWarning:(r,e)=>{console.warn(`Warning in Function: ${r} - ${E.inspect(e)}`);},logMessage:(r,e)=>{console.log(`Message in Function: ${r} - ${E.inspect(e)}`);},logInvalidPayload:(r,e)=>{console.error(`Invalid Payload received for Function: ${r}, Error: ${E.inspect(e)}`);},inspect:r=>typeof r=="string"?r:se__default.default.inspect(r)},g=E;var M=new Uint8Array(256),U=M.length;function z(){return U>M.length-16&&(oe__default.default.randomFillSync(M),U=0),M.slice(U,U+=16)}var Q=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;function ae(r){return typeof r=="string"&&Q.test(r)}var H=ae;var p=[];for(let r=0;r<256;++r)p.push((r+256).toString(16).slice(1));function L(r,e=0){return p[r[e+0]]+p[r[e+1]]+p[r[e+2]]+p[r[e+3]]+"-"+p[r[e+4]]+p[r[e+5]]+"-"+p[r[e+6]]+p[r[e+7]]+"-"+p[r[e+8]]+p[r[e+9]]+"-"+p[r[e+10]]+p[r[e+11]]+p[r[e+12]]+p[r[e+13]]+p[r[e+14]]+p[r[e+15]]}function ue(r){if(!H(r))throw TypeError("Invalid UUID");let e,t=new Uint8Array(16);return t[0]=(e=parseInt(r.slice(0,8),16))>>>24,t[1]=e>>>16&255,t[2]=e>>>8&255,t[3]=e&255,t[4]=(e=parseInt(r.slice(9,13),16))>>>8,t[5]=e&255,t[6]=(e=parseInt(r.slice(14,18),16))>>>8,t[7]=e&255,t[8]=(e=parseInt(r.slice(19,23),16))>>>8,t[9]=e&255,t[10]=(e=parseInt(r.slice(24,36),16))/1099511627776&255,t[11]=e/4294967296&255,t[12]=e>>>24&255,t[13]=e>>>16&255,t[14]=e>>>8&255,t[15]=e&255,t}var j=ue;function ce(r){r=unescape(encodeURIComponent(r));let e=[];for(let t=0;t<r.length;++t)e.push(r.charCodeAt(t));return e}var le="6ba7b810-9dad-11d1-80b4-00c04fd430c8",de="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function B(r,e,t){function i(n,s,u,m){var o;if(typeof n=="string"&&(n=ce(n)),typeof s=="string"&&(s=j(s)),((o=s)===null||o===void 0?void 0:o.length)!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let l=new Uint8Array(16+n.length);if(l.set(s),l.set(n,s.length),l=t(l),l[6]=l[6]&15|e,l[8]=l[8]&63|128,u){m=m||0;for(let h=0;h<16;++h)u[m+h]=l[h];return u}return L(l)}try{i.name=r;}catch{}return i.DNS=le,i.URL=de,i}var Y={randomUUID:oe__default.default.randomUUID};function ye(r,e,t){if(Y.randomUUID&&!e&&!r)return Y.randomUUID();r=r||{};let i=r.random||(r.rng||z)();if(i[6]=i[6]&15|64,i[8]=i[8]&63|128,e){t=t||0;for(let n=0;n<16;++n)e[t+n]=i[n];return e}return L(i)}var W=ye;function me(r){return Array.isArray(r)?r=Buffer.from(r):typeof r=="string"&&(r=Buffer.from(r,"utf8")),oe__default.default.createHash("sha1").update(r).digest()}var q=me;var he=B("v5",80,q),J=he;var D=class{customFields;version;createdAt;modifiedAt;modifiedBy;constructor(e,t=new Date){this.customFields={...e.customFields},this.version=e.version??1,this.createdAt=e.createdAt&&!isNaN(Date.parse(e.createdAt))?new Date(e.createdAt).toISOString():t.toISOString(),this.modifiedAt=e.modifiedAt&&!isNaN(Date.parse(e.modifiedAt))?new Date(e.modifiedAt).toISOString():t.toISOString(),this.modifiedBy={...e.modifiedBy};}getDetails(){return {customFields:this.getAllCustomFields(),version:this.getVersion(),createdAt:this.getCreatedAt(),modifiedAt:this.getModifiedAt(),modifiedBy:this.getModifiedBy()}}getVersion(){return this.version}getCreatedAt(){return this.createdAt}getCreatedAtTime(){return new Date(this.createdAt).getTime()}getModifiedAt(){return this.modifiedAt}getModifiedAtTime(){return new Date(this.modifiedAt).getTime()}getModifiedBy(){return {...this.modifiedBy}}setModifiedBy(e,t,i,n){this.modifiedBy={id:e,authType:t,requestId:i,lambdaName:n};}getCustomField(e){return this.customFields[e]??null}setCustomField(e,t){this.customFields[e]=t;}getAllCustomFields(){return {...this.customFields}}};var P={"en-IN":"en","kn-IN":"kn"};var Z={INR:"\u20B9"},X={INR:"en-IN"};var K=class extends Error{constructor(e="Failed to parse selection attributes key."){super(`SelectionAttributeParseError: ${e}`),this.name="SelectionAttributeParseError";}};var R=class extends Error{constructor(e="Tax category is not valid."){super(`InvalidTaxCategory: ${e}`),this.name="InvalidTaxCategoryError";}},_=class extends Error{constructor(e="Minimum quantity must be greater than zero."){super(`InvalidMinQuantity: ${e}`),this.name="InvalidMinQuantityError";}},k=class extends Error{constructor(e){super(`InvalidTieredPrice: ${e}`),this.name="InvalidTieredPriceError";}},F=class extends Error{constructor(e="Quantity must be greater than zero."){super(`InvalidQuantity: ${e}`),this.name="InvalidQuantityError";}},$=class extends Error{constructor(e){super(`NoApplicableTier: Quantity ${e} does not meet the minimum purchase requirement.`),this.name="NoApplicableTierError";}};var v=class extends Error{constructor(e="Amount cannot be negative."){super(`InvalidAmount: ${e}`),this.name="InvalidPriceAmountError";}},S=class extends Error{constructor(e="Currency code is required."){super(`InvalidCurrency: ${e}`),this.name="InvalidCurrencyCodeError";}},I=class extends Error{constructor(e="Cannot perform operation on prices with different currencies."){super(`CurrencyMismatch: ${e}`),this.name="CurrencyMismatchError";}},A=class extends Error{constructor(e){super(`InvalidArgument: ${e}`),this.name="InvalidArgumentError";}},w=class extends Error{constructor(e="Invalid image source configuration."){super(`InvalidImageSource: ${e}`),this.name="InvalidImageSourceError";}};var N=class{sources;alt;order;label;constructor(e){if(this.sources={...e.sources},this.alt=e.alt,this.order=e.order,this.label=e.label,!this.sources.original)throw new w("ImageInfoModel cannot be created without an 'original' source URL.")}getSources(){return {...this.sources}}getSource(e){return this.sources[e]||this.sources.original}getAlt(){return this.alt}getOrder(){return this.order}getLabel(){return this.label}setAlt(e){this.alt=e;}setOrder(e){this.order=e;}setLabel(e){this.label=e;}setSource(e,t){if(t===void 0){if(e==="original")throw new w("Cannot remove the 'original' image source.");delete this.sources[e];}else this.sources[e]=t;}getDetails(){return {sources:this.getSources(),alt:this.getAlt(),order:this.getOrder(),label:this.getLabel()}}};var x=class r{amount;currency;constructor(e){if(e.amount<0)throw new v("Amount cannot be negative.");if(!e.currency)throw new S("Currency code is required.");this.amount=e.amount,this.currency=e.currency;}getCurrency(){return this.currency}getAmount(){return this.amount}getDetails(){return {amount:this.amount,currency:this.currency}}compareTo(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot compare prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return this.amount-e.getAmount()}add(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot add prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return new r({amount:this.amount+e.getAmount(),currency:this.currency})}subtract(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot subtract prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return new r({amount:this.amount-e.getAmount(),currency:this.currency})}multiply(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot multiply prices in different currencies.");return new r({amount:this.amount*e.getAmount(),currency:this.currency})}else if(typeof e=="number"&&e>=0)return new r({amount:this.amount*e,currency:this.currency});throw new A("Must be a non-negative number.")}divide(e){if(e instanceof r){if(this.currency!==e.getCurrency())throw new I("Cannot divide prices in different currencies.");return new r({amount:this.amount/e.getAmount(),currency:this.currency})}else if(typeof e=="number"&&e>0)return new r({amount:this.amount/e,currency:this.currency});throw new A("Must be a positive number.")}min(...e){if(e.length===0)throw new A("Must provide at least one PriceModel.");return e.reduce((t,i)=>{if(i instanceof r){if(t.getCurrency()!==i.getCurrency())throw new I("Cannot compare prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return t.compareTo(i)<0?t:i})}max(...e){if(e.length===0)throw new A("Must provide at least one PriceModel.");return e.reduce((t,i)=>{if(i instanceof r){if(t.getCurrency()!==i.getCurrency())throw new I("Cannot compare prices in different currencies.")}else throw new A("Must be a PriceModel instance.");return t.compareTo(i)>0?t:i})}zero(){return new r({currency:this.currency,amount:0})}isZero(){return this.amount===0}round(){return new r({currency:this.currency,amount:this.getRoundedAmount()})}getRoundedAmount(){return r.getRoundedAmount(this.amount,this.currency)}getFormattedString(){return r.getFormattedString(this.amount,this.currency)}static getFormattedString(e,t,i={displayAsInteger:!1,style:"currency",currencyDisplay:"symbol"}){let n=X[t];if(!t||!n)throw new S("Invalid currency code for formatting.");let s=e,u=i.displayAsInteger?0:r.getDecimalPlaces(t),m={style:i.style??"currency",currency:t,signDisplay:"never",currencyDisplay:i.currencyDisplay,minimumFractionDigits:u,maximumFractionDigits:u};i.displayAsInteger&&(s=Math.ceil(s));try{return new Intl.NumberFormat(n,m).format(s)}catch(o){return console.error(`Error formatting price for currency "${t}" and locale "${n}":`,o),`${Z[t]??t} ${r.addThousandSeparators(s.toFixed(u))}`}}static getDecimalPlaces(e){switch(e){case"INR":default:return 2}}static addThousandSeparators(e){let t=e.split("."),i=t[0],n=t.length>1?"."+t[1]:"";return i.replace(/\B(?=(\d{3})+(?!\d))/g,",")+n}static getRoundedAmount(e,t){if(e<0)throw new v("Amount cannot be negative for rounding.");if(t===void 0)throw new S("Invalid currency code for rounding.");let i=r.getDecimalPlaces(t),n=Math.pow(10,i);return Math.round(e*n)/n}};var V=class{baseUnitPrice;taxCategory;tiers;constructor(e){let t=new x(e.baseUnitPrice);if(!e.taxCategory)throw new R;let i=(e.tiers??[]).map(o=>({minQuantity:o.minQuantity,unitPrice:new x(o.unitPrice)})).sort((o,l)=>o.minQuantity-l.minQuantity);if(i.some(o=>o.minQuantity<=0))throw new _;let s=i.some(o=>o.unitPrice.getCurrency()!==t.getCurrency()),u=i.some((o,l)=>l>0&&o.unitPrice.compareTo(i[l-1].unitPrice)>0),m=i[0]?.unitPrice.compareTo(t)>0;if(s||u||m)throw new k("Tiers must share the same currency and must not increase in unit price.");this.baseUnitPrice=t,this.taxCategory=e.taxCategory,this.tiers=i;}getBaseUnitPrice(){return this.baseUnitPrice}getTaxCategory(){return this.taxCategory}getTiers(){return this.tiers}getDetails(){return {baseUnitPrice:this.baseUnitPrice.getDetails(),taxCategory:this.taxCategory,tiers:this.tiers.map(e=>({minQuantity:e.minQuantity,unitPrice:e.unitPrice.getDetails()}))}}getApplicableTier(e){if(e<=0)throw new F;for(let t=this.tiers.length-1;t>=0;t--)if(e>=this.tiers[t].minQuantity)return this.tiers[t];throw new $(e)}getMinQuantity(){return this.tiers[0]?.minQuantity??1}getMaxDiscountPercent(){if(!this.tiers.length)return 0;let e=this.tiers[this.tiers.length-1].unitPrice.getAmount(),t=this.baseUnitPrice.getAmount();return (t-e)/t*100}};var O=class r extends D{id;key;name;description;slug;brand;pricing;variants;targetGender;attributes;specifications;categories;isActive;searchTags;static productKeyRegex=/^(?!\s)(?!.*\s$)[A-Z0-9-]{4,16}$/;static productSKURegex=/^(?!\s)(?!.*\s$)[A-Z0-9-]{4,16}$/;static generateSelectionAttributesKey(e){return Object.keys(e).filter(i=>e[i]!==void 0&&i.toLowerCase()!=="size").sort().map(i=>e[i].name?`${i}:c+${e[i].name}`:`${i}:${e[i]}`).join("|")}static parseSelectionAttributesKey(e){try{let t={},i=e.split("|");for(let n of i){let[s,u]=n.split(":");u.startsWith("c+")?t[s]={name:u.slice(2)}:t[s]=u;}return t}catch(t){throw new K(t?.message)}}constructor(e,t=new Date){super(e,t),this.id=e.id,this.key=e.key,this.name={...e.name},this.description={...e.description},this.slug={...e.slug},this.brand=e.brand,this.pricing=Object.keys(e.pricing).reduce((i,n)=>(e.pricing[n]&&(i[n]=new V(e.pricing[n])),i),{}),this.targetGender=e.targetGender,this.attributes=d.deepClone(e.attributes),this.specifications=d.deepClone(e.specifications),this.categories=d.deepClone(e.categories),this.variants=(e.variants||[]).map(i=>({sku:i.sku,selectionAttributes:i.selectionAttributes,images:{primary:new N(i.images.primary),gallery:(i.images.gallery||[]).map(n=>new N(n))}})),this.isActive=e.isActive,this.searchTags=e.searchTags?d.deepClone(e.searchTags):{en:[]};}getId(){return this.id}getKey(){return this.key}getName(e){return e?this.name[e]??this.name[P[e]]??this.name.en:d.deepClone(this.name)}getDescription(e){return e?this.description[e]??this.description[P[e]]??this.description.en:d.deepClone(this.description)}getSlug(e){return e?this.slug[e]??this.slug[P[e]]??this.slug.en:d.deepClone(this.slug)}getBrand(){return this.brand}getPriceDetails(e){return e?this.pricing[e]??null:this.pricing}getAttributes(){return d.deepClone(this.attributes)}getVariants(){return this.variants.map(e=>({sku:e.sku,selectionAttributes:e.selectionAttributes,images:{primary:e.images.primary,gallery:e.images.gallery}}))}getImagesBySelectionAttributes(e){let t=r.generateSelectionAttributesKey(e),i=this.variants.find(n=>r.generateSelectionAttributesKey(n.selectionAttributes)===t);return i?i.images:null}getImages(e,t){switch(t){case"PRIMARY":return this.getImagesBySelectionAttributes(e)?.primary??this.variants[0]?.images?.primary;case"GALLERY":return this.getImagesBySelectionAttributes(e)?.gallery??[];default:return this.getImagesBySelectionAttributes(e)??{primary:this.variants[0]?.images?.primary,gallery:[]}}}getIsActive(){return this.isActive}getTargetGender(){return this.targetGender}getCategories(){return d.deepClone(this.categories)}getSpecifications(e){return e?d.deepClone(this.specifications[e]??this.specifications[P[e]]??this.specifications.en):d.deepClone(this.specifications)}getSearchTags(e){return e?d.deepClone(this.searchTags[e]??this.searchTags[P[e]]??this.searchTags.en):d.deepClone(this.searchTags)}getDetails(){let e=super.getDetails();return {id:this.getId(),key:this.getKey(),name:this.getName(),description:this.getDescription(),slug:this.getSlug(),brand:this.getBrand(),pricing:Object.keys(this.pricing).reduce((t,i)=>(this.pricing[i]&&(t[i]=this.pricing[i]?.getDetails()),t),{}),attributes:this.getAttributes(),variants:this.variants.map(t=>({sku:t.sku,selectionAttributes:d.deepClone(t.selectionAttributes),images:{primary:t.images.primary.getDetails(),gallery:t.images.gallery.map(i=>i.getDetails())}})),isActive:this.getIsActive(),targetGender:this.getTargetGender(),categories:this.getCategories(),specifications:this.getSpecifications(),searchTags:this.getSearchTags(),...e}}validateSelectionAttribute(e){let t=r.generateSelectionAttributesKey(e);return this.variants.some(i=>r.generateSelectionAttributesKey(i.selectionAttributes)===t)}validateSize(e){return this.attributes.size.includes(e)}};var fe={isUUID:r=>/^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(r),isEmail:r=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(r),isURL:r=>/^(http|https):\/\/[^ "]+$/.test(r),generateUUID:(r,e)=>e&&r?J(r,e):W(),generateSearchId:(r,e)=>`${r}#${O.generateSelectionAttributesKey(e)}`,getKeyfromSearchId:r=>{let[e,t]=r.split("#");return {key:e,selectionAttribute:t}},deepClone(r){return structuredClone(r)}},d=fe;var Ae={handleException:(r,e,t)=>{e.knownError?(e.logError&&g.logError(r,e),t.status(e.status).json({status:e.status,error:e.error})):e.status&&e.error?(g.logException(r,e),t.status(e.status).json({error:e.errorMessage||JSON.stringify(e.error),status:e.status})):(g.logException(r,e),t.status(500).json({status:500,error:a.INTERNAL_SERVER_ERROR}));},generateResponse:(r,e,t)=>({status:r,data:e,error:t}),generateError:(r,e,t=!0,i=!1)=>({status:r,error:e,knownError:t,logError:i})},T=Ae;var Te=async(r,e,t="GET",i={},n)=>{let s={method:t,headers:{"Content-Type":"application/json",...i}};t!=="GET"&&n&&(s.body=JSON.stringify(n));let u=`${r}${e?"/"+e:""}`,m=u.includes("api.xetile.com")||u.includes("localhost");try{let o=await fetch(u,s);if(!o.ok){let h,f=await o.text();try{h=JSON.parse(f);}catch{h={status:o.status,error:f||o.statusText},g.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${u}. Raw text: ${f}`);}throw {status:o.status,statusText:o.statusText,error:h}}let l=await o.json();return g.logMessage("Fetch",`API call successful: URL-${u}, Status- ${o.status}`),{status:o.status,statusText:o.statusText,data:m?l.data:l}}catch(o){throw g.logError("Fetch",`API call failed: URL-${u}, Status- ${o.status||500}, Error- ${g.inspect(o.error||o)}`),{status:o.status||500,statusText:o.statusText||a.INTERNAL_SERVER_ERROR,error:o.error||{status:o.status||500,error:o.statusText||a.SOMETHING_WENT_WRONG}}}},ee=Te;var C=class r{static instance=null;id;type;token;initializedAt;lambdaName;requestId;constructor(e,t,i,n){this.id=e,this.type=t,this.token=i,this.lambdaName=process.env.AWS_LAMBDA_FUNCTION_NAME,this.initializedAt=new Date;}static getInstance(){return y__default.default(r.instance,a.AUTH_CONTEXT_NOT_INITIALIZED),r.instance}static init(e,t,i,n){return r.instance=new r(e,t,i,n),r.instance}static uninit(){r.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 te={userTokenAge:"30 days",userPrivateKeys:"[]",userPublicKeys:"[]",anonymousTokenAge:"30 days",anonymousPrivateKeys:"[]",anonymousPublicKeys:"[]",systemTokenAge:"5 min",systemPrivateKeys:"[]",systemPublicKeys:"[]",adminTokenAge:"30 days",adminPrivateKeys:"[]",adminPublicKeys:"[]",cdnKeys:"[]"},xe=(s=>(s.ANON="Anon",s.USER="User",s.SYSTEM="System",s.ADMIN="Admin",s.CDN="CDN",s))(xe||{}),re={allowAnonymous:!1,allowSystem:!0,allowUser:!0,allowCDN:!1},G=class{userTokenAge;userPrivateKeys;userPublicKeys;anonymousTokenAge;anonymousPrivateKeys;anonymousPublicKeys;systemTokenAge;systemPrivateKeys;systemPublicKeys;adminTokenAge;adminPrivateKeys;adminPublicKeys;cdnKeys;constructor(e=te){let{userTokenAge:t,userPrivateKeys:i,userPublicKeys:n,anonymousTokenAge:s,anonymousPrivateKeys:u,anonymousPublicKeys:m,systemTokenAge:o,systemPrivateKeys:l,systemPublicKeys:h,adminTokenAge:f,adminPrivateKeys:b,adminPublicKeys:ie,cdnKeys:ne}={...te,...e};this.userTokenAge=t,this.userPrivateKeys=this.parseKeyArray(i,"user private"),this.userPublicKeys=this.parseKeyArray(n,"user public"),this.anonymousTokenAge=s,this.anonymousPrivateKeys=this.parseKeyArray(u,"anonymous private"),this.anonymousPublicKeys=this.parseKeyArray(m,"anonymous public"),this.systemTokenAge=o,this.systemPrivateKeys=this.parseKeyArray(l,"system private"),this.systemPublicKeys=this.parseKeyArray(h,"system public"),this.adminTokenAge=f,this.adminPrivateKeys=this.parseKeyArray(b,"admin private"),this.adminPublicKeys=this.parseKeyArray(ie,"admin public"),this.cdnKeys=this.parseKeyArray(ne,"cdn"),this.logWarnings();}parseKeyArray(e,t){try{let i=JSON.parse(e);return !Array.isArray(i)||!i.every(n=>typeof n=="string")?(g.logError("AuthUtility",`Invalid format for ${t} keys in config: Expected stringified array of strings.`),[]):i}catch(i){return g.logError("AuthUtility",`Failed to parse ${t} keys from config: ${i}`),[]}}logWarnings(){let e=(t,i,n)=>i.length>n&&g.logWarning("AuthUtility",`More than ${n} ${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 n=await jose.importPKCS8(t,"RS256");return await new jose.SignJWT(e).setProtectedHeader({alg:"RS256"}).setExpirationTime(i).setIssuedAt().sign(n)}async verifySignedJWT(e,t,i){for(let n=t.length-1;n>=0;n--)try{let s=await jose.importSPKI(t[n],"RS256");return (await jose.jwtVerify(e,s,{clockTolerance:30,maxTokenAge:i})).payload}catch(s){if(n===0)throw s;continue}throw new Error(a.INVALID_TOKEN)}async createAnonymousToken(e,t){y__default.default(this.anonymousPrivateKeys.length,a.ANONYMOUS_PRIVATE_KEY_NOT_FOUND),y__default.default(d.isUUID(e),a.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){y__default.default(this.anonymousPublicKeys.length,a.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.anonymousPublicKeys,this.anonymousTokenAge);return y__default.default(t.type==="Anon",a.INVALID_AUTH_TYPE),t}async createUserToken(e,t){y__default.default(this.userPrivateKeys.length,a.USER_PRIVATE_KEY_NOT_FOUND),y__default.default(d.isUUID(e),a.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){y__default.default(this.userPublicKeys.length,a.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.userPublicKeys,this.userTokenAge);return y__default.default(t.type==="User",a.INVALID_AUTH_TYPE),t}async createSystemToken(e,t){y__default.default(this.systemPrivateKeys.length,a.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){y__default.default(this.systemPublicKeys.length,a.USER_PUBLIC_KEY_NOT_FOUND);let t=await this.verifySignedJWT(e,this.systemPublicKeys,this.systemTokenAge);return y__default.default(t.type==="System",a.INVALID_AUTH_TYPE),t}async createAdminToken(e,t,i){y__default.default(this.adminPrivateKeys.length,a.ADMIN_PRIVATE_KEY_NOT_FOUND),y__default.default(d.isEmail(e),a.INVALID_EMAIL),y__default.default(d.isURL(t),a.INVALID_VERIFIER);let n={id:e,type:"Admin",verifier:t,...i};return await this.createSignedJWT(n,this.adminPrivateKeys[this.adminPrivateKeys.length-1],this.adminTokenAge)}async verifyAdminToken(e,t,i){y__default.default(this.adminPublicKeys.length,a.ADMIN_PUBLIC_KEY_NOT_FOUND);let n=await this.verifySignedJWT(e,this.adminPublicKeys,this.adminTokenAge);if(y__default.default(n.type==="Admin",a.INVALID_AUTH_TYPE),i){let s=await ee(n.verifier,"","POST",{},{token:e,permissions:t});if(y__default.default(s.data.isTokenValid===!0,a.INVALID_TOKEN),s.data.hasPermissions!==!0)throw T.generateError(403,a.INVALID_PERMISSIONS)}return n}async verifyCDNToken(e){return y__default.default(this.cdnKeys.includes(e),a.INVALID_TOKEN),{id:e,type:"CDN"}}AuthMiddleware(e=re,t=[]){let{allowAnonymous:i,allowSystem:n,allowUser:s,allowCDN:u}={...re,...e};return async(m,o,l)=>{try{let[h,f]=m.get("Authorization")?.split(" ")||[];if(!f)throw new Error(a.INVALID_TOKEN);let b;switch(h){case"Anon":if(!i)throw T.generateError(403,a.ANONYMOUS_SESSION_NOT_ALLOWED);b=await this.verifyAnonymousToken(f);break;case"User":if(!s)throw T.generateError(403,a.USER_SESSION_NOT_ALLOWED);b=await this.verifyUserToken(f);break;case"System":if(!n)throw T.generateError(403,a.SYSTEM_SESSION_NOT_ALLOWED);b=await this.verifySystemToken(f);break;case"Admin":b=await this.verifyAdminToken(f,t,!0);break;case"CDN":if(!u)throw T.generateError(403,a.CDN_SESSION_NOT_ALLOWED);b=await this.verifyCDNToken(f);break;default:throw T.generateError(403,a.INVALID_AUTH_TYPE)}l();}catch(h){g.logError("AuthMiddleware",h),T.handleException("AuthMiddleware",T.generateError(401,h.error||a.TOKEN_EXPIRED,!0),o);}}}decodeJWTPayloadWithJose(e){if(!e||typeof e!="string")return g.logError("AuthContextMiddleware","Invalid token provided for decoding."),null;try{return jose.decodeJwt(e)}catch(t){return g.logError("AuthContextMiddleware",`Failed to decode JWT payload: ${t}`),null}}AuthContextMiddleware(){return async(e,t,i)=>{try{let[n,s]=e.get("Authorization")?.split(" ")||[],u=n==="CDN"?{id:s,type:"CDN"}:n?this.decodeJWTPayloadWithJose(s):{},m=C.init(u?.id||s,u?.type||n,s,e.get("x-request-id"));g.logMessage("AuthContextMiddleware",`AuthContext initialized: ${m.getType()||"No-Type"} - ${m.getId()||"No-Id"}`),t.on("finish",()=>{g.logMessage("AuthContextMiddleware","Uninitializing AuthContext"),C.uninit();}),i();}catch(n){g.logError("AuthContextMiddleware",n),T.handleException("AuthContextMiddleware",T.generateError(500,n.error||a.INTERNAL_SERVER_ERROR,!0),t);}}}},Ar=G;exports.AuthContext=C;exports.AuthType=xe;exports.DefaultAuthMiddlewareConfig=re;exports.DefaultAuthUtilityConfig=te;exports.default=Ar;//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map