b23-lib 1.8.3 → 1.8.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Auth/index.js +1 -1
- package/dist/Auth/index.js.map +1 -1
- package/dist/Auth/index.mjs +1 -1
- package/dist/chunk-CKUUUEWT.mjs +2 -0
- package/dist/chunk-CKUUUEWT.mjs.map +1 -0
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -1
- package/package.json +1 -1
- package/dist/chunk-6S4JI32B.mjs +0 -2
- package/dist/chunk-6S4JI32B.mjs.map +0 -1
package/dist/Auth/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var jose=require('jose'),V=require('util'),Y=require('crypto'),l=require('assert');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var V__default=/*#__PURE__*/_interopDefault(V);var Y__default=/*#__PURE__*/_interopDefault(Y);var l__default=/*#__PURE__*/_interopDefault(l);var n=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 f={logException:(e,t)=>{console.error(`Exception Occurred in Function: ${e}, Error: ${f.inspect(t)}`);},logError:(e,t)=>{console.error(`Error Occurred in Function: ${e}, Error: ${f.inspect(t)}`);},logWarning:(e,t)=>{console.warn(`Warning in Function: ${e} - ${f.inspect(t)}`);},logMessage:(e,t)=>{console.log(`Message in Function: ${e} - ${f.inspect(t)}`);},logInvalidPayload:(e,t)=>{console.error(`Invalid Payload received for Function: ${e}, Error: ${f.inspect(t)}`);},inspect:e=>typeof e=="string"?e:V__default.default.inspect(e)},y=f;var S=new Uint8Array(256),I=S.length;function P(){return I>S.length-16&&(Y__default.default.randomFillSync(S),I=0),S.slice(I,I+=16)}var D=/^(?:[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 W(e){return typeof e=="string"&&D.test(e)}var b=W;var g=[];for(let e=0;e<256;++e)g.push((e+256).toString(16).slice(1));function _(e,t=0){return g[e[t+0]]+g[e[t+1]]+g[e[t+2]]+g[e[t+3]]+"-"+g[e[t+4]]+g[e[t+5]]+"-"+g[e[t+6]]+g[e[t+7]]+"-"+g[e[t+8]]+g[e[t+9]]+"-"+g[e[t+10]]+g[e[t+11]]+g[e[t+12]]+g[e[t+13]]+g[e[t+14]]+g[e[t+15]]}function $(e){if(!b(e))throw TypeError("Invalid UUID");let t,r=new Uint8Array(16);return r[0]=(t=parseInt(e.slice(0,8),16))>>>24,r[1]=t>>>16&255,r[2]=t>>>8&255,r[3]=t&255,r[4]=(t=parseInt(e.slice(9,13),16))>>>8,r[5]=t&255,r[6]=(t=parseInt(e.slice(14,18),16))>>>8,r[7]=t&255,r[8]=(t=parseInt(e.slice(19,23),16))>>>8,r[9]=t&255,r[10]=(t=parseInt(e.slice(24,36),16))/1099511627776&255,r[11]=t/4294967296&255,r[12]=t>>>24&255,r[13]=t>>>16&255,r[14]=t>>>8&255,r[15]=t&255,r}var w=$;function J(e){e=unescape(encodeURIComponent(e));let t=[];for(let r=0;r<e.length;++r)t.push(e.charCodeAt(r));return t}var z="6ba7b810-9dad-11d1-80b4-00c04fd430c8",B="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function v(e,t,r){function i(s,a,c,o){var A;if(typeof s=="string"&&(s=J(s)),typeof a=="string"&&(a=w(a)),((A=a)===null||A===void 0?void 0:A.length)!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let u=new Uint8Array(16+s.length);if(u.set(a),u.set(s,a.length),u=r(u),u[6]=u[6]&15|t,u[8]=u[8]&63|128,c){o=o||0;for(let p=0;p<16;++p)c[o+p]=u[p];return c}return _(u)}try{i.name=e;}catch{}return i.DNS=z,i.URL=B,i}var K={randomUUID:Y__default.default.randomUUID};function j(e,t,r){if(K.randomUUID&&!t&&!e)return K.randomUUID();e=e||{};let i=e.random||(e.rng||P)();if(i[6]=i[6]&15|64,i[8]=i[8]&63|128,t){r=r||0;for(let s=0;s<16;++s)t[r+s]=i[s];return t}return _(i)}var O=j;function q(e){return Array.isArray(e)?e=Buffer.from(e):typeof e=="string"&&(e=Buffer.from(e,"utf8")),Y__default.default.createHash("sha1").update(e).digest()}var R=q;var X=v("v5",80,R),U=X;var Z={isUUID:e=>/^[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(e),isEmail:e=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(e),isURL:e=>/^(http|https):\/\/[^ "]+$/.test(e),generateUUID:(e,t)=>t&&e?U(e,t):O(),generateSearchId:(e,t)=>`${e}#${t}`,getKeyfromSearchId:e=>{let[t,r]=e.split("#");return {key:t,variantId:r}}},E=Z;var Q={handleException:(e,t,r)=>{t.knownError?(t.logError&&y.logError(e,t),r.status(t.status).json({status:t.status,error:t.error})):t.status&&t.error?(y.logException(e,t),r.status(t.status).json({error:t.errorMessage||JSON.stringify(t.error),status:t.status})):(y.logException(e,t),r.status(500).json({status:500,error:n.INTERNAL_SERVER_ERROR}));},generateResponse:(e,t,r)=>({status:e,data:t,error:r}),generateError:(e,t,r=!0,i=!1)=>({status:e,error:t,knownError:r,logError:i})},m=Q;var tt=async(e,t,r="GET",i={},s)=>{let a={method:r,headers:{"Content-Type":"application/json",...i}};r!=="GET"&&s&&(a.body=JSON.stringify(s));let c=`${e}${t?"/"+t:""}`;try{let o=await fetch(c,a);if(!o.ok){let u,p=await o.text();try{u=JSON.parse(p);}catch{u={status:o.status,error:p||o.statusText},y.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${c}. Raw text: ${p}`);}throw {status:o.status,statusText:o.statusText,error:u}}let A=await o.json();return y.logMessage("Fetch",`API call successful: URL-${c}, Status- ${o.status}`),{status:o.status,statusText:o.statusText,data:A.data||{data:A}}}catch(o){throw y.logError("Fetch",`API call failed: URL-${c}, Status- ${o.status||500}, Error- ${y.inspect(o.error||o)}`),{status:o.status||500,statusText:o.statusText||n.INTERNAL_SERVER_ERROR,error:o.error||{status:o.status||500,error:o.statusText||n.SOMETHING_WENT_WRONG}}}},L=tt;var N=class e{static instance=null;id;type;token;initializedAt;lambdaName;requestId;constructor(t,r,i,s){this.id=t,this.type=r,this.token=i,this.lambdaName=process.env.AWS_LAMBDA_FUNCTION_NAME,this.initializedAt=new Date;}static getInstance(){return l__default.default(e.instance,n.AUTH_CONTEXT_NOT_INITIALIZED),e.instance}static init(t,r,i,s){return e.instance=new e(t,r,i,s),e.instance}static uninit(){e.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(t){let r=this.lambdaName||t;return this.requestId?`${r} - ${this.requestId}`:r}};var k={userTokenAge:"30 days",userPrivateKeys:"[]",userPublicKeys:"[]",anonymousTokenAge:"30 days",anonymousPrivateKeys:"[]",anonymousPublicKeys:"[]",systemTokenAge:"5 min",systemPrivateKeys:"[]",systemPublicKeys:"[]",adminTokenAge:"30 days",adminPrivateKeys:"[]",adminPublicKeys:"[]",cdnKeys:"[]"},ot=(a=>(a.ANON="Anon",a.USER="User",a.SYSTEM="System",a.ADMIN="Admin",a.CDN="CDN",a))(ot||{}),C={allowAnonymous:!1,allowSystem:!0,allowUser:!0,allowCDN:!1},x=class{userTokenAge;userPrivateKeys;userPublicKeys;anonymousTokenAge;anonymousPrivateKeys;anonymousPublicKeys;systemTokenAge;systemPrivateKeys;systemPublicKeys;adminTokenAge;adminPrivateKeys;adminPublicKeys;cdnKeys;constructor(t=k){let{userTokenAge:r,userPrivateKeys:i,userPublicKeys:s,anonymousTokenAge:a,anonymousPrivateKeys:c,anonymousPublicKeys:o,systemTokenAge:A,systemPrivateKeys:u,systemPublicKeys:p,adminTokenAge:h,adminPrivateKeys:T,adminPublicKeys:M,cdnKeys:F}={...k,...t};this.userTokenAge=r,this.userPrivateKeys=this.parseKeyArray(i,"user private"),this.userPublicKeys=this.parseKeyArray(s,"user public"),this.anonymousTokenAge=a,this.anonymousPrivateKeys=this.parseKeyArray(c,"anonymous private"),this.anonymousPublicKeys=this.parseKeyArray(o,"anonymous public"),this.systemTokenAge=A,this.systemPrivateKeys=this.parseKeyArray(u,"system private"),this.systemPublicKeys=this.parseKeyArray(p,"system public"),this.adminTokenAge=h,this.adminPrivateKeys=this.parseKeyArray(T,"admin private"),this.adminPublicKeys=this.parseKeyArray(M,"admin public"),this.cdnKeys=this.parseKeyArray(F,"cdn"),this.logWarnings();}parseKeyArray(t,r){try{let i=JSON.parse(t);return !Array.isArray(i)||!i.every(s=>typeof s=="string")?(y.logError("AuthUtility",`Invalid format for ${r} keys in config: Expected stringified array of strings.`),[]):i}catch(i){return y.logError("AuthUtility",`Failed to parse ${r} keys from config: ${i}`),[]}}logWarnings(){let t=(r,i,s)=>i.length>s&&y.logWarning("AuthUtility",`More than ${s} ${r} keys provided. This is not recommended.`);t("user private",this.userPrivateKeys,3),t("user public",this.userPublicKeys,3),t("anonymous private",this.anonymousPrivateKeys,1),t("anonymous public",this.anonymousPublicKeys,3),t("system private",this.systemPrivateKeys,1),t("system public",this.systemPublicKeys,3),t("admin private",this.adminPrivateKeys,1),t("admin public",this.adminPublicKeys,3);}async createSignedJWT(t,r,i){let s=await jose.importPKCS8(r,"RS256");return await new jose.SignJWT(t).setProtectedHeader({alg:"RS256"}).setExpirationTime(i).setIssuedAt().sign(s)}async verifySignedJWT(t,r,i){for(let s=r.length-1;s>=0;s--)try{let a=await jose.importSPKI(r[s],"RS256");return (await jose.jwtVerify(t,a,{clockTolerance:30,maxTokenAge:i})).payload}catch(a){if(s===0)throw a;continue}throw new Error(n.INVALID_TOKEN)}async createAnonymousToken(t,r){l__default.default(this.anonymousPrivateKeys.length,n.ANONYMOUS_PRIVATE_KEY_NOT_FOUND),l__default.default(E.isUUID(t),n.INVALID_UUID);let i={id:t,type:"Anon",...r};return await this.createSignedJWT(i,this.anonymousPrivateKeys[this.anonymousPrivateKeys.length-1],this.anonymousTokenAge)}async verifyAnonymousToken(t){l__default.default(this.anonymousPublicKeys.length,n.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(t,this.anonymousPublicKeys,this.anonymousTokenAge);return l__default.default(r.type==="Anon",n.INVALID_AUTH_TYPE),r}async createUserToken(t,r){l__default.default(this.userPrivateKeys.length,n.USER_PRIVATE_KEY_NOT_FOUND),l__default.default(E.isUUID(t),n.INVALID_UUID);let i={id:t,type:"User",...r};return await this.createSignedJWT(i,this.userPrivateKeys[this.userPrivateKeys.length-1],this.userTokenAge)}async verifyUserToken(t){l__default.default(this.userPublicKeys.length,n.USER_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(t,this.userPublicKeys,this.userTokenAge);return l__default.default(r.type==="User",n.INVALID_AUTH_TYPE),r}async createSystemToken(t,r){l__default.default(this.systemPrivateKeys.length,n.SYSTEM_PRIVATE_KEY_NOT_FOUND);let i={id:t,type:"System",...r};return await this.createSignedJWT(i,this.systemPrivateKeys[this.systemPrivateKeys.length-1],this.systemTokenAge)}async verifySystemToken(t){l__default.default(this.systemPublicKeys.length,n.USER_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(t,this.systemPublicKeys,this.systemTokenAge);return l__default.default(r.type==="System",n.INVALID_AUTH_TYPE),r}async createAdminToken(t,r,i){l__default.default(this.adminPrivateKeys.length,n.ADMIN_PRIVATE_KEY_NOT_FOUND),l__default.default(E.isEmail(t),n.INVALID_EMAIL),l__default.default(E.isURL(r),n.INVALID_VERIFIER);let s={id:t,type:"Admin",verifier:r,...i};return await this.createSignedJWT(s,this.adminPrivateKeys[this.adminPrivateKeys.length-1],this.adminTokenAge)}async verifyAdminToken(t,r,i){l__default.default(this.adminPublicKeys.length,n.ADMIN_PUBLIC_KEY_NOT_FOUND);let s=await this.verifySignedJWT(t,this.adminPublicKeys,this.adminTokenAge);if(l__default.default(s.type==="Admin",n.INVALID_AUTH_TYPE),i){let a=await L(s.verifier,"","POST",{},{token:t,permissions:r});if(l__default.default(a.data.isTokenValid===!0,n.INVALID_TOKEN),a.data.hasPermissions!==!0)throw m.generateError(403,n.INVALID_PERMISSIONS)}return s}async verifyCDNToken(t){return l__default.default(this.cdnKeys.includes(t),n.INVALID_TOKEN),{id:t,type:"CDN"}}AuthMiddleware(t=C,r=[]){let{allowAnonymous:i,allowSystem:s,allowUser:a,allowCDN:c}={...C,...t};return async(o,A,u)=>{try{let[p,h]=o.get("Authorization")?.split(" ")||[];if(!h)throw new Error(n.INVALID_TOKEN);let T;switch(p){case"Anon":if(!i)throw m.generateError(403,n.ANONYMOUS_SESSION_NOT_ALLOWED);T=await this.verifyAnonymousToken(h);break;case"User":if(!a)throw m.generateError(403,n.USER_SESSION_NOT_ALLOWED);T=await this.verifyUserToken(h);break;case"System":if(!s)throw m.generateError(403,n.SYSTEM_SESSION_NOT_ALLOWED);T=await this.verifySystemToken(h);break;case"Admin":T=await this.verifyAdminToken(h,r,!0);break;case"CDN":if(!c)throw m.generateError(403,n.CDN_SESSION_NOT_ALLOWED);T=await this.verifyCDNToken(h);break;default:throw m.generateError(403,n.INVALID_AUTH_TYPE)}u();}catch(p){y.logError("AuthMiddleware",p),m.handleException("AuthMiddleware",m.generateError(401,p.error||n.TOKEN_EXPIRED,!0),A);}}}decodeJWTPayloadWithJose(t){if(!t||typeof t!="string")return y.logError("AuthContextMiddleware","Invalid token provided for decoding."),null;try{return jose.decodeJwt(t)}catch(r){return y.logError("AuthContextMiddleware",`Failed to decode JWT payload: ${r}`),null}}AuthContextMiddleware(){return async(t,r,i)=>{try{let[s,a]=t.get("Authorization")?.split(" ")||[],c=s==="CDN"?{id:a,type:"CDN"}:this.decodeJWTPayloadWithJose(a),o=N.init(c?.id||a,c?.type||s,a,t.get("x-request-id"));y.logMessage("AuthContextMiddleware",`AuthContext initialized: ${o.getType()||"No-Type"} - ${o.getId()||"No-Id"}`),r.on("finish",()=>{y.logMessage("AuthContextMiddleware","Uninitializing AuthContext"),N.uninit();}),i();}catch(s){y.logError("AuthContextMiddleware",s),m.handleException("AuthContextMiddleware",m.generateError(500,s.error||n.INTERNAL_SERVER_ERROR,!0),r);}}}},Te=x;exports.AuthContext=N;exports.AuthType=ot;exports.DefaultAuthMiddlewareConfig=C;exports.DefaultAuthUtilityConfig=k;exports.default=Te;//# sourceMappingURL=index.js.map
|
|
1
|
+
'use strict';Object.defineProperty(exports,'__esModule',{value:true});var jose=require('jose'),V=require('util'),Y=require('crypto'),l=require('assert');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var V__default=/*#__PURE__*/_interopDefault(V);var Y__default=/*#__PURE__*/_interopDefault(Y);var l__default=/*#__PURE__*/_interopDefault(l);var n=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 f={logException:(e,t)=>{console.error(`Exception Occurred in Function: ${e}, Error: ${f.inspect(t)}`);},logError:(e,t)=>{console.error(`Error Occurred in Function: ${e}, Error: ${f.inspect(t)}`);},logWarning:(e,t)=>{console.warn(`Warning in Function: ${e} - ${f.inspect(t)}`);},logMessage:(e,t)=>{console.log(`Message in Function: ${e} - ${f.inspect(t)}`);},logInvalidPayload:(e,t)=>{console.error(`Invalid Payload received for Function: ${e}, Error: ${f.inspect(t)}`);},inspect:e=>typeof e=="string"?e:V__default.default.inspect(e)},y=f;var S=new Uint8Array(256),I=S.length;function P(){return I>S.length-16&&(Y__default.default.randomFillSync(S),I=0),S.slice(I,I+=16)}var D=/^(?:[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 W(e){return typeof e=="string"&&D.test(e)}var b=W;var c=[];for(let e=0;e<256;++e)c.push((e+256).toString(16).slice(1));function _(e,t=0){return c[e[t+0]]+c[e[t+1]]+c[e[t+2]]+c[e[t+3]]+"-"+c[e[t+4]]+c[e[t+5]]+"-"+c[e[t+6]]+c[e[t+7]]+"-"+c[e[t+8]]+c[e[t+9]]+"-"+c[e[t+10]]+c[e[t+11]]+c[e[t+12]]+c[e[t+13]]+c[e[t+14]]+c[e[t+15]]}function $(e){if(!b(e))throw TypeError("Invalid UUID");let t,r=new Uint8Array(16);return r[0]=(t=parseInt(e.slice(0,8),16))>>>24,r[1]=t>>>16&255,r[2]=t>>>8&255,r[3]=t&255,r[4]=(t=parseInt(e.slice(9,13),16))>>>8,r[5]=t&255,r[6]=(t=parseInt(e.slice(14,18),16))>>>8,r[7]=t&255,r[8]=(t=parseInt(e.slice(19,23),16))>>>8,r[9]=t&255,r[10]=(t=parseInt(e.slice(24,36),16))/1099511627776&255,r[11]=t/4294967296&255,r[12]=t>>>24&255,r[13]=t>>>16&255,r[14]=t>>>8&255,r[15]=t&255,r}var w=$;function J(e){e=unescape(encodeURIComponent(e));let t=[];for(let r=0;r<e.length;++r)t.push(e.charCodeAt(r));return t}var z="6ba7b810-9dad-11d1-80b4-00c04fd430c8",B="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function v(e,t,r){function i(s,a,u,m){var o;if(typeof s=="string"&&(s=J(s)),typeof a=="string"&&(a=w(a)),((o=a)===null||o===void 0?void 0:o.length)!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let d=new Uint8Array(16+s.length);if(d.set(a),d.set(s,a.length),d=r(d),d[6]=d[6]&15|t,d[8]=d[8]&63|128,u){m=m||0;for(let p=0;p<16;++p)u[m+p]=d[p];return u}return _(d)}try{i.name=e;}catch{}return i.DNS=z,i.URL=B,i}var K={randomUUID:Y__default.default.randomUUID};function j(e,t,r){if(K.randomUUID&&!t&&!e)return K.randomUUID();e=e||{};let i=e.random||(e.rng||P)();if(i[6]=i[6]&15|64,i[8]=i[8]&63|128,t){r=r||0;for(let s=0;s<16;++s)t[r+s]=i[s];return t}return _(i)}var O=j;function q(e){return Array.isArray(e)?e=Buffer.from(e):typeof e=="string"&&(e=Buffer.from(e,"utf8")),Y__default.default.createHash("sha1").update(e).digest()}var R=q;var X=v("v5",80,R),U=X;var Z={isUUID:e=>/^[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(e),isEmail:e=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(e),isURL:e=>/^(http|https):\/\/[^ "]+$/.test(e),generateUUID:(e,t)=>t&&e?U(e,t):O(),generateSearchId:(e,t)=>`${e}#${t}`,getKeyfromSearchId:e=>{let[t,r]=e.split("#");return {key:t,variantId:r}}},E=Z;var Q={handleException:(e,t,r)=>{t.knownError?(t.logError&&y.logError(e,t),r.status(t.status).json({status:t.status,error:t.error})):t.status&&t.error?(y.logException(e,t),r.status(t.status).json({error:t.errorMessage||JSON.stringify(t.error),status:t.status})):(y.logException(e,t),r.status(500).json({status:500,error:n.INTERNAL_SERVER_ERROR}));},generateResponse:(e,t,r)=>({status:e,data:t,error:r}),generateError:(e,t,r=!0,i=!1)=>({status:e,error:t,knownError:r,logError:i})},h=Q;var tt=async(e,t,r="GET",i={},s)=>{let a={method:r,headers:{"Content-Type":"application/json",...i}};r!=="GET"&&s&&(a.body=JSON.stringify(s));let u=`${e}${t?"/"+t:""}`,m=u.includes("api.xetile.com")||u.includes("localhost");try{let o=await fetch(u,a);if(!o.ok){let p,A=await o.text();try{p=JSON.parse(A);}catch{p={status:o.status,error:A||o.statusText},y.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${u}. Raw text: ${A}`);}throw {status:o.status,statusText:o.statusText,error:p}}let d=await o.json();return y.logMessage("Fetch",`API call successful: URL-${u}, Status- ${o.status}`),{status:o.status,statusText:o.statusText,data:m?d.data:d}}catch(o){throw y.logError("Fetch",`API call failed: URL-${u}, Status- ${o.status||500}, Error- ${y.inspect(o.error||o)}`),{status:o.status||500,statusText:o.statusText||n.INTERNAL_SERVER_ERROR,error:o.error||{status:o.status||500,error:o.statusText||n.SOMETHING_WENT_WRONG}}}},L=tt;var N=class e{static instance=null;id;type;token;initializedAt;lambdaName;requestId;constructor(t,r,i,s){this.id=t,this.type=r,this.token=i,this.lambdaName=process.env.AWS_LAMBDA_FUNCTION_NAME,this.initializedAt=new Date;}static getInstance(){return l__default.default(e.instance,n.AUTH_CONTEXT_NOT_INITIALIZED),e.instance}static init(t,r,i,s){return e.instance=new e(t,r,i,s),e.instance}static uninit(){e.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(t){let r=this.lambdaName||t;return this.requestId?`${r} - ${this.requestId}`:r}};var k={userTokenAge:"30 days",userPrivateKeys:"[]",userPublicKeys:"[]",anonymousTokenAge:"30 days",anonymousPrivateKeys:"[]",anonymousPublicKeys:"[]",systemTokenAge:"5 min",systemPrivateKeys:"[]",systemPublicKeys:"[]",adminTokenAge:"30 days",adminPrivateKeys:"[]",adminPublicKeys:"[]",cdnKeys:"[]"},ot=(a=>(a.ANON="Anon",a.USER="User",a.SYSTEM="System",a.ADMIN="Admin",a.CDN="CDN",a))(ot||{}),C={allowAnonymous:!1,allowSystem:!0,allowUser:!0,allowCDN:!1},x=class{userTokenAge;userPrivateKeys;userPublicKeys;anonymousTokenAge;anonymousPrivateKeys;anonymousPublicKeys;systemTokenAge;systemPrivateKeys;systemPublicKeys;adminTokenAge;adminPrivateKeys;adminPublicKeys;cdnKeys;constructor(t=k){let{userTokenAge:r,userPrivateKeys:i,userPublicKeys:s,anonymousTokenAge:a,anonymousPrivateKeys:u,anonymousPublicKeys:m,systemTokenAge:o,systemPrivateKeys:d,systemPublicKeys:p,adminTokenAge:A,adminPrivateKeys:T,adminPublicKeys:M,cdnKeys:F}={...k,...t};this.userTokenAge=r,this.userPrivateKeys=this.parseKeyArray(i,"user private"),this.userPublicKeys=this.parseKeyArray(s,"user public"),this.anonymousTokenAge=a,this.anonymousPrivateKeys=this.parseKeyArray(u,"anonymous private"),this.anonymousPublicKeys=this.parseKeyArray(m,"anonymous public"),this.systemTokenAge=o,this.systemPrivateKeys=this.parseKeyArray(d,"system private"),this.systemPublicKeys=this.parseKeyArray(p,"system public"),this.adminTokenAge=A,this.adminPrivateKeys=this.parseKeyArray(T,"admin private"),this.adminPublicKeys=this.parseKeyArray(M,"admin public"),this.cdnKeys=this.parseKeyArray(F,"cdn"),this.logWarnings();}parseKeyArray(t,r){try{let i=JSON.parse(t);return !Array.isArray(i)||!i.every(s=>typeof s=="string")?(y.logError("AuthUtility",`Invalid format for ${r} keys in config: Expected stringified array of strings.`),[]):i}catch(i){return y.logError("AuthUtility",`Failed to parse ${r} keys from config: ${i}`),[]}}logWarnings(){let t=(r,i,s)=>i.length>s&&y.logWarning("AuthUtility",`More than ${s} ${r} keys provided. This is not recommended.`);t("user private",this.userPrivateKeys,3),t("user public",this.userPublicKeys,3),t("anonymous private",this.anonymousPrivateKeys,1),t("anonymous public",this.anonymousPublicKeys,3),t("system private",this.systemPrivateKeys,1),t("system public",this.systemPublicKeys,3),t("admin private",this.adminPrivateKeys,1),t("admin public",this.adminPublicKeys,3);}async createSignedJWT(t,r,i){let s=await jose.importPKCS8(r,"RS256");return await new jose.SignJWT(t).setProtectedHeader({alg:"RS256"}).setExpirationTime(i).setIssuedAt().sign(s)}async verifySignedJWT(t,r,i){for(let s=r.length-1;s>=0;s--)try{let a=await jose.importSPKI(r[s],"RS256");return (await jose.jwtVerify(t,a,{clockTolerance:30,maxTokenAge:i})).payload}catch(a){if(s===0)throw a;continue}throw new Error(n.INVALID_TOKEN)}async createAnonymousToken(t,r){l__default.default(this.anonymousPrivateKeys.length,n.ANONYMOUS_PRIVATE_KEY_NOT_FOUND),l__default.default(E.isUUID(t),n.INVALID_UUID);let i={id:t,type:"Anon",...r};return await this.createSignedJWT(i,this.anonymousPrivateKeys[this.anonymousPrivateKeys.length-1],this.anonymousTokenAge)}async verifyAnonymousToken(t){l__default.default(this.anonymousPublicKeys.length,n.ANONYMOUS_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(t,this.anonymousPublicKeys,this.anonymousTokenAge);return l__default.default(r.type==="Anon",n.INVALID_AUTH_TYPE),r}async createUserToken(t,r){l__default.default(this.userPrivateKeys.length,n.USER_PRIVATE_KEY_NOT_FOUND),l__default.default(E.isUUID(t),n.INVALID_UUID);let i={id:t,type:"User",...r};return await this.createSignedJWT(i,this.userPrivateKeys[this.userPrivateKeys.length-1],this.userTokenAge)}async verifyUserToken(t){l__default.default(this.userPublicKeys.length,n.USER_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(t,this.userPublicKeys,this.userTokenAge);return l__default.default(r.type==="User",n.INVALID_AUTH_TYPE),r}async createSystemToken(t,r){l__default.default(this.systemPrivateKeys.length,n.SYSTEM_PRIVATE_KEY_NOT_FOUND);let i={id:t,type:"System",...r};return await this.createSignedJWT(i,this.systemPrivateKeys[this.systemPrivateKeys.length-1],this.systemTokenAge)}async verifySystemToken(t){l__default.default(this.systemPublicKeys.length,n.USER_PUBLIC_KEY_NOT_FOUND);let r=await this.verifySignedJWT(t,this.systemPublicKeys,this.systemTokenAge);return l__default.default(r.type==="System",n.INVALID_AUTH_TYPE),r}async createAdminToken(t,r,i){l__default.default(this.adminPrivateKeys.length,n.ADMIN_PRIVATE_KEY_NOT_FOUND),l__default.default(E.isEmail(t),n.INVALID_EMAIL),l__default.default(E.isURL(r),n.INVALID_VERIFIER);let s={id:t,type:"Admin",verifier:r,...i};return await this.createSignedJWT(s,this.adminPrivateKeys[this.adminPrivateKeys.length-1],this.adminTokenAge)}async verifyAdminToken(t,r,i){l__default.default(this.adminPublicKeys.length,n.ADMIN_PUBLIC_KEY_NOT_FOUND);let s=await this.verifySignedJWT(t,this.adminPublicKeys,this.adminTokenAge);if(l__default.default(s.type==="Admin",n.INVALID_AUTH_TYPE),i){let a=await L(s.verifier,"","POST",{},{token:t,permissions:r});if(l__default.default(a.data.isTokenValid===!0,n.INVALID_TOKEN),a.data.hasPermissions!==!0)throw h.generateError(403,n.INVALID_PERMISSIONS)}return s}async verifyCDNToken(t){return l__default.default(this.cdnKeys.includes(t),n.INVALID_TOKEN),{id:t,type:"CDN"}}AuthMiddleware(t=C,r=[]){let{allowAnonymous:i,allowSystem:s,allowUser:a,allowCDN:u}={...C,...t};return async(m,o,d)=>{try{let[p,A]=m.get("Authorization")?.split(" ")||[];if(!A)throw new Error(n.INVALID_TOKEN);let T;switch(p){case"Anon":if(!i)throw h.generateError(403,n.ANONYMOUS_SESSION_NOT_ALLOWED);T=await this.verifyAnonymousToken(A);break;case"User":if(!a)throw h.generateError(403,n.USER_SESSION_NOT_ALLOWED);T=await this.verifyUserToken(A);break;case"System":if(!s)throw h.generateError(403,n.SYSTEM_SESSION_NOT_ALLOWED);T=await this.verifySystemToken(A);break;case"Admin":T=await this.verifyAdminToken(A,r,!0);break;case"CDN":if(!u)throw h.generateError(403,n.CDN_SESSION_NOT_ALLOWED);T=await this.verifyCDNToken(A);break;default:throw h.generateError(403,n.INVALID_AUTH_TYPE)}d();}catch(p){y.logError("AuthMiddleware",p),h.handleException("AuthMiddleware",h.generateError(401,p.error||n.TOKEN_EXPIRED,!0),o);}}}decodeJWTPayloadWithJose(t){if(!t||typeof t!="string")return y.logError("AuthContextMiddleware","Invalid token provided for decoding."),null;try{return jose.decodeJwt(t)}catch(r){return y.logError("AuthContextMiddleware",`Failed to decode JWT payload: ${r}`),null}}AuthContextMiddleware(){return async(t,r,i)=>{try{let[s,a]=t.get("Authorization")?.split(" ")||[],u=s==="CDN"?{id:a,type:"CDN"}:this.decodeJWTPayloadWithJose(a),m=N.init(u?.id||a,u?.type||s,a,t.get("x-request-id"));y.logMessage("AuthContextMiddleware",`AuthContext initialized: ${m.getType()||"No-Type"} - ${m.getId()||"No-Id"}`),r.on("finish",()=>{y.logMessage("AuthContextMiddleware","Uninitializing AuthContext"),N.uninit();}),i();}catch(s){y.logError("AuthContextMiddleware",s),h.handleException("AuthContextMiddleware",h.generateError(500,s.error||n.INTERNAL_SERVER_ERROR,!0),r);}}}},Te=x;exports.AuthContext=N;exports.AuthType=ot;exports.DefaultAuthMiddlewareConfig=C;exports.DefaultAuthUtilityConfig=k;exports.default=Te;//# sourceMappingURL=index.js.map
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/Auth/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/enums/ErrorTypes.ts","../../src/Logger/index.ts","../../node_modules/uuid/dist/esm-node/rng.js","../../node_modules/uuid/dist/esm-node/regex.js","../../node_modules/uuid/dist/esm-node/validate.js","../../node_modules/uuid/dist/esm-node/stringify.js","../../node_modules/uuid/dist/esm-node/parse.js","../../node_modules/uuid/dist/esm-node/v35.js","../../node_modules/uuid/dist/esm-node/native.js","../../node_modules/uuid/dist/esm-node/v4.js","../../node_modules/uuid/dist/esm-node/sha1.js","../../node_modules/uuid/dist/esm-node/v5.js","../../src/Utils/index.ts","../../src/Utils/response.ts","../../src/Utils/fetch.ts","../../src/Auth/AuthContext.ts","../../src/Auth/index.ts"],"names":["ErrorTypes_default","Logger","functionName","error","message","errorMessage","context","util","Logger_default","rnds8Pool","poolPtr","rng","crypto","regex_default","validate","uuid","validate_default","byteToHex","i","unsafeStringify","arr","offset","parse","v","parse_default","stringToBytes","str","bytes","DNS","URL","v35","name","version","hashfunc","generateUUID","value","namespace","buf","_namespace","native_default","v4","options","rnds","v4_default","sha1","sha1_default","v5","v5_default","Utils","key","variantId","searchId","Utils_default","ResponseUtility","res","status","data","knownError","logError","response_default","Fetch","baseURL","endpoint","method","headers","payload","completeURL","response","errorBody","errorText","body","err","fetch_default","AuthContext","_AuthContext","id","type","token","requestId","assert","fallbackLambdaName","baseId","DefaultAuthUtilityConfig","AuthType","DefaultAuthMiddlewareConfig","AuthUtility","config","userTokenAge","userPrivateKeys","userPublicKeys","anonymousTokenAge","anonymousPrivateKeys","anonymousPublicKeys","systemTokenAge","systemPrivateKeys","systemPublicKeys","adminTokenAge","adminPrivateKeys","adminPublicKeys","cdnKeys","jsonString","keyType","parsed","item","warn","keys","limit","privateKeyString","expiration","privateKey","importPKCS8","SignJWT","publicKeyString","publicKey","importSPKI","jwtVerify","additionalData","email","verifier","permissions","authenticate","allowAnonymous","allowSystem","allowUser","allowCDN","req","next","authType","decodeJwt","authContext","Auth_default"],"mappings":"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","file":"index.js","sourcesContent":["export default Object.freeze({\r\n INVALID_UUID: \"Invalid UUID\",\r\n INVALID_EMAIL: \"Invalid Email\",\r\n INVALID_TOKEN: \"Invalid Token\",\r\n TOKEN_EXPIRED: \"Token Expired\",\r\n INVALID_VERIFIER: \"Invalid Verifier\",\r\n INVALID_PERMISSIONS: \"Invalid Permissions\",\r\n INVALID_AUTH_TYPE: \"Invalid Authorization Type\",\r\n USER_PRIVATE_KEY_NOT_FOUND: \"User Private Key Not Found\",\r\n USER_PUBLIC_KEY_NOT_FOUND: \"User Public Key Not Found\",\r\n ANONYMOUS_PRIVATE_KEY_NOT_FOUND: \"Anonymous Private Key Not Found\",\r\n ANONYMOUS_PUBLIC_KEY_NOT_FOUND: \"Anonymous Public Key Not Found\",\r\n SYSTEM_PRIVATE_KEY_NOT_FOUND: \"System Private Key Not Found\",\r\n SYSTEM_PUBLIC_KEY_NOT_FOUND: \"System Public Key Not Found\",\r\n ADMIN_PRIVATE_KEY_NOT_FOUND: \"Admin Private Key Not Found\",\r\n ADMIN_PUBLIC_KEY_NOT_FOUND: \"Admin Public Key Not Found\",\r\n SECRET_TOKEN_NOT_FOUND: \"Secret Token Not Found\",\r\n ANONYMOUS_SESSION_NOT_ALLOWED: \"Anonymous Session Not Allowed\",\r\n USER_SESSION_NOT_ALLOWED: \"User Session Not Allowed\",\r\n SYSTEM_SESSION_NOT_ALLOWED: \"System Session Not Allowed\",\r\n CDN_SESSION_NOT_ALLOWED: \"CDN Session Not Allowed\",\r\n INTERNAL_SERVER_ERROR: \"Internal Server Error\",\r\n SOMETHING_WENT_WRONG: 'Something went wrong',\r\n AUTH_CONTEXT_NOT_INITIALIZED: 'Auth Context not Initialized'\r\n})","import util from 'util';\r\nconst Logger = {\r\n logException: (functionName: string, error: any) => {\r\n console.error(`Exception Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logError: (functionName: string, error: any) => {\r\n console.error(`Error Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logWarning: (functionName: string, message: any) => {\r\n console.warn(`Warning in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logMessage: (functionName: string, message: any) => {\r\n console.log(`Message in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logInvalidPayload: (functionName: string, errorMessage: string) => {\r\n console.error(`Invalid Payload received for Function: ${functionName}, Error: ${Logger.inspect(errorMessage)}`);\r\n },\r\n\r\n inspect: (context: any) => {\r\n return (typeof context === \"string\" ? context : util.inspect(context));\r\n }\r\n}\r\n\r\nexport default Logger;","import crypto from 'crypto';\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n crypto.randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","export default /^(?:[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;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import { unsafeStringify } from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function v35(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n var _namespace;\n\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (((_namespace = namespace) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","import crypto from 'crypto';\nexport default {\n randomUUID: crypto.randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import crypto from 'crypto';\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return crypto.createHash('sha1').update(bytes).digest();\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nconst v5 = v35('v5', 0x50, sha1);\nexport default v5;","import { v4 as uuidv4, v5 as uuidv5 } from 'uuid';\r\n\r\nconst Utils = {\r\n isUUID: (value: string): boolean => {\r\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\r\n return uuidRegex.test(value);\r\n },\r\n\r\n isEmail: (value: string): boolean => {\r\n const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n return emailRegex.test(value);\r\n },\r\n\r\n isURL: (value: string): boolean => {\r\n const urlRegex = /^(http|https):\\/\\/[^ \"]+$/;\r\n return urlRegex.test(value);\r\n },\r\n \r\n generateUUID: (value?: string, namespace?: string) => {\r\n if(namespace && value){\r\n return uuidv5(value, namespace);\r\n }\r\n return uuidv4();\r\n },\r\n\r\n generateSearchId: (key: string, variantId: string) => {\r\n return `${key}#${variantId}`;\r\n },\r\n\r\n getKeyfromSearchId: (searchId: string) => {\r\n const [key, variantId] = searchId.split('#');\r\n return {\r\n key,\r\n variantId\r\n }\r\n },\r\n}\r\n\r\nexport default Utils;\r\n","import ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport const ResponseUtility = {\r\n handleException: (functionName: string, error: any, res: any) => {\r\n if (error.knownError) {\r\n error.logError && Logger.logError(functionName, error);\r\n res.status(error.status).json({\r\n status: error.status,\r\n error: error.error\r\n });\r\n } else if(error.status && error.error) {\r\n Logger.logException(functionName, error);\r\n res.status(error.status).json({\r\n error: error.errorMessage || JSON.stringify(error.error),\r\n status: error.status,\r\n });\r\n } else {\r\n Logger.logException(functionName, error);\r\n res.status(500).json({\r\n status: 500,\r\n error: ErrorTypes.INTERNAL_SERVER_ERROR\r\n })\r\n }\r\n },\r\n\r\n generateResponse: (status: number, data?: any, error?: string) => {\r\n return {\r\n status,\r\n data,\r\n error\r\n }\r\n },\r\n\r\n generateError: (status: number, error: string, knownError: Boolean = true, logError: boolean = false) => {\r\n return {\r\n status,\r\n error,\r\n knownError,\r\n logError\r\n }\r\n }\r\n}\r\n\r\nexport default ResponseUtility;","\"use client\";\r\n\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport type ErrorType = {\r\n status: number;\r\n statusText: string;\r\n error: any;\r\n};\r\n\r\nexport type SuccessType = {\r\n status: number;\r\n statusText: string;\r\n data: any;\r\n};\r\n\r\n/**\r\n * Makes an HTTP request to the specified endpoint using the provided parameters.\r\n *\r\n * @param {string} baseURL - The base URL of the API.\r\n * @param {string} endpoint - The specific endpoint to call.\r\n * @param {'GET' | 'POST' | 'PATCH' | 'DELETE'} [method='GET'] - The HTTP method to use for the request.\r\n * @param {Record<string, string>} [headers={}] - Additional headers to include in the request.\r\n * @param {any} [payload] - The payload to send with the request, if applicable.\r\n * @returns {Promise<SuccessType>} - A promise that resolves to the response data if the request is successful.\r\n * @throws {ErrorType} - Throws an error if the request fails.\r\n */\r\nconst Fetch = async (\r\n baseURL: string,\r\n endpoint: string,\r\n method: 'GET' | 'POST' | 'PATCH' | 'DELETE' = 'GET',\r\n headers: Record<string, string> = {},\r\n payload?: any,\r\n): Promise<SuccessType> => {\r\n const options: RequestInit = {\r\n method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n ...headers,\r\n },\r\n };\r\n\r\n if (method !== 'GET' && payload) {\r\n options.body = JSON.stringify(payload);\r\n }\r\n\r\n const completeURL = `${baseURL}${endpoint ? ('/' + endpoint) : ''}`\r\n try {\r\n const response: any = await fetch(completeURL, options);\r\n\r\n if (!response.ok) {\r\n let errorBody: any;\r\n const errorText = await response.text();\r\n\r\n try {\r\n errorBody = JSON.parse(errorText);\r\n } catch (parseError) {\r\n errorBody = {\r\n status: response.status,\r\n error: errorText || response.statusText\r\n };\r\n Logger.logWarning('Fetch', `Failed to parse error response body as JSON for URL-${completeURL}. Raw text: ${errorText}`);\r\n }\r\n\r\n throw {\r\n status: response.status,\r\n statusText: response.statusText,\r\n error: errorBody\r\n } as ErrorType;\r\n }\r\n\r\n const body = await response.json();\r\n\r\n Logger.logMessage('Fetch', `API call successful: URL-${completeURL}, Status- ${response.status}`);\r\n return {\r\n status: response.status,\r\n statusText: response.statusText,\r\n data: body.data || { data: body },\r\n } as SuccessType;\r\n } catch (err: any) {\r\n \r\n Logger.logError('Fetch', `API call failed: URL-${completeURL}, Status- ${err.status || 500}, Error- ${Logger.inspect(err.error || err)}`);\r\n throw {\r\n status: err.status || 500,\r\n statusText: err.statusText || ErrorTypes.INTERNAL_SERVER_ERROR,\r\n error: err.error || {\r\n status: err.status || 500,\r\n error: err.statusText || ErrorTypes.SOMETHING_WENT_WRONG,\r\n }\r\n } as ErrorType;\r\n }\r\n};\r\n\r\nexport default Fetch;\r\n","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/enums/ErrorTypes.ts","../../src/Logger/index.ts","../../node_modules/uuid/dist/esm-node/rng.js","../../node_modules/uuid/dist/esm-node/regex.js","../../node_modules/uuid/dist/esm-node/validate.js","../../node_modules/uuid/dist/esm-node/stringify.js","../../node_modules/uuid/dist/esm-node/parse.js","../../node_modules/uuid/dist/esm-node/v35.js","../../node_modules/uuid/dist/esm-node/native.js","../../node_modules/uuid/dist/esm-node/v4.js","../../node_modules/uuid/dist/esm-node/sha1.js","../../node_modules/uuid/dist/esm-node/v5.js","../../src/Utils/index.ts","../../src/Utils/response.ts","../../src/Auth/index.ts","../../src/Utils/fetch.ts","../../src/Auth/AuthContext.ts"],"names":["ErrorTypes_default","Logger","functionName","error","message","errorMessage","context","util","Logger_default","rnds8Pool","poolPtr","rng","crypto","regex_default","validate","uuid","validate_default","byteToHex","i","unsafeStringify","arr","offset","parse","v","parse_default","stringToBytes","str","bytes","DNS","URL","v35","name","version","hashfunc","generateUUID","value","namespace","buf","_namespace","native_default","v4","options","rnds","v4_default","sha1","sha1_default","v5","v5_default","Utils","key","variantId","searchId","Utils_default","ResponseUtility","res","status","data","knownError","logError","response_default","Fetch","baseURL","endpoint","method","headers","payload","completeURL","isInternalAPI","response","errorBody","errorText","body","err","fetch_default","AuthContext","_AuthContext","id","type","token","requestId","assert","fallbackLambdaName","baseId","DefaultAuthUtilityConfig","AuthType","DefaultAuthMiddlewareConfig","AuthUtility","config","userTokenAge","userPrivateKeys","userPublicKeys","anonymousTokenAge","anonymousPrivateKeys","anonymousPublicKeys","systemTokenAge","systemPrivateKeys","systemPublicKeys","adminTokenAge","adminPrivateKeys","adminPublicKeys","cdnKeys","jsonString","keyType","parsed","item","warn","keys","limit","privateKeyString","expiration","privateKey","importPKCS8","SignJWT","publicKeyString","publicKey","importSPKI","jwtVerify","additionalData","email","verifier","permissions","authenticate","allowAnonymous","allowSystem","allowUser","allowCDN","req","next","authType","decodeJwt","authContext","Auth_default"],"mappings":"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","file":"index.js","sourcesContent":["export default Object.freeze({\r\n INVALID_UUID: \"Invalid UUID\",\r\n INVALID_EMAIL: \"Invalid Email\",\r\n INVALID_TOKEN: \"Invalid Token\",\r\n TOKEN_EXPIRED: \"Token Expired\",\r\n INVALID_VERIFIER: \"Invalid Verifier\",\r\n INVALID_PERMISSIONS: \"Invalid Permissions\",\r\n INVALID_AUTH_TYPE: \"Invalid Authorization Type\",\r\n USER_PRIVATE_KEY_NOT_FOUND: \"User Private Key Not Found\",\r\n USER_PUBLIC_KEY_NOT_FOUND: \"User Public Key Not Found\",\r\n ANONYMOUS_PRIVATE_KEY_NOT_FOUND: \"Anonymous Private Key Not Found\",\r\n ANONYMOUS_PUBLIC_KEY_NOT_FOUND: \"Anonymous Public Key Not Found\",\r\n SYSTEM_PRIVATE_KEY_NOT_FOUND: \"System Private Key Not Found\",\r\n SYSTEM_PUBLIC_KEY_NOT_FOUND: \"System Public Key Not Found\",\r\n ADMIN_PRIVATE_KEY_NOT_FOUND: \"Admin Private Key Not Found\",\r\n ADMIN_PUBLIC_KEY_NOT_FOUND: \"Admin Public Key Not Found\",\r\n SECRET_TOKEN_NOT_FOUND: \"Secret Token Not Found\",\r\n ANONYMOUS_SESSION_NOT_ALLOWED: \"Anonymous Session Not Allowed\",\r\n USER_SESSION_NOT_ALLOWED: \"User Session Not Allowed\",\r\n SYSTEM_SESSION_NOT_ALLOWED: \"System Session Not Allowed\",\r\n CDN_SESSION_NOT_ALLOWED: \"CDN Session Not Allowed\",\r\n INTERNAL_SERVER_ERROR: \"Internal Server Error\",\r\n SOMETHING_WENT_WRONG: 'Something went wrong',\r\n AUTH_CONTEXT_NOT_INITIALIZED: 'Auth Context not Initialized'\r\n})","import util from 'util';\r\nconst Logger = {\r\n logException: (functionName: string, error: any) => {\r\n console.error(`Exception Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logError: (functionName: string, error: any) => {\r\n console.error(`Error Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logWarning: (functionName: string, message: any) => {\r\n console.warn(`Warning in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logMessage: (functionName: string, message: any) => {\r\n console.log(`Message in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logInvalidPayload: (functionName: string, errorMessage: string) => {\r\n console.error(`Invalid Payload received for Function: ${functionName}, Error: ${Logger.inspect(errorMessage)}`);\r\n },\r\n\r\n inspect: (context: any) => {\r\n return (typeof context === \"string\" ? context : util.inspect(context));\r\n }\r\n}\r\n\r\nexport default Logger;","import crypto from 'crypto';\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n crypto.randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","export default /^(?:[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;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import { unsafeStringify } from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function v35(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n var _namespace;\n\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (((_namespace = namespace) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","import crypto from 'crypto';\nexport default {\n randomUUID: crypto.randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import crypto from 'crypto';\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return crypto.createHash('sha1').update(bytes).digest();\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nconst v5 = v35('v5', 0x50, sha1);\nexport default v5;","import { v4 as uuidv4, v5 as uuidv5 } from 'uuid';\r\n\r\nconst Utils = {\r\n isUUID: (value: string): boolean => {\r\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\r\n return uuidRegex.test(value);\r\n },\r\n\r\n isEmail: (value: string): boolean => {\r\n const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n return emailRegex.test(value);\r\n },\r\n\r\n isURL: (value: string): boolean => {\r\n const urlRegex = /^(http|https):\\/\\/[^ \"]+$/;\r\n return urlRegex.test(value);\r\n },\r\n \r\n generateUUID: (value?: string, namespace?: string) => {\r\n if(namespace && value){\r\n return uuidv5(value, namespace);\r\n }\r\n return uuidv4();\r\n },\r\n\r\n generateSearchId: (key: string, variantId: string) => {\r\n return `${key}#${variantId}`;\r\n },\r\n\r\n getKeyfromSearchId: (searchId: string) => {\r\n const [key, variantId] = searchId.split('#');\r\n return {\r\n key,\r\n variantId\r\n }\r\n },\r\n}\r\n\r\nexport default Utils;\r\n","import ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport const ResponseUtility = {\r\n handleException: (functionName: string, error: any, res: any) => {\r\n if (error.knownError) {\r\n error.logError && Logger.logError(functionName, error);\r\n res.status(error.status).json({\r\n status: error.status,\r\n error: error.error\r\n });\r\n } else if(error.status && error.error) {\r\n Logger.logException(functionName, error);\r\n res.status(error.status).json({\r\n error: error.errorMessage || JSON.stringify(error.error),\r\n status: error.status,\r\n });\r\n } else {\r\n Logger.logException(functionName, error);\r\n res.status(500).json({\r\n status: 500,\r\n error: ErrorTypes.INTERNAL_SERVER_ERROR\r\n })\r\n }\r\n },\r\n\r\n generateResponse: (status: number, data?: any, error?: string) => {\r\n return {\r\n status,\r\n data,\r\n error\r\n }\r\n },\r\n\r\n generateError: (status: number, error: string, knownError: Boolean = true, logError: boolean = false) => {\r\n return {\r\n status,\r\n error,\r\n knownError,\r\n logError\r\n }\r\n }\r\n}\r\n\r\nexport default ResponseUtility;","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","\"use client\";\r\n\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport type ErrorType = {\r\n status: number;\r\n statusText: string;\r\n error: any;\r\n};\r\n\r\nexport type SuccessType = {\r\n status: number;\r\n statusText: string;\r\n data: any;\r\n};\r\n\r\n/**\r\n * Makes an HTTP request to the specified endpoint using the provided parameters.\r\n *\r\n * @param {string} baseURL - The base URL of the API.\r\n * @param {string} endpoint - The specific endpoint to call.\r\n * @param {'GET' | 'POST' | 'PATCH' | 'DELETE'} [method='GET'] - The HTTP method to use for the request.\r\n * @param {Record<string, string>} [headers={}] - Additional headers to include in the request.\r\n * @param {any} [payload] - The payload to send with the request, if applicable.\r\n * @returns {Promise<SuccessType>} - A promise that resolves to the response data if the request is successful.\r\n * @throws {ErrorType} - Throws an error if the request fails.\r\n */\r\nconst Fetch = async (\r\n baseURL: string,\r\n endpoint: string,\r\n method: 'GET' | 'POST' | 'PATCH' | 'DELETE' = 'GET',\r\n headers: Record<string, string> = {},\r\n payload?: any,\r\n): Promise<SuccessType> => {\r\n const options: RequestInit = {\r\n method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n ...headers,\r\n },\r\n };\r\n\r\n if (method !== 'GET' && payload) {\r\n options.body = JSON.stringify(payload);\r\n }\r\n\r\n const completeURL = `${baseURL}${endpoint ? ('/' + endpoint) : ''}`;\r\n const isInternalAPI = completeURL.includes('api.xetile.com') || completeURL.includes('localhost');\r\n \r\n try {\r\n const response: any = await fetch(completeURL, options);\r\n\r\n if (!response.ok) {\r\n let errorBody: any;\r\n const errorText = await response.text();\r\n\r\n try {\r\n errorBody = JSON.parse(errorText);\r\n } catch (parseError) {\r\n errorBody = {\r\n status: response.status,\r\n error: errorText || response.statusText\r\n };\r\n Logger.logWarning('Fetch', `Failed to parse error response body as JSON for URL-${completeURL}. Raw text: ${errorText}`);\r\n }\r\n\r\n throw {\r\n status: response.status,\r\n statusText: response.statusText,\r\n error: errorBody\r\n } as ErrorType;\r\n }\r\n\r\n const body = await response.json();\r\n\r\n Logger.logMessage('Fetch', `API call successful: URL-${completeURL}, Status- ${response.status}`);\r\n return {\r\n status: response.status,\r\n statusText: response.statusText,\r\n data: isInternalAPI ? body.data : body,\r\n } as SuccessType;\r\n } catch (err: any) {\r\n \r\n Logger.logError('Fetch', `API call failed: URL-${completeURL}, Status- ${err.status || 500}, Error- ${Logger.inspect(err.error || err)}`);\r\n throw {\r\n status: err.status || 500,\r\n statusText: err.statusText || ErrorTypes.INTERNAL_SERVER_ERROR,\r\n error: err.error || {\r\n status: err.status || 500,\r\n error: err.statusText || ErrorTypes.SOMETHING_WENT_WRONG,\r\n }\r\n } as ErrorType;\r\n }\r\n};\r\n\r\nexport default Fetch;\r\n","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}"]}
|
package/dist/Auth/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import {b,c as c$1,a as a$1,e,d}from'../chunk-
|
|
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
|
|
2
2
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import h from'crypto';import W from'util';var I=new Uint8Array(256),x=I.length;function T(){return x>I.length-16&&(h.randomFillSync(I),x=0),I.slice(x,x+=16)}var R=/^(?:[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 L(t){return typeof t=="string"&&R.test(t)}var A=L;var n=[];for(let t=0;t<256;++t)n.push((t+256).toString(16).slice(1));function y(t,r=0){return n[t[r+0]]+n[t[r+1]]+n[t[r+2]]+n[t[r+3]]+"-"+n[t[r+4]]+n[t[r+5]]+"-"+n[t[r+6]]+n[t[r+7]]+"-"+n[t[r+8]]+n[t[r+9]]+"-"+n[t[r+10]]+n[t[r+11]]+n[t[r+12]]+n[t[r+13]]+n[t[r+14]]+n[t[r+15]]}function F(t){if(!A(t))throw TypeError("Invalid UUID");let r,e=new Uint8Array(16);return e[0]=(r=parseInt(t.slice(0,8),16))>>>24,e[1]=r>>>16&255,e[2]=r>>>8&255,e[3]=r&255,e[4]=(r=parseInt(t.slice(9,13),16))>>>8,e[5]=r&255,e[6]=(r=parseInt(t.slice(14,18),16))>>>8,e[7]=r&255,e[8]=(r=parseInt(t.slice(19,23),16))>>>8,e[9]=r&255,e[10]=(r=parseInt(t.slice(24,36),16))/1099511627776&255,e[11]=r/4294967296&255,e[12]=r>>>24&255,e[13]=r>>>16&255,e[14]=r>>>8&255,e[15]=r&255,e}var D=F;function P(t){t=unescape(encodeURIComponent(t));let r=[];for(let e=0;e<t.length;++e)r.push(t.charCodeAt(e));return r}var $="6ba7b810-9dad-11d1-80b4-00c04fd430c8",w="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function _(t,r,e){function s(u,f,c,g){var o;if(typeof u=="string"&&(u=P(u)),typeof f=="string"&&(f=D(f)),((o=f)===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+u.length);if(l.set(f),l.set(u,f.length),l=e(l),l[6]=l[6]&15|r,l[8]=l[8]&63|128,c){g=g||0;for(let d=0;d<16;++d)c[g+d]=l[d];return c}return y(l)}try{s.name=t;}catch{}return s.DNS=$,s.URL=w,s}var S={randomUUID:h.randomUUID};function b(t,r,e){if(S.randomUUID&&!r&&!t)return S.randomUUID();t=t||{};let s=t.random||(t.rng||T)();if(s[6]=s[6]&15|64,s[8]=s[8]&63|128,r){e=e||0;for(let u=0;u<16;++u)r[e+u]=s[u];return r}return y(s)}var U=b;function V(t){return Array.isArray(t)?t=Buffer.from(t):typeof t=="string"&&(t=Buffer.from(t,"utf8")),h.createHash("sha1").update(t).digest()}var v=V;var Y=_("v5",80,v),O=Y;var C={isUUID:t=>/^[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(t),isEmail:t=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(t),isURL:t=>/^(http|https):\/\/[^ "]+$/.test(t),generateUUID:(t,r)=>r&&t?O(t,r):U(),generateSearchId:(t,r)=>`${t}#${r}`,getKeyfromSearchId:t=>{let[r,e]=t.split("#");return {key:r,variantId:e}}},vt=C;var N=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:(t,r)=>{console.error(`Exception Occurred in Function: ${t}, Error: ${E.inspect(r)}`);},logError:(t,r)=>{console.error(`Error Occurred in Function: ${t}, Error: ${E.inspect(r)}`);},logWarning:(t,r)=>{console.warn(`Warning in Function: ${t} - ${E.inspect(r)}`);},logMessage:(t,r)=>{console.log(`Message in Function: ${t} - ${E.inspect(r)}`);},logInvalidPayload:(t,r)=>{console.error(`Invalid Payload received for Function: ${t}, Error: ${E.inspect(r)}`);},inspect:t=>typeof t=="string"?t:W.inspect(t)},p=E;var B={handleException:(t,r,e)=>{r.knownError?(r.logError&&p.logError(t,r),e.status(r.status).json({status:r.status,error:r.error})):r.status&&r.error?(p.logException(t,r),e.status(r.status).json({error:r.errorMessage||JSON.stringify(r.error),status:r.status})):(p.logException(t,r),e.status(500).json({status:500,error:N.INTERNAL_SERVER_ERROR}));},generateResponse:(t,r,e)=>({status:t,data:r,error:e}),generateError:(t,r,e=!0,s=!1)=>({status:t,error:r,knownError:e,logError:s})},Vt=B;var G=async(t,r,e="GET",s={},u)=>{let f={method:e,headers:{"Content-Type":"application/json",...s}};e!=="GET"&&u&&(f.body=JSON.stringify(u));let c=`${t}${r?"/"+r:""}`,g=c.includes("api.xetile.com")||c.includes("localhost");try{let o=await fetch(c,f);if(!o.ok){let d,m=await o.text();try{d=JSON.parse(m);}catch{d={status:o.status,error:m||o.statusText},p.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${c}. Raw text: ${m}`);}throw {status:o.status,statusText:o.statusText,error:d}}let l=await o.json();return p.logMessage("Fetch",`API call successful: URL-${c}, Status- ${o.status}`),{status:o.status,statusText:o.statusText,data:g?l.data:l}}catch(o){throw p.logError("Fetch",`API call failed: URL-${c}, Status- ${o.status||500}, Error- ${p.inspect(o.error||o)}`),{status:o.status||500,statusText:o.statusText||N.INTERNAL_SERVER_ERROR,error:o.error||{status:o.status||500,error:o.statusText||N.SOMETHING_WENT_WRONG}}}},Gt=G;export{vt as a,N as b,p as c,Vt as d,Gt as e};//# sourceMappingURL=chunk-CKUUUEWT.mjs.map
|
|
2
|
+
//# sourceMappingURL=chunk-CKUUUEWT.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../node_modules/uuid/dist/esm-node/rng.js","../node_modules/uuid/dist/esm-node/regex.js","../node_modules/uuid/dist/esm-node/validate.js","../node_modules/uuid/dist/esm-node/stringify.js","../node_modules/uuid/dist/esm-node/parse.js","../node_modules/uuid/dist/esm-node/v35.js","../node_modules/uuid/dist/esm-node/native.js","../node_modules/uuid/dist/esm-node/v4.js","../node_modules/uuid/dist/esm-node/sha1.js","../node_modules/uuid/dist/esm-node/v5.js","../src/Utils/index.ts","../src/enums/ErrorTypes.ts","../src/Logger/index.ts","../src/Utils/response.ts","../src/Utils/fetch.ts"],"names":["rnds8Pool","poolPtr","rng","crypto","regex_default","validate","uuid","validate_default","byteToHex","i","unsafeStringify","arr","offset","parse","v","parse_default","stringToBytes","str","bytes","DNS","URL","v35","name","version","hashfunc","generateUUID","value","namespace","buf","_namespace","native_default","v4","options","rnds","v4_default","sha1","sha1_default","v5","v5_default","Utils","key","variantId","searchId","Utils_default","ErrorTypes_default","Logger","functionName","error","message","errorMessage","context","util","Logger_default","ResponseUtility","res","status","data","knownError","logError","response_default","Fetch","baseURL","endpoint","method","headers","payload","completeURL","isInternalAPI","response","errorBody","errorText","body","err","fetch_default"],"mappings":"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","file":"chunk-CKUUUEWT.mjs","sourcesContent":["import crypto from 'crypto';\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n crypto.randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","export default /^(?:[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;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import { unsafeStringify } from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function v35(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n var _namespace;\n\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (((_namespace = namespace) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","import crypto from 'crypto';\nexport default {\n randomUUID: crypto.randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import crypto from 'crypto';\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return crypto.createHash('sha1').update(bytes).digest();\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nconst v5 = v35('v5', 0x50, sha1);\nexport default v5;","import { v4 as uuidv4, v5 as uuidv5 } from 'uuid';\r\n\r\nconst Utils = {\r\n isUUID: (value: string): boolean => {\r\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\r\n return uuidRegex.test(value);\r\n },\r\n\r\n isEmail: (value: string): boolean => {\r\n const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n return emailRegex.test(value);\r\n },\r\n\r\n isURL: (value: string): boolean => {\r\n const urlRegex = /^(http|https):\\/\\/[^ \"]+$/;\r\n return urlRegex.test(value);\r\n },\r\n \r\n generateUUID: (value?: string, namespace?: string) => {\r\n if(namespace && value){\r\n return uuidv5(value, namespace);\r\n }\r\n return uuidv4();\r\n },\r\n\r\n generateSearchId: (key: string, variantId: string) => {\r\n return `${key}#${variantId}`;\r\n },\r\n\r\n getKeyfromSearchId: (searchId: string) => {\r\n const [key, variantId] = searchId.split('#');\r\n return {\r\n key,\r\n variantId\r\n }\r\n },\r\n}\r\n\r\nexport default Utils;\r\n","export default Object.freeze({\r\n INVALID_UUID: \"Invalid UUID\",\r\n INVALID_EMAIL: \"Invalid Email\",\r\n INVALID_TOKEN: \"Invalid Token\",\r\n TOKEN_EXPIRED: \"Token Expired\",\r\n INVALID_VERIFIER: \"Invalid Verifier\",\r\n INVALID_PERMISSIONS: \"Invalid Permissions\",\r\n INVALID_AUTH_TYPE: \"Invalid Authorization Type\",\r\n USER_PRIVATE_KEY_NOT_FOUND: \"User Private Key Not Found\",\r\n USER_PUBLIC_KEY_NOT_FOUND: \"User Public Key Not Found\",\r\n ANONYMOUS_PRIVATE_KEY_NOT_FOUND: \"Anonymous Private Key Not Found\",\r\n ANONYMOUS_PUBLIC_KEY_NOT_FOUND: \"Anonymous Public Key Not Found\",\r\n SYSTEM_PRIVATE_KEY_NOT_FOUND: \"System Private Key Not Found\",\r\n SYSTEM_PUBLIC_KEY_NOT_FOUND: \"System Public Key Not Found\",\r\n ADMIN_PRIVATE_KEY_NOT_FOUND: \"Admin Private Key Not Found\",\r\n ADMIN_PUBLIC_KEY_NOT_FOUND: \"Admin Public Key Not Found\",\r\n SECRET_TOKEN_NOT_FOUND: \"Secret Token Not Found\",\r\n ANONYMOUS_SESSION_NOT_ALLOWED: \"Anonymous Session Not Allowed\",\r\n USER_SESSION_NOT_ALLOWED: \"User Session Not Allowed\",\r\n SYSTEM_SESSION_NOT_ALLOWED: \"System Session Not Allowed\",\r\n CDN_SESSION_NOT_ALLOWED: \"CDN Session Not Allowed\",\r\n INTERNAL_SERVER_ERROR: \"Internal Server Error\",\r\n SOMETHING_WENT_WRONG: 'Something went wrong',\r\n AUTH_CONTEXT_NOT_INITIALIZED: 'Auth Context not Initialized'\r\n})","import util from 'util';\r\nconst Logger = {\r\n logException: (functionName: string, error: any) => {\r\n console.error(`Exception Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logError: (functionName: string, error: any) => {\r\n console.error(`Error Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logWarning: (functionName: string, message: any) => {\r\n console.warn(`Warning in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logMessage: (functionName: string, message: any) => {\r\n console.log(`Message in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logInvalidPayload: (functionName: string, errorMessage: string) => {\r\n console.error(`Invalid Payload received for Function: ${functionName}, Error: ${Logger.inspect(errorMessage)}`);\r\n },\r\n\r\n inspect: (context: any) => {\r\n return (typeof context === \"string\" ? context : util.inspect(context));\r\n }\r\n}\r\n\r\nexport default Logger;","import ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport const ResponseUtility = {\r\n handleException: (functionName: string, error: any, res: any) => {\r\n if (error.knownError) {\r\n error.logError && Logger.logError(functionName, error);\r\n res.status(error.status).json({\r\n status: error.status,\r\n error: error.error\r\n });\r\n } else if(error.status && error.error) {\r\n Logger.logException(functionName, error);\r\n res.status(error.status).json({\r\n error: error.errorMessage || JSON.stringify(error.error),\r\n status: error.status,\r\n });\r\n } else {\r\n Logger.logException(functionName, error);\r\n res.status(500).json({\r\n status: 500,\r\n error: ErrorTypes.INTERNAL_SERVER_ERROR\r\n })\r\n }\r\n },\r\n\r\n generateResponse: (status: number, data?: any, error?: string) => {\r\n return {\r\n status,\r\n data,\r\n error\r\n }\r\n },\r\n\r\n generateError: (status: number, error: string, knownError: Boolean = true, logError: boolean = false) => {\r\n return {\r\n status,\r\n error,\r\n knownError,\r\n logError\r\n }\r\n }\r\n}\r\n\r\nexport default ResponseUtility;","\"use client\";\r\n\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport type ErrorType = {\r\n status: number;\r\n statusText: string;\r\n error: any;\r\n};\r\n\r\nexport type SuccessType = {\r\n status: number;\r\n statusText: string;\r\n data: any;\r\n};\r\n\r\n/**\r\n * Makes an HTTP request to the specified endpoint using the provided parameters.\r\n *\r\n * @param {string} baseURL - The base URL of the API.\r\n * @param {string} endpoint - The specific endpoint to call.\r\n * @param {'GET' | 'POST' | 'PATCH' | 'DELETE'} [method='GET'] - The HTTP method to use for the request.\r\n * @param {Record<string, string>} [headers={}] - Additional headers to include in the request.\r\n * @param {any} [payload] - The payload to send with the request, if applicable.\r\n * @returns {Promise<SuccessType>} - A promise that resolves to the response data if the request is successful.\r\n * @throws {ErrorType} - Throws an error if the request fails.\r\n */\r\nconst Fetch = async (\r\n baseURL: string,\r\n endpoint: string,\r\n method: 'GET' | 'POST' | 'PATCH' | 'DELETE' = 'GET',\r\n headers: Record<string, string> = {},\r\n payload?: any,\r\n): Promise<SuccessType> => {\r\n const options: RequestInit = {\r\n method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n ...headers,\r\n },\r\n };\r\n\r\n if (method !== 'GET' && payload) {\r\n options.body = JSON.stringify(payload);\r\n }\r\n\r\n const completeURL = `${baseURL}${endpoint ? ('/' + endpoint) : ''}`;\r\n const isInternalAPI = completeURL.includes('api.xetile.com') || completeURL.includes('localhost');\r\n \r\n try {\r\n const response: any = await fetch(completeURL, options);\r\n\r\n if (!response.ok) {\r\n let errorBody: any;\r\n const errorText = await response.text();\r\n\r\n try {\r\n errorBody = JSON.parse(errorText);\r\n } catch (parseError) {\r\n errorBody = {\r\n status: response.status,\r\n error: errorText || response.statusText\r\n };\r\n Logger.logWarning('Fetch', `Failed to parse error response body as JSON for URL-${completeURL}. Raw text: ${errorText}`);\r\n }\r\n\r\n throw {\r\n status: response.status,\r\n statusText: response.statusText,\r\n error: errorBody\r\n } as ErrorType;\r\n }\r\n\r\n const body = await response.json();\r\n\r\n Logger.logMessage('Fetch', `API call successful: URL-${completeURL}, Status- ${response.status}`);\r\n return {\r\n status: response.status,\r\n statusText: response.statusText,\r\n data: isInternalAPI ? body.data : body,\r\n } as SuccessType;\r\n } catch (err: any) {\r\n \r\n Logger.logError('Fetch', `API call failed: URL-${completeURL}, Status- ${err.status || 500}, Error- ${Logger.inspect(err.error || err)}`);\r\n throw {\r\n status: err.status || 500,\r\n statusText: err.statusText || ErrorTypes.INTERNAL_SERVER_ERROR,\r\n error: err.error || {\r\n status: err.status || 500,\r\n error: err.statusText || ErrorTypes.SOMETHING_WENT_WRONG,\r\n }\r\n } as ErrorType;\r\n }\r\n};\r\n\r\nexport default Fetch;\r\n"]}
|
package/dist/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var
|
|
2
|
-
exports.Fetch=
|
|
1
|
+
'use strict';var F=require('crypto'),W=require('util');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var F__default=/*#__PURE__*/_interopDefault(F);var W__default=/*#__PURE__*/_interopDefault(W);var A={$id:"standards",definitions:{lowercaseText:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]*$"},lowercaseText10:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,10}$"},lowercaseText16:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,16}$"},lowercaseText30:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,30}$"},lowercaseText50:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,50}$"},lowercaseText256:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,256}$"},text:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).*$"},text10:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,10}$"},text16:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,16}$"},text30:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,30}$"},text50:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,50}$"},text256:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,256}$"},requiredText:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).+$"},requiredText10:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,10}$"},requiredText16:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,16}$"},requiredText30:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,30}$"},requiredText50:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,50}$"},requiredText256:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,256}$"},url:{type:"string",pattern:"^https://[^\\s/$.?#].[^\\s]*$",maxLength:2048},uuid:{type:"string",minLength:1,pattern:"^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$"},productKey:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[A-Z0-9-]{4,16}$"},variantId:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[A-Z0-9-]{4,16}$"},firstName:{$ref:"#/definitions/requiredText30"},lastName:{$ref:"#/definitions/text30"},phone:{type:"string",pattern:"^[0-9]{10}$"},email:{type:"string",pattern:"^[^\\s]+@[^\\s]+\\.[^\\s]+$"},addressLine1:{$ref:"#/definitions/requiredText50"},addressLine2:{$ref:"#/definitions/text50"},city:{$ref:"#/definitions/requiredText30"},postalCode:{$ref:"#/definitions/requiredText16"},state:{type:"string",enum:["AP","AR","AS","BR","CT","GA","GJ","HR","HP","JH","KA","KL","MP","MH","MN","ML","MZ","NL","OR","PB","RJ","SK","TN","TG","TR","UP","UT","WB","AN","CH","DH","LD","DL","PY","LA","JK"]},country:{type:"string",enum:["IN"]},currency:{type:"string",enum:["INR"]},locale:{type:"string",enum:["en-IN"]},addressType:{type:"string",enum:["shipping","billing","billing&shipping"]},address:{type:"object",properties:{firstName:{$ref:"standards#/definitions/firstName"},lastName:{$ref:"standards#/definitions/lastName"},phone:{$ref:"standards#/definitions/phone"},email:{$ref:"standards#/definitions/email"},addressLine1:{$ref:"standards#/definitions/addressLine1"},addressLine2:{$ref:"standards#/definitions/addressLine2"},city:{$ref:"standards#/definitions/city"},postalCode:{$ref:"standards#/definitions/postalCode"},state:{$ref:"standards#/definitions/state"},country:{$ref:"standards#/definitions/country"}},required:["firstName","lastName","phone","email","addressLine1","postalCode","state","country"]}}};var D={getStandardSchemaDefinition(){return A}},v=D;var x=new Uint8Array(256),m=x.length;function N(){return m>x.length-16&&(F__default.default.randomFillSync(x),m=0),x.slice(m,m+=16)}var U=/^(?:[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 P(t){return typeof t=="string"&&U.test(t)}var R=P;var i=[];for(let t=0;t<256;++t)i.push((t+256).toString(16).slice(1));function T(t,e=0){return i[t[e+0]]+i[t[e+1]]+i[t[e+2]]+i[t[e+3]]+"-"+i[t[e+4]]+i[t[e+5]]+"-"+i[t[e+6]]+i[t[e+7]]+"-"+i[t[e+8]]+i[t[e+9]]+"-"+i[t[e+10]]+i[t[e+11]]+i[t[e+12]]+i[t[e+13]]+i[t[e+14]]+i[t[e+15]]}function w(t){if(!R(t))throw TypeError("Invalid UUID");let e,r=new Uint8Array(16);return r[0]=(e=parseInt(t.slice(0,8),16))>>>24,r[1]=e>>>16&255,r[2]=e>>>8&255,r[3]=e&255,r[4]=(e=parseInt(t.slice(9,13),16))>>>8,r[5]=e&255,r[6]=(e=parseInt(t.slice(14,18),16))>>>8,r[7]=e&255,r[8]=(e=parseInt(t.slice(19,23),16))>>>8,r[9]=e&255,r[10]=(e=parseInt(t.slice(24,36),16))/1099511627776&255,r[11]=e/4294967296&255,r[12]=e>>>24&255,r[13]=e>>>16&255,r[14]=e>>>8&255,r[15]=e&255,r}var O=w;function K(t){t=unescape(encodeURIComponent(t));let e=[];for(let r=0;r<t.length;++r)e.push(t.charCodeAt(r));return e}var b="6ba7b810-9dad-11d1-80b4-00c04fd430c8",M="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function $(t,e,r){function o(a,f,d,g){var s;if(typeof a=="string"&&(a=K(a)),typeof f=="string"&&(f=O(f)),((s=f)===null||s===void 0?void 0:s.length)!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let p=new Uint8Array(16+a.length);if(p.set(f),p.set(a,f.length),p=r(p),p[6]=p[6]&15|e,p[8]=p[8]&63|128,d){g=g||0;for(let l=0;l<16;++l)d[g+l]=p[l];return d}return T(p)}try{o.name=t;}catch{}return o.DNS=b,o.URL=M,o}var I={randomUUID:F__default.default.randomUUID};function Y(t,e,r){if(I.randomUUID&&!e&&!t)return I.randomUUID();t=t||{};let o=t.random||(t.rng||N)();if(o[6]=o[6]&15|64,o[8]=o[8]&63|128,e){r=r||0;for(let a=0;a<16;++a)e[r+a]=o[a];return e}return T(o)}var S=Y;function H(t){return Array.isArray(t)?t=Buffer.from(t):typeof t=="string"&&(t=Buffer.from(t,"utf8")),F__default.default.createHash("sha1").update(t).digest()}var L=H;var q=$("v5",80,L),_=q;var z={isUUID:t=>/^[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(t),isEmail:t=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(t),isURL:t=>/^(http|https):\/\/[^ "]+$/.test(t),generateUUID:(t,e)=>e&&t?_(t,e):S(),generateSearchId:(t,e)=>`${t}#${e}`,getKeyfromSearchId:t=>{let[e,r]=t.split("#");return {key:e,variantId:r}}},B=z;var y=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 c={logException:(t,e)=>{console.error(`Exception Occurred in Function: ${t}, Error: ${c.inspect(e)}`);},logError:(t,e)=>{console.error(`Error Occurred in Function: ${t}, Error: ${c.inspect(e)}`);},logWarning:(t,e)=>{console.warn(`Warning in Function: ${t} - ${c.inspect(e)}`);},logMessage:(t,e)=>{console.log(`Message in Function: ${t} - ${c.inspect(e)}`);},logInvalidPayload:(t,e)=>{console.error(`Invalid Payload received for Function: ${t}, Error: ${c.inspect(e)}`);},inspect:t=>typeof t=="string"?t:W__default.default.inspect(t)},u=c;var G={handleException:(t,e,r)=>{e.knownError?(e.logError&&u.logError(t,e),r.status(e.status).json({status:e.status,error:e.error})):e.status&&e.error?(u.logException(t,e),r.status(e.status).json({error:e.errorMessage||JSON.stringify(e.error),status:e.status})):(u.logException(t,e),r.status(500).json({status:500,error:y.INTERNAL_SERVER_ERROR}));},generateResponse:(t,e,r)=>({status:t,data:e,error:r}),generateError:(t,e,r=!0,o=!1)=>({status:t,error:e,knownError:r,logError:o})},J=G;var j=async(t,e,r="GET",o={},a)=>{let f={method:r,headers:{"Content-Type":"application/json",...o}};r!=="GET"&&a&&(f.body=JSON.stringify(a));let d=`${t}${e?"/"+e:""}`,g=d.includes("api.xetile.com")||d.includes("localhost");try{let s=await fetch(d,f);if(!s.ok){let l,E=await s.text();try{l=JSON.parse(E);}catch{l={status:s.status,error:E||s.statusText},u.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${d}. Raw text: ${E}`);}throw {status:s.status,statusText:s.statusText,error:l}}let p=await s.json();return u.logMessage("Fetch",`API call successful: URL-${d}, Status- ${s.status}`),{status:s.status,statusText:s.statusText,data:g?p.data:p}}catch(s){throw u.logError("Fetch",`API call failed: URL-${d}, Status- ${s.status||500}, Error- ${u.inspect(s.error||s)}`),{status:s.status||500,statusText:s.statusText||y.INTERNAL_SERVER_ERROR,error:s.error||{status:s.status||500,error:s.statusText||y.SOMETHING_WENT_WRONG}}}},k=j;
|
|
2
|
+
exports.Fetch=k;exports.Logger=u;exports.ResponseUtility=J;exports.Schema=v;exports.Utils=B;//# sourceMappingURL=index.js.map
|
|
3
3
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/Schema/definition.json","../src/Schema/index.ts","../node_modules/uuid/dist/esm-node/rng.js","../node_modules/uuid/dist/esm-node/regex.js","../node_modules/uuid/dist/esm-node/validate.js","../node_modules/uuid/dist/esm-node/stringify.js","../node_modules/uuid/dist/esm-node/parse.js","../node_modules/uuid/dist/esm-node/v35.js","../node_modules/uuid/dist/esm-node/native.js","../node_modules/uuid/dist/esm-node/v4.js","../node_modules/uuid/dist/esm-node/sha1.js","../node_modules/uuid/dist/esm-node/v5.js","../src/Utils/index.ts","../src/enums/ErrorTypes.ts","../src/Logger/index.ts","../src/Utils/response.ts","../src/Utils/fetch.ts"],"names":["definition_default","Schema","Schema_default","rnds8Pool","poolPtr","rng","crypto","regex_default","validate","uuid","validate_default","byteToHex","i","unsafeStringify","arr","offset","parse","v","parse_default","stringToBytes","str","bytes","DNS","URL","v35","name","version","hashfunc","generateUUID","value","namespace","buf","_namespace","native_default","v4","options","rnds","v4_default","sha1","sha1_default","v5","v5_default","Utils","key","variantId","searchId","Utils_default","ErrorTypes_default","Logger","functionName","error","message","errorMessage","context","util","Logger_default","ResponseUtility","res","status","data","knownError","logError","response_default","Fetch","baseURL","endpoint","method","headers","payload","completeURL","response","errorBody","errorText","body","err","fetch_default"],"mappings":"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","file":"index.js","sourcesContent":["{\r\n \"$id\": \"standards\",\r\n \"definitions\": {\r\n \"lowercaseText\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]*$\"\r\n },\r\n \"lowercaseText10\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,10}$\"\r\n },\r\n \"lowercaseText16\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,16}$\"\r\n },\r\n \"lowercaseText30\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,30}$\"\r\n },\r\n \"lowercaseText50\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,50}$\"\r\n },\r\n \"lowercaseText256\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,256}$\"\r\n },\r\n \"text\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).*$\"\r\n },\r\n \"text10\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,10}$\"\r\n },\r\n \"text16\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,16}$\"\r\n },\r\n \"text30\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,30}$\"\r\n },\r\n \"text50\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,50}$\"\r\n },\r\n \"text256\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,256}$\"\r\n },\r\n \"requiredText\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).+$\"\r\n },\r\n \"requiredText10\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,10}$\"\r\n },\r\n \"requiredText16\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,16}$\"\r\n },\r\n \"requiredText30\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,30}$\"\r\n },\r\n \"requiredText50\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,50}$\"\r\n },\r\n \"requiredText256\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,256}$\"\r\n },\r\n \"url\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^https://[^\\\\s/$.?#].[^\\\\s]*$\",\r\n \"maxLength\": 2048\r\n },\r\n \"uuid\": {\r\n \"type\": \"string\",\r\n \"minLength\": 1,\r\n \"pattern\": \"^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$\"\r\n },\r\n \"productKey\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[A-Z0-9-]{4,16}$\"\r\n },\r\n \"variantId\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[A-Z0-9-]{4,16}$\"\r\n },\r\n \"firstName\": { \"$ref\": \"#/definitions/requiredText30\" },\r\n \"lastName\": { \"$ref\": \"#/definitions/text30\" },\r\n \"phone\": { \r\n \"type\" : \"string\",\r\n \"pattern\": \"^[0-9]{10}$\"\r\n },\r\n \"email\": { \r\n \"type\" : \"string\",\r\n \"pattern\": \"^[^\\\\s]+@[^\\\\s]+\\\\.[^\\\\s]+$\"\r\n },\r\n \"addressLine1\": { \"$ref\": \"#/definitions/requiredText50\" },\r\n \"addressLine2\": { \"$ref\": \"#/definitions/text50\" },\r\n \"city\": { \"$ref\": \"#/definitions/requiredText30\" },\r\n \"postalCode\": { \"$ref\": \"#/definitions/requiredText16\" },\r\n \"state\": {\r\n \"type\": \"string\",\r\n \"enum\": [\"AP\", \"AR\", \"AS\", \"BR\", \"CT\", \"GA\", \"GJ\", \"HR\", \"HP\", \"JH\", \"KA\", \"KL\", \"MP\", \"MH\", \"MN\", \"ML\", \"MZ\", \"NL\", \"OR\", \"PB\", \"RJ\", \"SK\", \"TN\", \"TG\", \"TR\", \"UP\", \"UT\", \"WB\", \"AN\", \"CH\", \"DH\", \"LD\", \"DL\", \"PY\", \"LA\", \"JK\"]\r\n },\r\n \"country\": {\r\n \"type\": \"string\",\r\n \"enum\": [\r\n \"IN\"\r\n ]\r\n },\r\n \"currency\": {\r\n \"type\": \"string\",\r\n \"enum\": [\r\n \"INR\"\r\n ]\r\n },\r\n \"locale\": {\r\n \"type\": \"string\",\r\n \"enum\": [\r\n \"en-IN\"\r\n ]\r\n },\r\n \"addressType\": {\r\n \"type\": \"string\",\r\n \"enum\": [\"shipping\", \"billing\", \"billing&shipping\"]\r\n },\r\n \"address\": {\r\n \"type\": \"object\",\r\n \"properties\": {\r\n \"firstName\": {\"$ref\": \"standards#/definitions/firstName\"},\r\n \"lastName\": { \"$ref\": \"standards#/definitions/lastName\" },\r\n \"phone\": { \"$ref\": \"standards#/definitions/phone\" },\r\n \"email\": { \"$ref\": \"standards#/definitions/email\" },\r\n \"addressLine1\": { \"$ref\": \"standards#/definitions/addressLine1\" },\r\n \"addressLine2\": { \"$ref\": \"standards#/definitions/addressLine2\" },\r\n \"city\": { \"$ref\": \"standards#/definitions/city\" },\r\n \"postalCode\": { \"$ref\": \"standards#/definitions/postalCode\" },\r\n \"state\": { \"$ref\": \"standards#/definitions/state\" },\r\n \"country\": { \"$ref\": \"standards#/definitions/country\" }\r\n },\r\n \"required\": [\"firstName\", \"lastName\", \"phone\", \"email\", \"addressLine1\", \"postalCode\", \"state\", \"country\"]\r\n }\r\n }\r\n}","import SchemaDefinitions from './definition.json';\r\n\r\nconst Schema = {\r\n getStandardSchemaDefinition() {\r\n return SchemaDefinitions;\r\n }\r\n}\r\n\r\nexport default Schema;\r\n","import crypto from 'crypto';\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n crypto.randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","export default /^(?:[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;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import { unsafeStringify } from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function v35(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n var _namespace;\n\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (((_namespace = namespace) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","import crypto from 'crypto';\nexport default {\n randomUUID: crypto.randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import crypto from 'crypto';\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return crypto.createHash('sha1').update(bytes).digest();\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nconst v5 = v35('v5', 0x50, sha1);\nexport default v5;","import { v4 as uuidv4, v5 as uuidv5 } from 'uuid';\r\n\r\nconst Utils = {\r\n isUUID: (value: string): boolean => {\r\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\r\n return uuidRegex.test(value);\r\n },\r\n\r\n isEmail: (value: string): boolean => {\r\n const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n return emailRegex.test(value);\r\n },\r\n\r\n isURL: (value: string): boolean => {\r\n const urlRegex = /^(http|https):\\/\\/[^ \"]+$/;\r\n return urlRegex.test(value);\r\n },\r\n \r\n generateUUID: (value?: string, namespace?: string) => {\r\n if(namespace && value){\r\n return uuidv5(value, namespace);\r\n }\r\n return uuidv4();\r\n },\r\n\r\n generateSearchId: (key: string, variantId: string) => {\r\n return `${key}#${variantId}`;\r\n },\r\n\r\n getKeyfromSearchId: (searchId: string) => {\r\n const [key, variantId] = searchId.split('#');\r\n return {\r\n key,\r\n variantId\r\n }\r\n },\r\n}\r\n\r\nexport default Utils;\r\n","export default Object.freeze({\r\n INVALID_UUID: \"Invalid UUID\",\r\n INVALID_EMAIL: \"Invalid Email\",\r\n INVALID_TOKEN: \"Invalid Token\",\r\n TOKEN_EXPIRED: \"Token Expired\",\r\n INVALID_VERIFIER: \"Invalid Verifier\",\r\n INVALID_PERMISSIONS: \"Invalid Permissions\",\r\n INVALID_AUTH_TYPE: \"Invalid Authorization Type\",\r\n USER_PRIVATE_KEY_NOT_FOUND: \"User Private Key Not Found\",\r\n USER_PUBLIC_KEY_NOT_FOUND: \"User Public Key Not Found\",\r\n ANONYMOUS_PRIVATE_KEY_NOT_FOUND: \"Anonymous Private Key Not Found\",\r\n ANONYMOUS_PUBLIC_KEY_NOT_FOUND: \"Anonymous Public Key Not Found\",\r\n SYSTEM_PRIVATE_KEY_NOT_FOUND: \"System Private Key Not Found\",\r\n SYSTEM_PUBLIC_KEY_NOT_FOUND: \"System Public Key Not Found\",\r\n ADMIN_PRIVATE_KEY_NOT_FOUND: \"Admin Private Key Not Found\",\r\n ADMIN_PUBLIC_KEY_NOT_FOUND: \"Admin Public Key Not Found\",\r\n SECRET_TOKEN_NOT_FOUND: \"Secret Token Not Found\",\r\n ANONYMOUS_SESSION_NOT_ALLOWED: \"Anonymous Session Not Allowed\",\r\n USER_SESSION_NOT_ALLOWED: \"User Session Not Allowed\",\r\n SYSTEM_SESSION_NOT_ALLOWED: \"System Session Not Allowed\",\r\n CDN_SESSION_NOT_ALLOWED: \"CDN Session Not Allowed\",\r\n INTERNAL_SERVER_ERROR: \"Internal Server Error\",\r\n SOMETHING_WENT_WRONG: 'Something went wrong',\r\n AUTH_CONTEXT_NOT_INITIALIZED: 'Auth Context not Initialized'\r\n})","import util from 'util';\r\nconst Logger = {\r\n logException: (functionName: string, error: any) => {\r\n console.error(`Exception Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logError: (functionName: string, error: any) => {\r\n console.error(`Error Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logWarning: (functionName: string, message: any) => {\r\n console.warn(`Warning in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logMessage: (functionName: string, message: any) => {\r\n console.log(`Message in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logInvalidPayload: (functionName: string, errorMessage: string) => {\r\n console.error(`Invalid Payload received for Function: ${functionName}, Error: ${Logger.inspect(errorMessage)}`);\r\n },\r\n\r\n inspect: (context: any) => {\r\n return (typeof context === \"string\" ? context : util.inspect(context));\r\n }\r\n}\r\n\r\nexport default Logger;","import ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport const ResponseUtility = {\r\n handleException: (functionName: string, error: any, res: any) => {\r\n if (error.knownError) {\r\n error.logError && Logger.logError(functionName, error);\r\n res.status(error.status).json({\r\n status: error.status,\r\n error: error.error\r\n });\r\n } else if(error.status && error.error) {\r\n Logger.logException(functionName, error);\r\n res.status(error.status).json({\r\n error: error.errorMessage || JSON.stringify(error.error),\r\n status: error.status,\r\n });\r\n } else {\r\n Logger.logException(functionName, error);\r\n res.status(500).json({\r\n status: 500,\r\n error: ErrorTypes.INTERNAL_SERVER_ERROR\r\n })\r\n }\r\n },\r\n\r\n generateResponse: (status: number, data?: any, error?: string) => {\r\n return {\r\n status,\r\n data,\r\n error\r\n }\r\n },\r\n\r\n generateError: (status: number, error: string, knownError: Boolean = true, logError: boolean = false) => {\r\n return {\r\n status,\r\n error,\r\n knownError,\r\n logError\r\n }\r\n }\r\n}\r\n\r\nexport default ResponseUtility;","\"use client\";\r\n\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport type ErrorType = {\r\n status: number;\r\n statusText: string;\r\n error: any;\r\n};\r\n\r\nexport type SuccessType = {\r\n status: number;\r\n statusText: string;\r\n data: any;\r\n};\r\n\r\n/**\r\n * Makes an HTTP request to the specified endpoint using the provided parameters.\r\n *\r\n * @param {string} baseURL - The base URL of the API.\r\n * @param {string} endpoint - The specific endpoint to call.\r\n * @param {'GET' | 'POST' | 'PATCH' | 'DELETE'} [method='GET'] - The HTTP method to use for the request.\r\n * @param {Record<string, string>} [headers={}] - Additional headers to include in the request.\r\n * @param {any} [payload] - The payload to send with the request, if applicable.\r\n * @returns {Promise<SuccessType>} - A promise that resolves to the response data if the request is successful.\r\n * @throws {ErrorType} - Throws an error if the request fails.\r\n */\r\nconst Fetch = async (\r\n baseURL: string,\r\n endpoint: string,\r\n method: 'GET' | 'POST' | 'PATCH' | 'DELETE' = 'GET',\r\n headers: Record<string, string> = {},\r\n payload?: any,\r\n): Promise<SuccessType> => {\r\n const options: RequestInit = {\r\n method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n ...headers,\r\n },\r\n };\r\n\r\n if (method !== 'GET' && payload) {\r\n options.body = JSON.stringify(payload);\r\n }\r\n\r\n const completeURL = `${baseURL}${endpoint ? ('/' + endpoint) : ''}`\r\n try {\r\n const response: any = await fetch(completeURL, options);\r\n\r\n if (!response.ok) {\r\n let errorBody: any;\r\n const errorText = await response.text();\r\n\r\n try {\r\n errorBody = JSON.parse(errorText);\r\n } catch (parseError) {\r\n errorBody = {\r\n status: response.status,\r\n error: errorText || response.statusText\r\n };\r\n Logger.logWarning('Fetch', `Failed to parse error response body as JSON for URL-${completeURL}. Raw text: ${errorText}`);\r\n }\r\n\r\n throw {\r\n status: response.status,\r\n statusText: response.statusText,\r\n error: errorBody\r\n } as ErrorType;\r\n }\r\n\r\n const body = await response.json();\r\n\r\n Logger.logMessage('Fetch', `API call successful: URL-${completeURL}, Status- ${response.status}`);\r\n return {\r\n status: response.status,\r\n statusText: response.statusText,\r\n data: body.data || { data: body },\r\n } as SuccessType;\r\n } catch (err: any) {\r\n \r\n Logger.logError('Fetch', `API call failed: URL-${completeURL}, Status- ${err.status || 500}, Error- ${Logger.inspect(err.error || err)}`);\r\n throw {\r\n status: err.status || 500,\r\n statusText: err.statusText || ErrorTypes.INTERNAL_SERVER_ERROR,\r\n error: err.error || {\r\n status: err.status || 500,\r\n error: err.statusText || ErrorTypes.SOMETHING_WENT_WRONG,\r\n }\r\n } as ErrorType;\r\n }\r\n};\r\n\r\nexport default Fetch;\r\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/Schema/definition.json","../src/Schema/index.ts","../node_modules/uuid/dist/esm-node/rng.js","../node_modules/uuid/dist/esm-node/regex.js","../node_modules/uuid/dist/esm-node/validate.js","../node_modules/uuid/dist/esm-node/stringify.js","../node_modules/uuid/dist/esm-node/parse.js","../node_modules/uuid/dist/esm-node/v35.js","../node_modules/uuid/dist/esm-node/native.js","../node_modules/uuid/dist/esm-node/v4.js","../node_modules/uuid/dist/esm-node/sha1.js","../node_modules/uuid/dist/esm-node/v5.js","../src/Utils/index.ts","../src/enums/ErrorTypes.ts","../src/Logger/index.ts","../src/Utils/response.ts","../src/Utils/fetch.ts"],"names":["definition_default","Schema","Schema_default","rnds8Pool","poolPtr","rng","crypto","regex_default","validate","uuid","validate_default","byteToHex","i","unsafeStringify","arr","offset","parse","v","parse_default","stringToBytes","str","bytes","DNS","URL","v35","name","version","hashfunc","generateUUID","value","namespace","buf","_namespace","native_default","v4","options","rnds","v4_default","sha1","sha1_default","v5","v5_default","Utils","key","variantId","searchId","Utils_default","ErrorTypes_default","Logger","functionName","error","message","errorMessage","context","util","Logger_default","ResponseUtility","res","status","data","knownError","logError","response_default","Fetch","baseURL","endpoint","method","headers","payload","completeURL","isInternalAPI","response","errorBody","errorText","body","err","fetch_default"],"mappings":"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","file":"index.js","sourcesContent":["{\r\n \"$id\": \"standards\",\r\n \"definitions\": {\r\n \"lowercaseText\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]*$\"\r\n },\r\n \"lowercaseText10\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,10}$\"\r\n },\r\n \"lowercaseText16\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,16}$\"\r\n },\r\n \"lowercaseText30\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,30}$\"\r\n },\r\n \"lowercaseText50\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,50}$\"\r\n },\r\n \"lowercaseText256\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[a-z]{0,256}$\"\r\n },\r\n \"text\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).*$\"\r\n },\r\n \"text10\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,10}$\"\r\n },\r\n \"text16\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,16}$\"\r\n },\r\n \"text30\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,30}$\"\r\n },\r\n \"text50\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,50}$\"\r\n },\r\n \"text256\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{0,256}$\"\r\n },\r\n \"requiredText\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).+$\"\r\n },\r\n \"requiredText10\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,10}$\"\r\n },\r\n \"requiredText16\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,16}$\"\r\n },\r\n \"requiredText30\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,30}$\"\r\n },\r\n \"requiredText50\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,50}$\"\r\n },\r\n \"requiredText256\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$).{1,256}$\"\r\n },\r\n \"url\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^https://[^\\\\s/$.?#].[^\\\\s]*$\",\r\n \"maxLength\": 2048\r\n },\r\n \"uuid\": {\r\n \"type\": \"string\",\r\n \"minLength\": 1,\r\n \"pattern\": \"^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$\"\r\n },\r\n \"productKey\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[A-Z0-9-]{4,16}$\"\r\n },\r\n \"variantId\": {\r\n \"type\": \"string\",\r\n \"pattern\": \"^(?!\\\\s)(?!.*\\\\s$)[A-Z0-9-]{4,16}$\"\r\n },\r\n \"firstName\": { \"$ref\": \"#/definitions/requiredText30\" },\r\n \"lastName\": { \"$ref\": \"#/definitions/text30\" },\r\n \"phone\": { \r\n \"type\" : \"string\",\r\n \"pattern\": \"^[0-9]{10}$\"\r\n },\r\n \"email\": { \r\n \"type\" : \"string\",\r\n \"pattern\": \"^[^\\\\s]+@[^\\\\s]+\\\\.[^\\\\s]+$\"\r\n },\r\n \"addressLine1\": { \"$ref\": \"#/definitions/requiredText50\" },\r\n \"addressLine2\": { \"$ref\": \"#/definitions/text50\" },\r\n \"city\": { \"$ref\": \"#/definitions/requiredText30\" },\r\n \"postalCode\": { \"$ref\": \"#/definitions/requiredText16\" },\r\n \"state\": {\r\n \"type\": \"string\",\r\n \"enum\": [\"AP\", \"AR\", \"AS\", \"BR\", \"CT\", \"GA\", \"GJ\", \"HR\", \"HP\", \"JH\", \"KA\", \"KL\", \"MP\", \"MH\", \"MN\", \"ML\", \"MZ\", \"NL\", \"OR\", \"PB\", \"RJ\", \"SK\", \"TN\", \"TG\", \"TR\", \"UP\", \"UT\", \"WB\", \"AN\", \"CH\", \"DH\", \"LD\", \"DL\", \"PY\", \"LA\", \"JK\"]\r\n },\r\n \"country\": {\r\n \"type\": \"string\",\r\n \"enum\": [\r\n \"IN\"\r\n ]\r\n },\r\n \"currency\": {\r\n \"type\": \"string\",\r\n \"enum\": [\r\n \"INR\"\r\n ]\r\n },\r\n \"locale\": {\r\n \"type\": \"string\",\r\n \"enum\": [\r\n \"en-IN\"\r\n ]\r\n },\r\n \"addressType\": {\r\n \"type\": \"string\",\r\n \"enum\": [\"shipping\", \"billing\", \"billing&shipping\"]\r\n },\r\n \"address\": {\r\n \"type\": \"object\",\r\n \"properties\": {\r\n \"firstName\": {\"$ref\": \"standards#/definitions/firstName\"},\r\n \"lastName\": { \"$ref\": \"standards#/definitions/lastName\" },\r\n \"phone\": { \"$ref\": \"standards#/definitions/phone\" },\r\n \"email\": { \"$ref\": \"standards#/definitions/email\" },\r\n \"addressLine1\": { \"$ref\": \"standards#/definitions/addressLine1\" },\r\n \"addressLine2\": { \"$ref\": \"standards#/definitions/addressLine2\" },\r\n \"city\": { \"$ref\": \"standards#/definitions/city\" },\r\n \"postalCode\": { \"$ref\": \"standards#/definitions/postalCode\" },\r\n \"state\": { \"$ref\": \"standards#/definitions/state\" },\r\n \"country\": { \"$ref\": \"standards#/definitions/country\" }\r\n },\r\n \"required\": [\"firstName\", \"lastName\", \"phone\", \"email\", \"addressLine1\", \"postalCode\", \"state\", \"country\"]\r\n }\r\n }\r\n}","import SchemaDefinitions from './definition.json';\r\n\r\nconst Schema = {\r\n getStandardSchemaDefinition() {\r\n return SchemaDefinitions;\r\n }\r\n}\r\n\r\nexport default Schema;\r\n","import crypto from 'crypto';\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n crypto.randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","export default /^(?:[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;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import { unsafeStringify } from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function v35(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n var _namespace;\n\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (((_namespace = namespace) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","import crypto from 'crypto';\nexport default {\n randomUUID: crypto.randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import crypto from 'crypto';\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return crypto.createHash('sha1').update(bytes).digest();\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nconst v5 = v35('v5', 0x50, sha1);\nexport default v5;","import { v4 as uuidv4, v5 as uuidv5 } from 'uuid';\r\n\r\nconst Utils = {\r\n isUUID: (value: string): boolean => {\r\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\r\n return uuidRegex.test(value);\r\n },\r\n\r\n isEmail: (value: string): boolean => {\r\n const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n return emailRegex.test(value);\r\n },\r\n\r\n isURL: (value: string): boolean => {\r\n const urlRegex = /^(http|https):\\/\\/[^ \"]+$/;\r\n return urlRegex.test(value);\r\n },\r\n \r\n generateUUID: (value?: string, namespace?: string) => {\r\n if(namespace && value){\r\n return uuidv5(value, namespace);\r\n }\r\n return uuidv4();\r\n },\r\n\r\n generateSearchId: (key: string, variantId: string) => {\r\n return `${key}#${variantId}`;\r\n },\r\n\r\n getKeyfromSearchId: (searchId: string) => {\r\n const [key, variantId] = searchId.split('#');\r\n return {\r\n key,\r\n variantId\r\n }\r\n },\r\n}\r\n\r\nexport default Utils;\r\n","export default Object.freeze({\r\n INVALID_UUID: \"Invalid UUID\",\r\n INVALID_EMAIL: \"Invalid Email\",\r\n INVALID_TOKEN: \"Invalid Token\",\r\n TOKEN_EXPIRED: \"Token Expired\",\r\n INVALID_VERIFIER: \"Invalid Verifier\",\r\n INVALID_PERMISSIONS: \"Invalid Permissions\",\r\n INVALID_AUTH_TYPE: \"Invalid Authorization Type\",\r\n USER_PRIVATE_KEY_NOT_FOUND: \"User Private Key Not Found\",\r\n USER_PUBLIC_KEY_NOT_FOUND: \"User Public Key Not Found\",\r\n ANONYMOUS_PRIVATE_KEY_NOT_FOUND: \"Anonymous Private Key Not Found\",\r\n ANONYMOUS_PUBLIC_KEY_NOT_FOUND: \"Anonymous Public Key Not Found\",\r\n SYSTEM_PRIVATE_KEY_NOT_FOUND: \"System Private Key Not Found\",\r\n SYSTEM_PUBLIC_KEY_NOT_FOUND: \"System Public Key Not Found\",\r\n ADMIN_PRIVATE_KEY_NOT_FOUND: \"Admin Private Key Not Found\",\r\n ADMIN_PUBLIC_KEY_NOT_FOUND: \"Admin Public Key Not Found\",\r\n SECRET_TOKEN_NOT_FOUND: \"Secret Token Not Found\",\r\n ANONYMOUS_SESSION_NOT_ALLOWED: \"Anonymous Session Not Allowed\",\r\n USER_SESSION_NOT_ALLOWED: \"User Session Not Allowed\",\r\n SYSTEM_SESSION_NOT_ALLOWED: \"System Session Not Allowed\",\r\n CDN_SESSION_NOT_ALLOWED: \"CDN Session Not Allowed\",\r\n INTERNAL_SERVER_ERROR: \"Internal Server Error\",\r\n SOMETHING_WENT_WRONG: 'Something went wrong',\r\n AUTH_CONTEXT_NOT_INITIALIZED: 'Auth Context not Initialized'\r\n})","import util from 'util';\r\nconst Logger = {\r\n logException: (functionName: string, error: any) => {\r\n console.error(`Exception Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logError: (functionName: string, error: any) => {\r\n console.error(`Error Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logWarning: (functionName: string, message: any) => {\r\n console.warn(`Warning in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logMessage: (functionName: string, message: any) => {\r\n console.log(`Message in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logInvalidPayload: (functionName: string, errorMessage: string) => {\r\n console.error(`Invalid Payload received for Function: ${functionName}, Error: ${Logger.inspect(errorMessage)}`);\r\n },\r\n\r\n inspect: (context: any) => {\r\n return (typeof context === \"string\" ? context : util.inspect(context));\r\n }\r\n}\r\n\r\nexport default Logger;","import ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport const ResponseUtility = {\r\n handleException: (functionName: string, error: any, res: any) => {\r\n if (error.knownError) {\r\n error.logError && Logger.logError(functionName, error);\r\n res.status(error.status).json({\r\n status: error.status,\r\n error: error.error\r\n });\r\n } else if(error.status && error.error) {\r\n Logger.logException(functionName, error);\r\n res.status(error.status).json({\r\n error: error.errorMessage || JSON.stringify(error.error),\r\n status: error.status,\r\n });\r\n } else {\r\n Logger.logException(functionName, error);\r\n res.status(500).json({\r\n status: 500,\r\n error: ErrorTypes.INTERNAL_SERVER_ERROR\r\n })\r\n }\r\n },\r\n\r\n generateResponse: (status: number, data?: any, error?: string) => {\r\n return {\r\n status,\r\n data,\r\n error\r\n }\r\n },\r\n\r\n generateError: (status: number, error: string, knownError: Boolean = true, logError: boolean = false) => {\r\n return {\r\n status,\r\n error,\r\n knownError,\r\n logError\r\n }\r\n }\r\n}\r\n\r\nexport default ResponseUtility;","\"use client\";\r\n\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport type ErrorType = {\r\n status: number;\r\n statusText: string;\r\n error: any;\r\n};\r\n\r\nexport type SuccessType = {\r\n status: number;\r\n statusText: string;\r\n data: any;\r\n};\r\n\r\n/**\r\n * Makes an HTTP request to the specified endpoint using the provided parameters.\r\n *\r\n * @param {string} baseURL - The base URL of the API.\r\n * @param {string} endpoint - The specific endpoint to call.\r\n * @param {'GET' | 'POST' | 'PATCH' | 'DELETE'} [method='GET'] - The HTTP method to use for the request.\r\n * @param {Record<string, string>} [headers={}] - Additional headers to include in the request.\r\n * @param {any} [payload] - The payload to send with the request, if applicable.\r\n * @returns {Promise<SuccessType>} - A promise that resolves to the response data if the request is successful.\r\n * @throws {ErrorType} - Throws an error if the request fails.\r\n */\r\nconst Fetch = async (\r\n baseURL: string,\r\n endpoint: string,\r\n method: 'GET' | 'POST' | 'PATCH' | 'DELETE' = 'GET',\r\n headers: Record<string, string> = {},\r\n payload?: any,\r\n): Promise<SuccessType> => {\r\n const options: RequestInit = {\r\n method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n ...headers,\r\n },\r\n };\r\n\r\n if (method !== 'GET' && payload) {\r\n options.body = JSON.stringify(payload);\r\n }\r\n\r\n const completeURL = `${baseURL}${endpoint ? ('/' + endpoint) : ''}`;\r\n const isInternalAPI = completeURL.includes('api.xetile.com') || completeURL.includes('localhost');\r\n \r\n try {\r\n const response: any = await fetch(completeURL, options);\r\n\r\n if (!response.ok) {\r\n let errorBody: any;\r\n const errorText = await response.text();\r\n\r\n try {\r\n errorBody = JSON.parse(errorText);\r\n } catch (parseError) {\r\n errorBody = {\r\n status: response.status,\r\n error: errorText || response.statusText\r\n };\r\n Logger.logWarning('Fetch', `Failed to parse error response body as JSON for URL-${completeURL}. Raw text: ${errorText}`);\r\n }\r\n\r\n throw {\r\n status: response.status,\r\n statusText: response.statusText,\r\n error: errorBody\r\n } as ErrorType;\r\n }\r\n\r\n const body = await response.json();\r\n\r\n Logger.logMessage('Fetch', `API call successful: URL-${completeURL}, Status- ${response.status}`);\r\n return {\r\n status: response.status,\r\n statusText: response.statusText,\r\n data: isInternalAPI ? body.data : body,\r\n } as SuccessType;\r\n } catch (err: any) {\r\n \r\n Logger.logError('Fetch', `API call failed: URL-${completeURL}, Status- ${err.status || 500}, Error- ${Logger.inspect(err.error || err)}`);\r\n throw {\r\n status: err.status || 500,\r\n statusText: err.statusText || ErrorTypes.INTERNAL_SERVER_ERROR,\r\n error: err.error || {\r\n status: err.status || 500,\r\n error: err.statusText || ErrorTypes.SOMETHING_WENT_WRONG,\r\n }\r\n } as ErrorType;\r\n }\r\n};\r\n\r\nexport default Fetch;\r\n"]}
|
package/dist/index.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export{e as Fetch,c as Logger,d as ResponseUtility,a as Utils}from'./chunk-
|
|
1
|
+
export{e as Fetch,c as Logger,d as ResponseUtility,a as Utils}from'./chunk-CKUUUEWT.mjs';var e={$id:"standards",definitions:{lowercaseText:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]*$"},lowercaseText10:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,10}$"},lowercaseText16:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,16}$"},lowercaseText30:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,30}$"},lowercaseText50:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,50}$"},lowercaseText256:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[a-z]{0,256}$"},text:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).*$"},text10:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,10}$"},text16:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,16}$"},text30:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,30}$"},text50:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,50}$"},text256:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{0,256}$"},requiredText:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).+$"},requiredText10:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,10}$"},requiredText16:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,16}$"},requiredText30:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,30}$"},requiredText50:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,50}$"},requiredText256:{type:"string",pattern:"^(?!\\s)(?!.*\\s$).{1,256}$"},url:{type:"string",pattern:"^https://[^\\s/$.?#].[^\\s]*$",maxLength:2048},uuid:{type:"string",minLength:1,pattern:"^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$"},productKey:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[A-Z0-9-]{4,16}$"},variantId:{type:"string",pattern:"^(?!\\s)(?!.*\\s$)[A-Z0-9-]{4,16}$"},firstName:{$ref:"#/definitions/requiredText30"},lastName:{$ref:"#/definitions/text30"},phone:{type:"string",pattern:"^[0-9]{10}$"},email:{type:"string",pattern:"^[^\\s]+@[^\\s]+\\.[^\\s]+$"},addressLine1:{$ref:"#/definitions/requiredText50"},addressLine2:{$ref:"#/definitions/text50"},city:{$ref:"#/definitions/requiredText30"},postalCode:{$ref:"#/definitions/requiredText16"},state:{type:"string",enum:["AP","AR","AS","BR","CT","GA","GJ","HR","HP","JH","KA","KL","MP","MH","MN","ML","MZ","NL","OR","PB","RJ","SK","TN","TG","TR","UP","UT","WB","AN","CH","DH","LD","DL","PY","LA","JK"]},country:{type:"string",enum:["IN"]},currency:{type:"string",enum:["INR"]},locale:{type:"string",enum:["en-IN"]},addressType:{type:"string",enum:["shipping","billing","billing&shipping"]},address:{type:"object",properties:{firstName:{$ref:"standards#/definitions/firstName"},lastName:{$ref:"standards#/definitions/lastName"},phone:{$ref:"standards#/definitions/phone"},email:{$ref:"standards#/definitions/email"},addressLine1:{$ref:"standards#/definitions/addressLine1"},addressLine2:{$ref:"standards#/definitions/addressLine2"},city:{$ref:"standards#/definitions/city"},postalCode:{$ref:"standards#/definitions/postalCode"},state:{$ref:"standards#/definitions/state"},country:{$ref:"standards#/definitions/country"}},required:["firstName","lastName","phone","email","addressLine1","postalCode","state","country"]}}};var d={getStandardSchemaDefinition(){return e}},o=d;
|
|
2
2
|
export{o as Schema};//# sourceMappingURL=index.mjs.map
|
|
3
3
|
//# sourceMappingURL=index.mjs.map
|
package/package.json
CHANGED
package/dist/chunk-6S4JI32B.mjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import v from'crypto';import C from'util';var I=new Uint8Array(256),x=I.length;function T(){return x>I.length-16&&(v.randomFillSync(I),x=0),I.slice(x,x+=16)}var O=/^(?:[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 L(t){return typeof t=="string"&&O.test(t)}var R=L;var n=[];for(let t=0;t<256;++t)n.push((t+256).toString(16).slice(1));function y(t,r=0){return n[t[r+0]]+n[t[r+1]]+n[t[r+2]]+n[t[r+3]]+"-"+n[t[r+4]]+n[t[r+5]]+"-"+n[t[r+6]]+n[t[r+7]]+"-"+n[t[r+8]]+n[t[r+9]]+"-"+n[t[r+10]]+n[t[r+11]]+n[t[r+12]]+n[t[r+13]]+n[t[r+14]]+n[t[r+15]]}function h(t){if(!R(t))throw TypeError("Invalid UUID");let r,e=new Uint8Array(16);return e[0]=(r=parseInt(t.slice(0,8),16))>>>24,e[1]=r>>>16&255,e[2]=r>>>8&255,e[3]=r&255,e[4]=(r=parseInt(t.slice(9,13),16))>>>8,e[5]=r&255,e[6]=(r=parseInt(t.slice(14,18),16))>>>8,e[7]=r&255,e[8]=(r=parseInt(t.slice(19,23),16))>>>8,e[9]=r&255,e[10]=(r=parseInt(t.slice(24,36),16))/1099511627776&255,e[11]=r/4294967296&255,e[12]=r>>>24&255,e[13]=r>>>16&255,e[14]=r>>>8&255,e[15]=r&255,e}var A=h;function F(t){t=unescape(encodeURIComponent(t));let r=[];for(let e=0;e<t.length;++e)r.push(t.charCodeAt(e));return r}var P="6ba7b810-9dad-11d1-80b4-00c04fd430c8",$="6ba7b811-9dad-11d1-80b4-00c04fd430c8";function m(t,r,e){function s(u,f,p,o){var E;if(typeof u=="string"&&(u=F(u)),typeof f=="string"&&(f=A(f)),((E=f)===null||E===void 0?void 0:E.length)!==16)throw TypeError("Namespace must be array-like (16 iterable integer values, 0-255)");let l=new Uint8Array(16+u.length);if(l.set(f),l.set(u,f.length),l=e(l),l[6]=l[6]&15|r,l[8]=l[8]&63|128,p){o=o||0;for(let d=0;d<16;++d)p[o+d]=l[d];return p}return y(l)}try{s.name=t;}catch{}return s.DNS=P,s.URL=$,s}var _={randomUUID:v.randomUUID};function K(t,r,e){if(_.randomUUID&&!r&&!t)return _.randomUUID();t=t||{};let s=t.random||(t.rng||T)();if(s[6]=s[6]&15|64,s[8]=s[8]&63|128,r){e=e||0;for(let u=0;u<16;++u)r[e+u]=s[u];return r}return y(s)}var S=K;function M(t){return Array.isArray(t)?t=Buffer.from(t):typeof t=="string"&&(t=Buffer.from(t,"utf8")),v.createHash("sha1").update(t).digest()}var D=M;var V=m("v5",80,D),U=V;var Y={isUUID:t=>/^[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(t),isEmail:t=>/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/.test(t),isURL:t=>/^(http|https):\/\/[^ "]+$/.test(t),generateUUID:(t,r)=>r&&t?U(t,r):S(),generateSearchId:(t,r)=>`${t}#${r}`,getKeyfromSearchId:t=>{let[r,e]=t.split("#");return {key:r,variantId:e}}},Dt=Y;var N=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 g={logException:(t,r)=>{console.error(`Exception Occurred in Function: ${t}, Error: ${g.inspect(r)}`);},logError:(t,r)=>{console.error(`Error Occurred in Function: ${t}, Error: ${g.inspect(r)}`);},logWarning:(t,r)=>{console.warn(`Warning in Function: ${t} - ${g.inspect(r)}`);},logMessage:(t,r)=>{console.log(`Message in Function: ${t} - ${g.inspect(r)}`);},logInvalidPayload:(t,r)=>{console.error(`Invalid Payload received for Function: ${t}, Error: ${g.inspect(r)}`);},inspect:t=>typeof t=="string"?t:C.inspect(t)},c=g;var W={handleException:(t,r,e)=>{r.knownError?(r.logError&&c.logError(t,r),e.status(r.status).json({status:r.status,error:r.error})):r.status&&r.error?(c.logException(t,r),e.status(r.status).json({error:r.errorMessage||JSON.stringify(r.error),status:r.status})):(c.logException(t,r),e.status(500).json({status:500,error:N.INTERNAL_SERVER_ERROR}));},generateResponse:(t,r,e)=>({status:t,data:r,error:e}),generateError:(t,r,e=!0,s=!1)=>({status:t,error:r,knownError:e,logError:s})},Mt=W;var B=async(t,r,e="GET",s={},u)=>{let f={method:e,headers:{"Content-Type":"application/json",...s}};e!=="GET"&&u&&(f.body=JSON.stringify(u));let p=`${t}${r?"/"+r:""}`;try{let o=await fetch(p,f);if(!o.ok){let l,d=await o.text();try{l=JSON.parse(d);}catch{l={status:o.status,error:d||o.statusText},c.logWarning("Fetch",`Failed to parse error response body as JSON for URL-${p}. Raw text: ${d}`);}throw {status:o.status,statusText:o.statusText,error:l}}let E=await o.json();return c.logMessage("Fetch",`API call successful: URL-${p}, Status- ${o.status}`),{status:o.status,statusText:o.statusText,data:E.data||{data:E}}}catch(o){throw c.logError("Fetch",`API call failed: URL-${p}, Status- ${o.status||500}, Error- ${c.inspect(o.error||o)}`),{status:o.status||500,statusText:o.statusText||N.INTERNAL_SERVER_ERROR,error:o.error||{status:o.status||500,error:o.statusText||N.SOMETHING_WENT_WRONG}}}},Bt=B;export{Dt as a,N as b,c,Mt as d,Bt as e};//# sourceMappingURL=chunk-6S4JI32B.mjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-6S4JI32B.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../node_modules/uuid/dist/esm-node/rng.js","../node_modules/uuid/dist/esm-node/regex.js","../node_modules/uuid/dist/esm-node/validate.js","../node_modules/uuid/dist/esm-node/stringify.js","../node_modules/uuid/dist/esm-node/parse.js","../node_modules/uuid/dist/esm-node/v35.js","../node_modules/uuid/dist/esm-node/native.js","../node_modules/uuid/dist/esm-node/v4.js","../node_modules/uuid/dist/esm-node/sha1.js","../node_modules/uuid/dist/esm-node/v5.js","../src/Utils/index.ts","../src/enums/ErrorTypes.ts","../src/Logger/index.ts","../src/Utils/response.ts","../src/Utils/fetch.ts"],"names":["rnds8Pool","poolPtr","rng","crypto","regex_default","validate","uuid","validate_default","byteToHex","i","unsafeStringify","arr","offset","parse","v","parse_default","stringToBytes","str","bytes","DNS","URL","v35","name","version","hashfunc","generateUUID","value","namespace","buf","_namespace","native_default","v4","options","rnds","v4_default","sha1","sha1_default","v5","v5_default","Utils","key","variantId","searchId","Utils_default","ErrorTypes_default","Logger","functionName","error","message","errorMessage","context","util","Logger_default","ResponseUtility","res","status","data","knownError","logError","response_default","Fetch","baseURL","endpoint","method","headers","payload","completeURL","response","errorBody","errorText","body","err","fetch_default"],"mappings":"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","file":"chunk-6S4JI32B.mjs","sourcesContent":["import crypto from 'crypto';\nconst rnds8Pool = new Uint8Array(256); // # of random values to pre-allocate\n\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n crypto.randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n\n return rnds8Pool.slice(poolPtr, poolPtr += 16);\n}","export default /^(?:[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;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n let v;\n const arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import { unsafeStringify } from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n const bytes = [];\n\n for (let i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport const DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport const URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function v35(name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n var _namespace;\n\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (((_namespace = namespace) === null || _namespace === void 0 ? void 0 : _namespace.length) !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n let bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","import crypto from 'crypto';\nexport default {\n randomUUID: crypto.randomUUID\n};","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n\n options = options || {};\n const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return unsafeStringify(rnds);\n}\n\nexport default v4;","import crypto from 'crypto';\n\nfunction sha1(bytes) {\n if (Array.isArray(bytes)) {\n bytes = Buffer.from(bytes);\n } else if (typeof bytes === 'string') {\n bytes = Buffer.from(bytes, 'utf8');\n }\n\n return crypto.createHash('sha1').update(bytes).digest();\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nconst v5 = v35('v5', 0x50, sha1);\nexport default v5;","import { v4 as uuidv4, v5 as uuidv5 } from 'uuid';\r\n\r\nconst Utils = {\r\n isUUID: (value: string): boolean => {\r\n const uuidRegex = /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\r\n return uuidRegex.test(value);\r\n },\r\n\r\n isEmail: (value: string): boolean => {\r\n const emailRegex = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$/;\r\n return emailRegex.test(value);\r\n },\r\n\r\n isURL: (value: string): boolean => {\r\n const urlRegex = /^(http|https):\\/\\/[^ \"]+$/;\r\n return urlRegex.test(value);\r\n },\r\n \r\n generateUUID: (value?: string, namespace?: string) => {\r\n if(namespace && value){\r\n return uuidv5(value, namespace);\r\n }\r\n return uuidv4();\r\n },\r\n\r\n generateSearchId: (key: string, variantId: string) => {\r\n return `${key}#${variantId}`;\r\n },\r\n\r\n getKeyfromSearchId: (searchId: string) => {\r\n const [key, variantId] = searchId.split('#');\r\n return {\r\n key,\r\n variantId\r\n }\r\n },\r\n}\r\n\r\nexport default Utils;\r\n","export default Object.freeze({\r\n INVALID_UUID: \"Invalid UUID\",\r\n INVALID_EMAIL: \"Invalid Email\",\r\n INVALID_TOKEN: \"Invalid Token\",\r\n TOKEN_EXPIRED: \"Token Expired\",\r\n INVALID_VERIFIER: \"Invalid Verifier\",\r\n INVALID_PERMISSIONS: \"Invalid Permissions\",\r\n INVALID_AUTH_TYPE: \"Invalid Authorization Type\",\r\n USER_PRIVATE_KEY_NOT_FOUND: \"User Private Key Not Found\",\r\n USER_PUBLIC_KEY_NOT_FOUND: \"User Public Key Not Found\",\r\n ANONYMOUS_PRIVATE_KEY_NOT_FOUND: \"Anonymous Private Key Not Found\",\r\n ANONYMOUS_PUBLIC_KEY_NOT_FOUND: \"Anonymous Public Key Not Found\",\r\n SYSTEM_PRIVATE_KEY_NOT_FOUND: \"System Private Key Not Found\",\r\n SYSTEM_PUBLIC_KEY_NOT_FOUND: \"System Public Key Not Found\",\r\n ADMIN_PRIVATE_KEY_NOT_FOUND: \"Admin Private Key Not Found\",\r\n ADMIN_PUBLIC_KEY_NOT_FOUND: \"Admin Public Key Not Found\",\r\n SECRET_TOKEN_NOT_FOUND: \"Secret Token Not Found\",\r\n ANONYMOUS_SESSION_NOT_ALLOWED: \"Anonymous Session Not Allowed\",\r\n USER_SESSION_NOT_ALLOWED: \"User Session Not Allowed\",\r\n SYSTEM_SESSION_NOT_ALLOWED: \"System Session Not Allowed\",\r\n CDN_SESSION_NOT_ALLOWED: \"CDN Session Not Allowed\",\r\n INTERNAL_SERVER_ERROR: \"Internal Server Error\",\r\n SOMETHING_WENT_WRONG: 'Something went wrong',\r\n AUTH_CONTEXT_NOT_INITIALIZED: 'Auth Context not Initialized'\r\n})","import util from 'util';\r\nconst Logger = {\r\n logException: (functionName: string, error: any) => {\r\n console.error(`Exception Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logError: (functionName: string, error: any) => {\r\n console.error(`Error Occurred in Function: ${functionName}, Error: ${Logger.inspect(error)}`);\r\n },\r\n\r\n logWarning: (functionName: string, message: any) => {\r\n console.warn(`Warning in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logMessage: (functionName: string, message: any) => {\r\n console.log(`Message in Function: ${functionName} - ${Logger.inspect(message)}`);\r\n },\r\n\r\n logInvalidPayload: (functionName: string, errorMessage: string) => {\r\n console.error(`Invalid Payload received for Function: ${functionName}, Error: ${Logger.inspect(errorMessage)}`);\r\n },\r\n\r\n inspect: (context: any) => {\r\n return (typeof context === \"string\" ? context : util.inspect(context));\r\n }\r\n}\r\n\r\nexport default Logger;","import ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport const ResponseUtility = {\r\n handleException: (functionName: string, error: any, res: any) => {\r\n if (error.knownError) {\r\n error.logError && Logger.logError(functionName, error);\r\n res.status(error.status).json({\r\n status: error.status,\r\n error: error.error\r\n });\r\n } else if(error.status && error.error) {\r\n Logger.logException(functionName, error);\r\n res.status(error.status).json({\r\n error: error.errorMessage || JSON.stringify(error.error),\r\n status: error.status,\r\n });\r\n } else {\r\n Logger.logException(functionName, error);\r\n res.status(500).json({\r\n status: 500,\r\n error: ErrorTypes.INTERNAL_SERVER_ERROR\r\n })\r\n }\r\n },\r\n\r\n generateResponse: (status: number, data?: any, error?: string) => {\r\n return {\r\n status,\r\n data,\r\n error\r\n }\r\n },\r\n\r\n generateError: (status: number, error: string, knownError: Boolean = true, logError: boolean = false) => {\r\n return {\r\n status,\r\n error,\r\n knownError,\r\n logError\r\n }\r\n }\r\n}\r\n\r\nexport default ResponseUtility;","\"use client\";\r\n\r\nimport ErrorTypes from \"../enums/ErrorTypes\";\r\nimport Logger from \"../Logger\";\r\n\r\nexport type ErrorType = {\r\n status: number;\r\n statusText: string;\r\n error: any;\r\n};\r\n\r\nexport type SuccessType = {\r\n status: number;\r\n statusText: string;\r\n data: any;\r\n};\r\n\r\n/**\r\n * Makes an HTTP request to the specified endpoint using the provided parameters.\r\n *\r\n * @param {string} baseURL - The base URL of the API.\r\n * @param {string} endpoint - The specific endpoint to call.\r\n * @param {'GET' | 'POST' | 'PATCH' | 'DELETE'} [method='GET'] - The HTTP method to use for the request.\r\n * @param {Record<string, string>} [headers={}] - Additional headers to include in the request.\r\n * @param {any} [payload] - The payload to send with the request, if applicable.\r\n * @returns {Promise<SuccessType>} - A promise that resolves to the response data if the request is successful.\r\n * @throws {ErrorType} - Throws an error if the request fails.\r\n */\r\nconst Fetch = async (\r\n baseURL: string,\r\n endpoint: string,\r\n method: 'GET' | 'POST' | 'PATCH' | 'DELETE' = 'GET',\r\n headers: Record<string, string> = {},\r\n payload?: any,\r\n): Promise<SuccessType> => {\r\n const options: RequestInit = {\r\n method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n ...headers,\r\n },\r\n };\r\n\r\n if (method !== 'GET' && payload) {\r\n options.body = JSON.stringify(payload);\r\n }\r\n\r\n const completeURL = `${baseURL}${endpoint ? ('/' + endpoint) : ''}`\r\n try {\r\n const response: any = await fetch(completeURL, options);\r\n\r\n if (!response.ok) {\r\n let errorBody: any;\r\n const errorText = await response.text();\r\n\r\n try {\r\n errorBody = JSON.parse(errorText);\r\n } catch (parseError) {\r\n errorBody = {\r\n status: response.status,\r\n error: errorText || response.statusText\r\n };\r\n Logger.logWarning('Fetch', `Failed to parse error response body as JSON for URL-${completeURL}. Raw text: ${errorText}`);\r\n }\r\n\r\n throw {\r\n status: response.status,\r\n statusText: response.statusText,\r\n error: errorBody\r\n } as ErrorType;\r\n }\r\n\r\n const body = await response.json();\r\n\r\n Logger.logMessage('Fetch', `API call successful: URL-${completeURL}, Status- ${response.status}`);\r\n return {\r\n status: response.status,\r\n statusText: response.statusText,\r\n data: body.data || { data: body },\r\n } as SuccessType;\r\n } catch (err: any) {\r\n \r\n Logger.logError('Fetch', `API call failed: URL-${completeURL}, Status- ${err.status || 500}, Error- ${Logger.inspect(err.error || err)}`);\r\n throw {\r\n status: err.status || 500,\r\n statusText: err.statusText || ErrorTypes.INTERNAL_SERVER_ERROR,\r\n error: err.error || {\r\n status: err.status || 500,\r\n error: err.statusText || ErrorTypes.SOMETHING_WENT_WRONG,\r\n }\r\n } as ErrorType;\r\n }\r\n};\r\n\r\nexport default Fetch;\r\n"]}
|