gemi 0.4.94 → 0.4.95

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (90) hide show
  1. package/dist/app/index.js +2 -0
  2. package/dist/app/index.js.map +13 -0
  3. package/dist/bin/index.js +3 -0
  4. package/dist/broadcasting/index.js +2 -0
  5. package/dist/broadcasting/index.js.map +10 -0
  6. package/dist/chunk-07f44e411ae4ea5e.js +4 -0
  7. package/dist/chunk-07f44e411ae4ea5e.js.map +11 -0
  8. package/dist/chunk-0d97333b6af9fc45.js +2 -0
  9. package/dist/chunk-0d97333b6af9fc45.js.map +9 -0
  10. package/dist/chunk-11de5b0adccef35c.js +4 -0
  11. package/dist/chunk-11de5b0adccef35c.js.map +17 -0
  12. package/dist/chunk-18a59fffad60f059.js +4 -0
  13. package/dist/chunk-18a59fffad60f059.js.map +12 -0
  14. package/dist/chunk-201c5005a90452fa.js +11 -0
  15. package/dist/chunk-201c5005a90452fa.js.map +11 -0
  16. package/dist/chunk-23d3df5f8342ecc6.js +2 -0
  17. package/dist/chunk-23d3df5f8342ecc6.js.map +54 -0
  18. package/dist/chunk-278677330e53423b.js +4 -0
  19. package/dist/chunk-278677330e53423b.js.map +26 -0
  20. package/dist/chunk-28ec4c2b20e69deb.js +2 -0
  21. package/dist/chunk-28ec4c2b20e69deb.js.map +10 -0
  22. package/dist/chunk-2f8cf8372320b622.js +2 -0
  23. package/dist/chunk-2f8cf8372320b622.js.map +11 -0
  24. package/dist/chunk-53b0fab00d83f47e.js +2 -0
  25. package/dist/chunk-53b0fab00d83f47e.js.map +13 -0
  26. package/dist/chunk-57ba59dd008d6e0e.js +4 -0
  27. package/dist/chunk-57ba59dd008d6e0e.js.map +32 -0
  28. package/dist/chunk-642b04056dab5d64.js +2 -0
  29. package/dist/chunk-642b04056dab5d64.js.map +11 -0
  30. package/dist/chunk-643529c2ad120db7.js +2 -0
  31. package/dist/chunk-643529c2ad120db7.js.map +50 -0
  32. package/dist/chunk-683905a55f8da1ad.js +5 -0
  33. package/dist/chunk-683905a55f8da1ad.js.map +64 -0
  34. package/dist/chunk-90436b32a64fc784.js +2 -0
  35. package/dist/chunk-90436b32a64fc784.js.map +53 -0
  36. package/dist/chunk-99c32e4d937131e0.js +2 -0
  37. package/dist/chunk-99c32e4d937131e0.js.map +10 -0
  38. package/dist/chunk-9be25fac5f76b2f7.js +8 -0
  39. package/dist/chunk-9be25fac5f76b2f7.js.map +13 -0
  40. package/dist/{chunk-eee44b06ba2a6e36.js → chunk-9f9e21f9fd0d6af1.js} +3 -1
  41. package/dist/chunk-9f9e21f9fd0d6af1.js.map +10 -0
  42. package/dist/chunk-9ff3d7096b6de8eb.js +4 -0
  43. package/dist/chunk-9ff3d7096b6de8eb.js.map +22 -0
  44. package/dist/chunk-a7d87b5d6d789781.js +4 -0
  45. package/dist/chunk-a7d87b5d6d789781.js.map +23 -0
  46. package/dist/chunk-b84d011a2972c7d1.js +2 -0
  47. package/dist/chunk-b84d011a2972c7d1.js.map +10 -0
  48. package/dist/{chunk-96e59b185e2d1612.js → chunk-bace428bfab523c4.js} +3 -1
  49. package/dist/chunk-bace428bfab523c4.js.map +23 -0
  50. package/dist/chunk-bd708d3c982948aa.js +4 -0
  51. package/dist/chunk-bd708d3c982948aa.js.map +16 -0
  52. package/dist/chunk-c8c4a1285a266c51.js +20 -0
  53. package/dist/chunk-c8c4a1285a266c51.js.map +169 -0
  54. package/dist/chunk-cd4bfdd46ec4cbb8.js +4 -0
  55. package/dist/chunk-cd4bfdd46ec4cbb8.js.map +10 -0
  56. package/dist/chunk-cd9c5e8a6c80384f.js +4 -0
  57. package/dist/chunk-cd9c5e8a6c80384f.js.map +20 -0
  58. package/dist/chunk-d5b8023c223e3a60.js +4 -0
  59. package/dist/chunk-d5b8023c223e3a60.js.map +10 -0
  60. package/dist/chunk-e4961d79807acd3d.js +2 -0
  61. package/dist/chunk-e4961d79807acd3d.js.map +33 -0
  62. package/dist/email/index.js +2 -0
  63. package/dist/email/index.js.map +11 -0
  64. package/dist/facades/index.js +2 -0
  65. package/dist/facades/index.js.map +28 -0
  66. package/dist/http/index.js +2 -0
  67. package/dist/http/index.js.map +29 -0
  68. package/dist/kernel/Kernel.d.ts.map +1 -1
  69. package/dist/kernel/index.js +3 -1
  70. package/dist/kernel/index.js.map +11 -0
  71. package/dist/server/index.js +2 -0
  72. package/dist/server/index.js.map +17 -0
  73. package/dist/services/index.js +6 -4
  74. package/dist/services/index.js.map +121 -0
  75. package/package.json +2 -2
  76. package/dist/chunk-2b9b6009ebe271d3.js +0 -2
  77. package/dist/chunk-3a6838d9e6866471.js +0 -2
  78. package/dist/chunk-3affaf143f242e08.js +0 -2
  79. package/dist/chunk-57352645a8e7e7cb.js +0 -2
  80. package/dist/chunk-6ac923265710cdd6.js +0 -18
  81. package/dist/chunk-809308720fc22418.js +0 -2
  82. package/dist/chunk-869ca3630adc189b.js +0 -2
  83. package/dist/chunk-931a005d4bb28ffe.js +0 -2
  84. package/dist/chunk-aa5366c3d468f9d7.js +0 -6
  85. package/dist/chunk-b94896500a1345bf.js +0 -2
  86. package/dist/chunk-bdac4694bbb37064.js +0 -1
  87. package/dist/chunk-c3c17a7115770391.js +0 -2
  88. package/dist/chunk-cadbc5f981d3a029.js +0 -2
  89. package/dist/chunk-cf9df3002593e357.js +0 -9
  90. package/dist/chunk-efd43c1cf8f87db4.js +0 -3
@@ -1,2 +1,4 @@
1
1
  // @bun
2
2
  import{H as m} from"../chunk-642b04056dab5d64.js";import{I as x} from"../chunk-99c32e4d937131e0.js";import"../chunk-0d97333b6af9fc45.js";class R{requests={};static kind="controller";constructor(){}}class O extends R{constructor(){super(...arguments)}}function I(e){return typeof e==="function"&&e.prototype!==void 0}var _=function(e){return I(e)};class u{e;t;n;middlewares=[];constructor(e,t,n){this.method=e;this.handler=t;this.methodName=n;this.handler=t,this.methodName=n,this.method=e}run(e){if(_(this.handler)){const t=new this.handler;return t[this.methodName].bind(t)()}else return this.handler()}middleware(e){return this.middlewares=e,this}}class M{constructor(...e){return new u(...e)}}class f{routes={};middlewares=[];middleware(e){}get(e,t){return new u("GET",e,t)}post(e,t){return new u("POST",e,t)}put(e,t){return new u("PUT",e,t)}patch(e,t){return new u("PATCH",e,t)}delete(e,t){return new u("DELETE",e,t)}resource(e){class t extends f{constructor(){super(...arguments)}routes={"/":{list:this.get(e,"list"),create:this.post(e,"create")},"/:id":{show:this.get(e,"show"),update:this.put(e,"update"),delete:this.delete(e,"delete")}}}return t}file(e,t){return new M("GET",e,t)}}class b{e;middlewares=[];handler;constructor(e,t){this.viewPath=e;if(!t)this.handler=()=>({});else if(typeof t==="function")this.handler=t;else{const[n,r]=t,o=new n,s=o[r].bind(o);this.handler=(i)=>{return s()}}}async run(e){return{[this.viewPath]:await this.handler(e)}}middleware(e){return this.middlewares=e,this}}class A{e;children;middlewares=[];handler=()=>({});constructor(e,t,n){this.viewPath=e;if(typeof t==="function")this.handler=t,this.children=class extends y{routes=n??{}};else if(Array.isArray(t)){const[r,o]=t,s=new r,i=s[o].bind(s);this.handler=(a)=>{let l=a;return l=s.requests[o]?new s.requests[o](a.rawRequest,a.params):l,i(a)},this.children=class extends y{routes=n??{}}}else this.children=class extends y{routes=t},this.handler=()=>({})}async run(e){return{[this.viewPath]:await this.handler(e)}}middleware(e){return this.middlewares=e,this}}class y{middlewares=[];routes={};view(e,t){return new b(e,t)}layout(e,t,n){return new A(e,t,n)}}var re="GEMI_REQUEST_BREAKER_ERROR";class d extends Error{constructor(){super(...arguments)}kind="GEMI_REQUEST_BREAKER_ERROR";payload={api:{},view:{}}}class P extends d{errors={};constructor(e){super("Validation error");this.name="ValidationError",this.errors=e,this.payload={api:{status:400,data:{error:{kind:"validation_error",messages:e}},headers:{"Content-Type":"application/json"}},view:{status:400}}}}import{AsyncLocalStorage as N} from"async_hooks";class w{e;t;n;constructor(e,t,n={}){this.name=e;this.value=t;this.options=n}toString(){return[`${this.name}=${this.value}`,this.options.maxAge?`Max-Age=${this.options.maxAge}`:"",this.options.httpOnly?"HttpOnly":"",this.options.secure?"Secure":"",this.options.sameSite?`SameSite=${this.options.sameSite}`:"SameSite=Strict",this.options.path?`Path=${this.options.path}`:"Path=/",this.options.domain?`Domain=${this.options.domain}`:"",this.options.expires?`Expires=${this.options.expires.toUTCString()}`:"",this.options.partitioned?"Partitioned":""].filter((e)=>e!=="").join("; ")}}var C=new N;class E{e;cookies=new Set;headers=new Headers;prefetchedResources=new Map;prefetchPromiseQueue=new Set;user=null;constructor(e){this.req=e}setCookie(e,t,n={}){this.cookies.add(new w(e,t,n))}setHeaders(e,t){this.headers.set(e,t)}setUser(e){this.user=e}setRequest(e){this.req=e}destroy(){delete this.cookies,delete this.headers,delete this.prefetchedResources,delete this.prefetchPromiseQueue,delete this.user}}class p{static getStore(){return C.getStore()}static setRequest(e){C.getStore().req=e}static run(e,t){return C.run(new E(e),t)}}var j=function(e){const[t,n]=e.match(/\d+|\D+/g)??[];if(!t||!n)return 0;const r=parseInt(t);switch(n){case"B":return r;case"KB":return r*1024;case"MB":return r*1024*1024;case"GB":return r*1024*1024*1024;case"TB":return r*1024*1024*1024*1024;default:return 0}},B=function(e){switch(e){case"image":return"image";case"png":return"image/png";case"jpg":return"image/jpeg";case"jpeg":return"image/jpeg";case"ttf":return"font/ttf";case"excel":return"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";case"csv":return"text/csv";case"word":return"application/vnd.openxmlformats-officedocument.wordprocessingml.document";case"pdf":return"application/pdf";case"json":return"application/json";default:return e}},Q=function(e){const[t,n]=e.split(":");switch(t){case"required":return(r)=>{if(r instanceof Blob)return r.size>0;return r!==null&&r!==void 0&&r?.length>0};case"password":return(r)=>{return/^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[^a-zA-Z0-9]).{8,}$/.test(r)};case"number":return(r)=>{if(typeof r!=="number")return!1;return!isNaN(r)};case"min":return(r)=>{return r?.length>=parseInt(n)};case"max":return(r)=>{return r?.length<=parseInt(n)};case"email":return(r)=>{return/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(r)};case"file":return(r)=>{return r instanceof Blob};case"fileType":return(r)=>{if(r instanceof Blob){const o=B(n);return r.type.startsWith(o)}};case"fileSize":return(r)=>{if(r instanceof Blob){const o=j(n);return r.size<=o}};default:return()=>!0}};class H{e;constructor(e){this.data=e}get(e){return this.data[e]}set(e,t){this.data[e]=t}has(e){return this.data[e]!==void 0}toJSON(){return this.data}}class q{rawRequest;headers;cookies;search;schema={};params;ctx=p.getStore();constructor(e,t){if(!e){const o=p.getStore().req;this.params=o.params,this.rawRequest=o.rawRequest}else this.params=t,this.rawRequest=e;this.headers=this.rawRequest.headers;const n=this.rawRequest.headers.get("Cookie"),r=new Map;if(n){const o=n.split(";");for(let s of o){const[i,a]=s.split("=");r.set(i.trim(),a.trim())}}if(this.rawRequest.method==="GET"){const o=new URL(this.rawRequest.url),s=new Map;for(let[a,l]of o.searchParams)if(s.has(a)){const T=s.get(a);if(Array.isArray(T))T.push(l),s.set(a,T);else s.set(a,[T,l])}else s.set(a,l);const i=Object.fromEntries(s.entries());this.search=new H(i)}this.cookies=r}refine(e){return{}}async parseBody(){const e=new H({});if(this.rawRequest.headers.get("Content-Type")==="application/json"){const t=await this.rawRequest.json();for(let[n,r]of Object.entries(t))e.set(n,r)}if(this.rawRequest.headers.get("Content-Type")==="application/x-www-form-urlencoded"){const t=await this.rawRequest.formData();for(let[n,r]of t)e.set(n,r)}if(this.rawRequest.headers.get("Content-Type")?.startsWith("multipart/form-data")){const t=await this.rawRequest.formData();for(let[n,r]of t)if(e.has(n)){const o=e.get(n);if(Array.isArray(o))o.push(r),e.set(n,o);else e.set(n,[o,r])}else e.set(n,r)}return e}validateInput(e){const t={};for(let[n,r]of Object.entries(this.schema))for(let[o,s]of Object.entries(r)){const i=Q(o);let a=s,l=!1;if(typeof s==="function")a=s(e.get(n)),l=typeof a==="undefined";else l=i(e.get(n));if(l)continue;if(!t[n])t[n]=[];if(o==="required"){t[n]=[String(a)];break}else t[n].push(String(a))}for(let[n,r]of Object.entries(this.refine(e.toJSON())??{})){if(!t[n])t[n]=[];t[n]=[...t[n]??[],r]}if(Object.keys(t).length>0)throw new P(t);else return e}async input(){return this.validateInput(await this.parseBody())}async safeInput(){const e=await this.parseBody();try{return this.validateInput(e),{isValid:!0,errors:{},input:e}}catch(t){if(!(t instanceof P))throw t;return{isValid:!1,errors:t.errors,input:e}}}async terminate(e){throw"not implemented"}}class c{e;constructor(e){this.routePath=e}async run(e,...t){return{}}}function F(e){const t=e.headers.get("cookie");if(!t)return new Map;const n=new Map,r=t.split(";");for(let o of r){const[s,i]=o.split("=");n.set(s.trim(),i)}return n}class S extends x{constructor(){super(...arguments)}aliases={};boot(){}}class $ extends d{error;constructor(e="Not authorized"){super("Authentication error");this.name="AuthenticationError",this.error=e,this.payload={api:{status:401,data:{error:this.error}},view:{}}}}class V extends d{error;constructor(e="Insufficient permissions"){super("Authentication error");this.name="AuthenticationError",this.error=e,this.payload={api:{status:401,data:{error:this.error}},view:{}}}}class h extends d{constructor(){super("Authentication error");this.name="AuthenticationError"}payload={api:{status:401,data:{error:"Authentication error"}},view:{status:302,headers:{"Cache-Control":"private, no-cache, no-store, max-age=0, must-revalidate",Location:"/auth/sign-in"}}}}class K extends m{e;name="AuthenticationServiceContainer";constructor(e){super();this.provider=e}async getSession(e,t){const n=await this.provider.adapter.findSession({token:e,userAgent:t});let r=null;if(n?.user)r=await this.provider.extendSession(n.user),n.user.extension=r;return n}}class v extends c{constructor(){super(...arguments)}async run(e){const t=p.getStore(),n=t.req.cookies.get("access_token");if(!n)throw new h;let r=t.user;if(!r){const o=await K.use().getSession(n,t.req.headers.get("User-Agent"));if(!o)throw new h;r=o?.user,t.setUser(r)}return{}}}class g extends m{e;name="RateLimiterServiceContainer";constructor(e){super();this.service=e}}class L extends d{constructor(){super("Rate limit exceeded");this.payload={api:{status:429,data:{error:{message:"Rate limit exceeded"}},headers:{"Content-Type":"application/json"}},view:{error:{message:"Rate limit exceeded"},status:429}}}}class U extends c{constructor(){super(...arguments)}async run(e,t=1000){const n=e.headers.get("x-forwarded-for"),r=g.use().service.driver;if(r.consume.call(r,n,this.routePath)>t)throw new L;return{}}}class k{policiesList={};constructor(){const e=this.register();for(let t of e){const n=new t;this.policiesList[t.name]=n}}register(){return[]}}class D{all(e,t){return!0}}class G extends x{constructor(){super(...arguments)}dictionary={};supportedLocales=[];defaultLocale="en-US";async init(){}detectLocale(e){return this.defaultLocale}boot(){}}export{F as getCookies,y as ViewRouter,P as ValidationError,O as ResourceController,d as RequestBreakerError,U as RateLimitMiddleware,k as PoliciesServiceProvider,D as Policies,S as MiddlewareServiceProvider,c as Middleware,V as InsufficientPermissionsError,G as I18nServiceProvider,q as HttpRequest,R as Controller,$ as AuthorizationError,v as AuthenticationMiddleware,h as AuthenticationError,f as ApiRouter};export{R as a,I as b,f as c,y as d,re as e,d as f,P as g,p as h,q as i,S as j,$ as k,V as l,K as m,g as n,G as o};
3
+
4
+ //# debugId=8AD557EF9D03F5BF64756e2164756e21
@@ -0,0 +1,29 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../http/Controller.ts", "../internal/isConstructor.ts", "../http/ApiRouter.ts", "../http/ViewRouter.ts", "../http/Error.ts", "../http/Router.ts", "../http/requestContext.ts", "../http/Cookie.ts", "../http/HttpRequest.ts", "../http/Middleware.ts", "../http/getCookies.ts", "../http/MiddlewareServiceProvider.ts", "../http/errors.ts", "../auth/AuthenticationServiceContainer.ts", "../http/AuthenticationMiddlware.ts", "../services/rate-limiter/RateLimiterServiceContainer.ts", "../http/RateLimitMiddleware.ts", "../http/PoliciesServiceProvider.ts", "../http/Policy.ts", "../http/I18nServiceProvider.ts"],
4
+ "sourcesContent": [
5
+ "import type { HttpRequest } from \"./HttpRequest\";\n\nexport class Controller {\n requests: Record<string, typeof HttpRequest<any, any>> = {};\n\n static kind = \"controller\" as const;\n\n constructor() {}\n}\n\ntype PromiseOrData<T> = T | Promise<T>;\n\nexport abstract class ResourceController extends Controller {\n abstract create(req: HttpRequest<any, any>): PromiseOrData<any>;\n abstract update(req: HttpRequest<any, any>): PromiseOrData<any>;\n abstract delete(req: HttpRequest<any, any>): PromiseOrData<any>;\n abstract list(req: HttpRequest<any, any>): PromiseOrData<any>;\n abstract show(req: HttpRequest<any, any>): PromiseOrData<any>;\n}\n\nexport type ControllerMethods<\n T extends new () => Controller | ResourceController,\n> = {\n [K in keyof InstanceType<T>]: InstanceType<T>[K] extends Function ? K : never;\n}[keyof InstanceType<T>];\n",
6
+ "export function isConstructor(value: any) {\n return typeof value === \"function\" && value.prototype !== undefined;\n}\n",
7
+ "import { isConstructor } from \"../internal/isConstructor\";\nimport type { KeyAndValue, KeyAndValueToObject } from \"../internal/type-utils\";\nimport {\n Controller,\n ResourceController,\n type ControllerMethods,\n} from \"./Controller\";\nimport { HttpRequest } from \"./HttpRequest\";\nimport type { MiddlewareReturnType } from \"./Router\";\n\ntype HttpMethod = \"GET\" | \"POST\" | \"PUT\" | \"PATCH\" | \"DELETE\";\n\nexport type ApiRouterHandler<Input, Output, Params> = (\n req: HttpRequest<Input, Params>,\n) => Output;\n\ntype CallbackHandler<Input, Output, Params> = (\n req: HttpRequest<Input, Params>,\n) => Promise<Output> | Output;\n\ntype ParseRouteHandler<\n T extends new () => Controller,\n K extends ControllerMethods<T>,\n M extends HttpMethod,\n> = InstanceType<T>[K] extends (\n req: HttpRequest<infer Input, infer Params>,\n) => infer Output\n ? RouteHandler<M, Input, Output, Params>\n : never;\n\nfunction isController(\n candidate: CallbackHandler<any, any, any> | (new () => Controller),\n): candidate is new () => Controller {\n return isConstructor(candidate);\n}\n\nexport class RouteHandler<M extends HttpMethod, Input, Output, Params> {\n middlewares: string[] = [];\n\n constructor(\n public method: M,\n private handler:\n | CallbackHandler<Input, Output, Params>\n | (new () => Controller),\n private methodName?: any,\n ) {\n this.handler = handler;\n this.methodName = methodName;\n this.method = method;\n }\n\n run(_req: HttpRequest<Input, Params>) {\n if (isController(this.handler)) {\n const controller = new this.handler();\n const handler = controller[this.methodName].bind(controller);\n return handler();\n } else {\n // @ts-ignore\n return this.handler();\n }\n }\n\n middleware(middlewareList: string[]) {\n this.middlewares = middlewareList;\n return this;\n }\n}\n\nexport class FileHandler {\n constructor(...args: ConstructorParameters<typeof RouteHandler>) {\n return new RouteHandler(...args) as any;\n }\n}\n\nexport type RouteHandlers =\n | {\n create: RouteHandler<\"POST\", any, any, any>;\n list: RouteHandler<\"GET\", any, any, any>;\n }\n | {\n update: RouteHandler<\"PUT\", any, any, any>;\n show: RouteHandler<\"GET\", any, any, any>;\n delete: RouteHandler<\"DELETE\", any, any, any>;\n };\n\nexport type ApiRoutes = Record<\n string,\n | RouteHandler<any, any, any, any>\n | FileHandler\n | RouteHandlers\n | typeof ApiRouter\n>;\n\nexport class ApiRouter {\n public routes: ApiRoutes = {};\n public middlewares: string[] = [];\n public middleware(_req: HttpRequest<any, any>): MiddlewareReturnType {}\n\n public get<Input, Output, Params>(\n handler: CallbackHandler<Input, Output, Params>,\n ): RouteHandler<\"GET\", Input, Output, Params>;\n public get<T extends new () => Controller, K extends ControllerMethods<T>>(\n handler: T,\n methodName: K,\n ): ParseRouteHandler<T, K, \"GET\">;\n public get<\n T extends CallbackHandler<any, any, any> | (new () => Controller),\n K extends ControllerMethods<any>,\n >(handler: T, methodName?: K) {\n return new RouteHandler(\"GET\", handler, methodName);\n }\n\n public post<Input, Output, Params>(\n handler: CallbackHandler<Input, Output, Params>,\n ): RouteHandler<\"POST\", Input, Output, Params>;\n public post<T extends new () => Controller, K extends ControllerMethods<T>>(\n handler: T,\n methodName: K,\n ): ParseRouteHandler<T, K, \"POST\">;\n public post<\n T extends CallbackHandler<any, any, any> | (new () => Controller),\n K extends ControllerMethods<any>,\n >(handler: T, methodName?: K) {\n return new RouteHandler(\"POST\", handler, methodName);\n }\n\n public put<Input, Output, Params>(\n handler: CallbackHandler<Input, Output, Params>,\n ): RouteHandler<\"PUT\", Input, Output, Params>;\n public put<T extends new () => Controller, K extends ControllerMethods<T>>(\n handler: T,\n methodName: K,\n ): ParseRouteHandler<T, K, \"PUT\">;\n public put<\n T extends CallbackHandler<any, any, any> | (new () => Controller),\n K extends ControllerMethods<any>,\n >(handler: T, methodName?: K) {\n return new RouteHandler(\"PUT\", handler, methodName);\n }\n\n public patch<Input, Output, Params>(\n handler: CallbackHandler<Input, Output, Params>,\n ): RouteHandler<\"PATCH\", Input, Output, Params>;\n public patch<T extends new () => Controller, K extends ControllerMethods<T>>(\n handler: T,\n methodName: K,\n ): ParseRouteHandler<T, K, \"PATCH\">;\n public patch<\n T extends CallbackHandler<any, any, any> | (new () => Controller),\n K extends ControllerMethods<any>,\n >(handler: T, methodName?: K) {\n return new RouteHandler(\"PATCH\", handler, methodName);\n }\n\n public delete<Input, Output, Params>(\n handler: CallbackHandler<Input, Output, Params>,\n ): RouteHandler<\"DELETE\", Input, Output, Params>;\n public delete<T extends new () => Controller, K extends ControllerMethods<T>>(\n handler: T,\n methodName: K,\n ): ParseRouteHandler<T, K, \"DELETE\">;\n public delete<\n T extends CallbackHandler<any, any, any> | (new () => Controller),\n K extends ControllerMethods<any>,\n >(handler: T, methodName?: K) {\n return new RouteHandler(\"DELETE\", handler, methodName);\n }\n\n public resource<T extends new () => ResourceController>(Controller: T) {\n class ResourceRouter extends ApiRouter {\n routes = {\n \"/\": {\n list: this.get(\n Controller,\n \"list\" as ControllerMethods<T>,\n ) as ParseRouteHandler<T, TestControllerMethod<T, \"list\">, \"GET\">,\n create: this.post(\n Controller,\n \"create\" as ControllerMethods<T>,\n ) as ParseRouteHandler<T, TestControllerMethod<T, \"create\">, \"POST\">,\n },\n \"/:id\": {\n show: this.get(\n Controller,\n \"show\" as ControllerMethods<T>,\n ) as ParseRouteHandler<T, TestControllerMethod<T, \"show\">, \"GET\">,\n update: this.put(\n Controller,\n \"update\" as ControllerMethods<T>,\n ) as ParseRouteHandler<T, TestControllerMethod<T, \"update\">, \"PUT\">,\n delete: this.delete(\n Controller,\n \"delete\" as ControllerMethods<T>,\n ) as ParseRouteHandler<\n T,\n TestControllerMethod<T, \"delete\">,\n \"DELETE\"\n >,\n },\n };\n }\n return ResourceRouter;\n }\n\n public file<Input, Output, Params>(\n handler: CallbackHandler<Input, Output, Params>,\n ): FileHandler;\n public file<T extends new () => Controller, K extends ControllerMethods<T>>(\n handler: T,\n methodName: K,\n ): FileHandler;\n public file<\n T extends CallbackHandler<any, any, any> | (new () => Controller),\n K extends ControllerMethods<any>,\n >(handler: T, methodName?: K) {\n return new FileHandler(\"GET\", handler, methodName);\n }\n}\n\ntype TestControllerMethod<T extends new () => Controller, K extends string> =\n K extends ControllerMethods<T> ? K : never;\n\ntype RouteHandlerParser<T, Prefix extends string = \"\"> =\n T extends RouteHandler<infer Method, infer Input, infer Output, infer Params>\n ? KeyAndValue<\n `${Method & string}:${Prefix & string}`,\n ApiRouterHandler<Input, Output, Params>\n >\n : never;\n\ntype RouteHandlersParser<\n T,\n Prefix extends string = \"\",\n> = T extends RouteHandlers\n ? {\n [K in keyof T]: T[K] extends RouteHandler<\n infer Method,\n infer Input,\n infer Output,\n infer Params\n >\n ? KeyAndValue<\n `${Method & string}:${Prefix & string}`,\n ApiRouterHandler<Input, Output, Params>\n >\n : never;\n }[keyof T]\n : never;\n\ntype RouterInstanceParser<\n T extends new () => ApiRouter,\n Prefix extends string,\n> = T extends new () => ApiRouter\n ? RouteParser<InstanceType<T>[\"routes\"], `${Prefix & string}`>\n : never;\n\ntype ParsePrefixAndKey<\n P extends PropertyKey,\n K extends PropertyKey,\n U = `${P & string}${K & string}`,\n> = U extends \"//\"\n ? \"/\"\n : U extends `${infer T1}//${infer T2}`\n ? `${T1}/${T2}`\n : U extends `${infer T1}/${infer T2}/`\n ? `${T1}/${T2}`\n : U;\n\ntype RouteParser<\n T extends ApiRoutes,\n Prefix extends PropertyKey = \"\",\n K extends keyof T = keyof T,\n> = K extends any\n ? T[K] extends RouteHandler<any, any, any, any>\n ? RouteHandlerParser<T[K], ParsePrefixAndKey<Prefix, K>>\n : T[K] extends new () => ApiRouter\n ? RouterInstanceParser<T[K], ParsePrefixAndKey<Prefix, K>>\n : T[K] extends RouteHandlers\n ? RouteHandlersParser<\n T[K],\n `${Prefix & string}${K extends \"/\" ? \"\" : K & string}`\n >\n : never\n : never;\n\nexport type CreateRPC<\n T extends ApiRouter,\n Prefix extends PropertyKey = \"\",\n> = KeyAndValueToObject<RouteParser<T[\"routes\"], Prefix>>;\n",
8
+ "import type { KeyAndValue, KeyAndValueToObject } from \"../internal/type-utils\";\nimport { Controller } from \"./Controller\";\nimport { HttpRequest } from \"./HttpRequest\";\n\ntype ControllerMethods<T extends new () => Controller> = {\n [K in keyof InstanceType<T>]: InstanceType<T>[K] extends Function ? K : never;\n}[keyof InstanceType<T>];\n\nexport type ViewRoutes = Record<\n string,\n | ViewRoute<any, any, any>\n | LayoutRoute<any, any, any, any>\n | (new () => ViewRouter)\n>;\n\ntype CallbackHandler<Input, Output, Params> = (\n req: HttpRequest<Input, Params>,\n) => Promise<Output> | Output;\n\nexport type ViewHandler<Input, Output, Params> =\n | CallbackHandler<Input, Output, Params>\n | (new () => Controller);\n\ntype ParseViewControllerHandler<\n C extends new () => Controller,\n M extends ControllerMethods<C>,\n> = InstanceType<C>[M] extends (\n req: HttpRequest<infer Input, infer Params>,\n) => infer Output\n ? ViewRoute<Input, Output, Params>\n : never;\n\ntype ParseLayoutControllerHandler<\n T extends ViewRoutes,\n C extends new () => Controller,\n M extends ControllerMethods<C>,\n> = InstanceType<C>[M] extends (\n req: HttpRequest<infer Input, infer Params>,\n) => infer Output\n ? LayoutRoute<T, Input, Output, Params>\n : never;\n\nexport class ViewRoute<Input, Output, Params> {\n middlewares: string[] = [];\n private handler: (req: HttpRequest<Input, Params>) => Output;\n constructor(\n public viewPath: string,\n handler?:\n | CallbackHandler<Input, Output, Params>\n | [new () => Controller, ControllerMethods<any>],\n ) {\n if (!handler) {\n this.handler = (() => ({})) as any;\n } else if (typeof handler === \"function\") {\n this.handler = handler as any;\n } else {\n const [controller, methodName] = handler;\n const controllerInstance = new controller();\n const controllerHandler =\n controllerInstance[methodName].bind(controllerInstance);\n this.handler = (_req: HttpRequest<Input, Params>): Output => {\n return controllerHandler();\n };\n }\n }\n\n async run(req: HttpRequest<Input, Params>) {\n return {\n [this.viewPath]: await this.handler(req),\n };\n }\n\n middleware(middlewares: string[]) {\n this.middlewares = middlewares;\n return this;\n }\n}\n\nexport class LayoutRoute<T extends ViewRoutes, Input, Output, Params> {\n children: new () => ViewRouter;\n middlewares: string[] = [];\n private handler: (req: HttpRequest<Input, Params>) => Output =\n (() => ({})) as any;\n constructor(\n public viewPath: string,\n handlerOrRoutes:\n | CallbackHandler<Input, Output, Params>\n | [new () => Controller, ControllerMethods<any>]\n | T,\n routes?: T,\n ) {\n if (typeof handlerOrRoutes === \"function\") {\n this.handler = handlerOrRoutes as any;\n this.children = class extends ViewRouter {\n routes = routes ?? ({} as T);\n };\n } else if (Array.isArray(handlerOrRoutes)) {\n const [controller, methodName] = handlerOrRoutes;\n const controllerInstance = new controller();\n const controllerHandler =\n controllerInstance[methodName].bind(controllerInstance);\n this.handler = (req: HttpRequest<Input, Params>): Output => {\n let httpRequest = req;\n httpRequest = controllerInstance.requests[methodName]\n ? new controllerInstance.requests[methodName](\n req.rawRequest,\n req.params,\n )\n : httpRequest;\n return controllerHandler(req);\n };\n this.children = class extends ViewRouter {\n routes = routes ?? ({} as T);\n };\n } else {\n this.children = class extends ViewRouter {\n routes = handlerOrRoutes as T;\n };\n this.handler = () => ({}) as Output;\n }\n }\n\n async run(req: HttpRequest<Input, Params>) {\n return {\n [this.viewPath]: await this.handler(req),\n };\n }\n\n middleware(middlewares: string[]) {\n this.middlewares = middlewares;\n return this;\n }\n}\n\nexport class ViewRouter {\n middlewares: string[] = [];\n routes: ViewRoutes = {};\n\n public view<C extends new () => Controller, M extends ControllerMethods<C>>(\n viewPath: string,\n handler?: [C, M],\n ): ParseViewControllerHandler<C, M>;\n public view<Input, Output, Params>(\n viewPath: string,\n handler?: ViewHandler<Input, Output, Params>,\n ): ViewRoute<Input, Output, Params>;\n public view<C extends new () => Controller, M extends ControllerMethods<C>>(\n viewPath: string,\n handler?: [C, M] | ViewHandler<any, any, any>,\n ) {\n return new ViewRoute(viewPath, handler as any);\n }\n\n public layout<T extends ViewRoutes>(\n viewPath: string,\n handlerOrRoutes: T,\n routes?: T,\n ): LayoutRoute<T, any, any, any>;\n public layout<\n T extends ViewRoutes,\n C extends new () => Controller,\n M extends ControllerMethods<C>,\n >(\n viewPath: string,\n handlerOrRoutes: [C, M],\n routes?: T,\n ): ParseLayoutControllerHandler<T, C, M>;\n public layout<T extends ViewRoutes, Input, Output, Params>(\n viewPath: string,\n handlerOrRoutes: CallbackHandler<Input, Output, Params>,\n routes?: T,\n ): LayoutRoute<T, Input, Output, Params>;\n public layout<\n T extends ViewRoutes,\n C extends new () => Controller,\n M extends ControllerMethods<C>,\n >(\n viewPath: string,\n handlerOrRoutes: ViewHandler<any, any, any> | [C, M] | T,\n routes?: T,\n ) {\n return new LayoutRoute(viewPath, handlerOrRoutes as any, routes);\n }\n}\n\ntype ViewRouteParser<T, Prefix extends PropertyKey = \"\"> =\n T extends ViewRoute<infer Input, infer Output, infer Params>\n ? KeyAndValue<`view:${Prefix & string}`, ViewHandler<Input, Output, Params>>\n : never;\n\ntype LayoutRouteParser<T, Prefix extends PropertyKey = \"\"> =\n T extends LayoutRoute<infer Routes, infer I, infer O, infer P>\n ?\n | RoutesParser<Routes, Prefix>\n | KeyAndValue<`layout:${Prefix & string}`, ViewHandler<I, O, P>>\n : never;\n\ntype ParsePrefixAndKey<\n P extends PropertyKey,\n K extends PropertyKey,\n U = `${P & string}${K & string}`,\n> = U extends \"//\"\n ? \"/\"\n : U extends `${infer T1}//${infer T2}`\n ? `${T1}/${T2}`\n : U extends `${infer T1}/${infer T2}/`\n ? `${T1}/${T2}`\n : U;\n\ntype RouterInstanceParser<\n T extends new () => ViewRouter,\n Prefix extends PropertyKey = \"\",\n> = RoutesParser<InstanceType<T>[\"routes\"], Prefix>;\n\ntype RoutesParser<\n T extends ViewRoutes,\n Prefix extends PropertyKey = \"\",\n K extends keyof T = keyof T,\n> = K extends any\n ? T[K] extends new () => ViewRouter\n ? RouterInstanceParser<T[K], ParsePrefixAndKey<Prefix, K>>\n : T[K] extends LayoutRoute<any, any, any, any>\n ? LayoutRouteParser<T[K], ParsePrefixAndKey<Prefix, K>>\n : T[K] extends ViewRoute<any, any, any>\n ? ViewRouteParser<T[K], ParsePrefixAndKey<Prefix, K>>\n : never\n : never;\n\nexport type CreateViewRPC<\n T extends ViewRouter,\n Prefix extends PropertyKey = \"\",\n> = KeyAndValueToObject<RoutesParser<T[\"routes\"], Prefix>>;\n",
9
+ "export const GEMI_REQUEST_BREAKER_ERROR = \"GEMI_REQUEST_BREAKER_ERROR\";\n\nexport class RequestBreakerError extends Error {\n public kind = GEMI_REQUEST_BREAKER_ERROR;\n public payload: {\n api: Record<string, any>;\n view: Record<string, any>;\n } = { api: {}, view: {} };\n}\n",
10
+ "import { RequestBreakerError } from \"./Error\";\nimport type { HttpRequest } from \"./HttpRequest\";\n\ntype MiddlewareResult = Partial<{\n headers: Record<string, string>;\n cookies: Record<string, string>;\n}>;\n\nexport type MiddlewareReturnType =\n | void\n | Promise<MiddlewareResult>\n | MiddlewareResult;\n\nexport type RouterMiddleware = (\n req: HttpRequest,\n ctx: any,\n) => MiddlewareReturnType;\n\nexport class ValidationError extends RequestBreakerError {\n errors: Record<string, string[]> = {};\n constructor(errors: Record<string, string[]>) {\n super(\"Validation error\");\n this.name = \"ValidationError\";\n this.errors = errors;\n this.payload = {\n api: {\n status: 400,\n data: {\n error: {\n kind: \"validation_error\",\n messages: errors,\n },\n },\n headers: {\n \"Content-Type\": \"application/json\",\n },\n },\n view: {\n status: 400,\n },\n };\n }\n}\n",
11
+ "import { AsyncLocalStorage } from \"async_hooks\";\nimport { Cookie, type CreateCookieOptions } from \"./Cookie\";\nimport { HttpRequest } from \"./HttpRequest\";\n\nconst requestContext = new AsyncLocalStorage<Store>();\n\nclass Store {\n cookies: Set<Cookie> = new Set();\n headers: Headers = new Headers();\n prefetchedResources = new Map<string, Record<string, any>>();\n prefetchPromiseQueue = new Set<() => Promise<any>>();\n user: any = null;\n\n constructor(public req: HttpRequest) {}\n\n setCookie(name: string, value: string, options: CreateCookieOptions = {}) {\n this.cookies.add(new Cookie(name, value, options));\n }\n\n setHeaders(name: string, value: string) {\n this.headers.set(name, value);\n }\n\n setUser(user: any) {\n this.user = user;\n }\n\n setRequest(req: HttpRequest<any, any>) {\n this.req = req;\n }\n\n destroy() {\n delete this.cookies;\n delete this.headers;\n delete this.prefetchedResources;\n delete this.prefetchPromiseQueue;\n delete this.user;\n }\n}\n\nexport class RequestContext {\n static getStore() {\n return requestContext.getStore()!;\n }\n\n static setRequest(req: HttpRequest<any, any>) {\n requestContext.getStore().req = req;\n }\n\n static run<T>(httpRequest: HttpRequest, fn: () => T): T {\n return requestContext.run(new Store(httpRequest), fn);\n }\n}\n",
12
+ "export interface CreateCookieOptions {\n maxAge?: number;\n expires?: Date;\n httpOnly?: boolean;\n secure?: boolean;\n sameSite?: \"Strict\" | \"Lax\";\n path?: string;\n domain?: string;\n partitioned?: boolean;\n}\n\nexport class Cookie {\n constructor(\n private name: string,\n private value: string,\n private options: CreateCookieOptions = {},\n ) {}\n\n toString() {\n return [\n `${this.name}=${this.value}`,\n this.options.maxAge ? `Max-Age=${this.options.maxAge}` : \"\",\n this.options.httpOnly ? \"HttpOnly\" : \"\",\n this.options.secure ? \"Secure\" : \"\",\n this.options.sameSite\n ? `SameSite=${this.options.sameSite}`\n : \"SameSite=Strict\",\n this.options.path ? `Path=${this.options.path}` : \"Path=/\",\n this.options.domain ? `Domain=${this.options.domain}` : \"\",\n this.options.expires\n ? `Expires=${this.options.expires.toUTCString()}`\n : \"\",\n this.options.partitioned ? \"Partitioned\" : \"\",\n ]\n .filter((i) => i !== \"\")\n .join(\"; \");\n }\n}\n",
13
+ "import { RequestContext } from \"./requestContext\";\nimport { ValidationError } from \"./Router\";\n\nclass Input<T extends Record<string, any>> {\n constructor(private data: T) {}\n\n public get(key: keyof T): T[keyof T] {\n return this.data[key];\n }\n\n public set(key: keyof T, value: T[keyof T]) {\n this.data[key] = value;\n }\n\n public has(key: keyof T) {\n return this.data[key] !== undefined;\n }\n\n public toJSON(): T {\n return this.data;\n }\n}\n\n// Formats B KB MB GB TB\n// e.g parseFileSizeString(\"1MB\") => 1024 * 1024\nfunction parseFileSizeString(size: string) {\n const [number, unit] = size.match(/\\d+|\\D+/g) ?? [];\n if (!number || !unit) {\n return 0;\n }\n const fileSize = parseInt(number);\n switch (unit) {\n case \"B\":\n return fileSize;\n case \"KB\":\n return fileSize * 1024;\n case \"MB\":\n return fileSize * 1024 * 1024;\n case \"GB\":\n return fileSize * 1024 * 1024 * 1024;\n case \"TB\":\n return fileSize * 1024 * 1024 * 1024 * 1024;\n default:\n return 0;\n }\n}\n\n// Formats png, jpg, ttf, excel, csv, word, pdf, json\n// Eg. png => image/png\nfunction parseFileTypeString(type: string) {\n switch (type) {\n case \"image\":\n return \"image\";\n case \"png\":\n return \"image/png\";\n case \"jpg\":\n return \"image/jpeg\";\n case \"jpeg\":\n return \"image/jpeg\";\n case \"ttf\":\n return \"font/ttf\";\n case \"excel\":\n return \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\";\n case \"csv\":\n return \"text/csv\";\n case \"word\":\n return \"application/vnd.openxmlformats-officedocument.wordprocessingml.document\";\n case \"pdf\":\n return \"application/pdf\";\n case \"json\":\n return \"application/json\";\n default:\n return type;\n }\n}\n\nfunction validate(ruleName: string) {\n const [rule, param] = ruleName.split(\":\");\n switch (rule) {\n case \"required\":\n return (value: any) => {\n if (value instanceof Blob) {\n return value.size > 0;\n }\n return value !== null && value !== undefined && value?.length > 0;\n };\n case \"password\":\n return (value: any) => {\n // min 8 characters\n // at least one uppercase letter,\n // at least one lowercase letter and one number\n // at least one special character\n const passwordRegex =\n /^(?=.*\\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[^a-zA-Z0-9]).{8,}$/;\n return passwordRegex.test(value);\n };\n\n case \"number\":\n return (value: any) => {\n if (typeof value !== \"number\") return false;\n\n return !isNaN(value);\n };\n case \"min\":\n return (value: any) => {\n return value?.length >= parseInt(param);\n };\n case \"max\":\n return (value: any) => {\n return value?.length <= parseInt(param);\n };\n case \"email\":\n return (value: any) => {\n const emailRegex = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/;\n return emailRegex.test(value);\n };\n case \"file\":\n return (value: any) => {\n return value instanceof Blob;\n };\n case \"fileType\":\n return (value: Blob) => {\n if (value instanceof Blob) {\n const parsedType = parseFileTypeString(param);\n return value.type.startsWith(parsedType);\n }\n };\n\n case \"fileSize\":\n return (value: Blob) => {\n if (value instanceof Blob) {\n const absoluteSize = parseFileSizeString(param);\n return value.size <= absoluteSize;\n }\n };\n default:\n return () => true;\n }\n}\n\ntype StringType = \"string\";\ntype NumberType = \"number\";\ntype BooleanType = \"boolean\";\ntype MinLengthType = `min:${number}`;\ntype MaxLengthType = `max:${number}`;\ntype RequiredType = \"required\";\ntype FileType = \"file\";\ntype FileTypeType = \"fileType:${string}\";\ntype FileSizeType = \"fileSize:${string}\";\ntype SchemaKey =\n | StringType\n | NumberType\n | BooleanType\n | MinLengthType\n | MaxLengthType\n | RequiredType\n | FileType\n | FileTypeType\n | FileSizeType;\n\nexport type Schema<T extends Body> = Record<\n keyof T,\n Partial<Record<SchemaKey, string>>\n>;\n\nexport type Body = Record<string, any>;\n\nexport class HttpRequest<\n T extends Body = Record<string, never>,\n Params = Record<string, never>,\n> {\n public rawRequest: Request;\n public headers: Headers;\n public cookies: Map<string, string>;\n public search: Input<T>;\n public schema: any = {};\n\n public params: Params;\n public ctx = RequestContext.getStore();\n\n constructor(req?: Request, params?: any) {\n if (!req) {\n const _req = RequestContext.getStore().req;\n this.params = _req.params as any;\n this.rawRequest = _req.rawRequest;\n } else {\n this.params = params;\n this.rawRequest = req;\n }\n\n this.headers = this.rawRequest.headers;\n\n const cookie = this.rawRequest.headers.get(\"Cookie\");\n const cookies = new Map();\n if (cookie) {\n const cookieArray = cookie.split(\";\");\n for (const c of cookieArray) {\n const [key, value] = c.split(\"=\");\n cookies.set(key.trim(), value.trim());\n }\n }\n if (this.rawRequest.method === \"GET\") {\n const url = new URL(this.rawRequest.url);\n const map = new Map<string, string | string[]>();\n for (const [key, value] of url.searchParams) {\n if (map.has(key)) {\n const currentValue = map.get(key);\n if (Array.isArray(currentValue)) {\n currentValue.push(value);\n map.set(key, currentValue);\n } else {\n map.set(key, [currentValue, value]);\n }\n } else {\n map.set(key, value);\n }\n }\n const params = Object.fromEntries(map.entries());\n this.search = new Input<T>(params as T);\n }\n this.cookies = cookies;\n }\n\n public refine(_input: any): any {\n return {};\n }\n\n private async parseBody() {\n const inputMap = new Input<T>({} as T);\n if (this.rawRequest.headers.get(\"Content-Type\") === \"application/json\") {\n const body = await this.rawRequest.json();\n for (const [key, value] of Object.entries(body)) {\n inputMap.set(key, value as T[keyof T]);\n }\n }\n if (\n this.rawRequest.headers.get(\"Content-Type\") ===\n \"application/x-www-form-urlencoded\"\n ) {\n const body = (await this.rawRequest.formData()) as any; // TODO: fix type\n for (const [key, value] of body) {\n inputMap.set(key, value as T[keyof T]);\n }\n }\n\n if (\n this.rawRequest.headers\n .get(\"Content-Type\")\n ?.startsWith(\"multipart/form-data\")\n ) {\n const body = (await this.rawRequest.formData()) as any; // TODO: fix type\n for (const [key, value] of body) {\n if (inputMap.has(key)) {\n const currentValue = inputMap.get(key);\n if (Array.isArray(currentValue)) {\n currentValue.push(value);\n inputMap.set(key, currentValue);\n } else {\n inputMap.set(key, [currentValue, value] as any);\n }\n } else {\n inputMap.set(key, value as T[keyof T]);\n }\n }\n }\n return inputMap;\n }\n\n private validateInput(input: Input<T>) {\n const errors: Record<string, string[]> = {};\n for (const [key, rules] of Object.entries(this.schema)) {\n for (const [rule, message] of Object.entries(rules)) {\n const validator = validate(rule);\n\n let _message = message;\n let _isValid = false;\n if (typeof message === \"function\") {\n _message = message(input.get(key));\n _isValid = typeof _message === \"undefined\";\n } else {\n _isValid = validator(input.get(key));\n }\n\n if (_isValid) {\n continue;\n }\n\n if (!errors[key]) {\n errors[key] = [];\n }\n if (rule === \"required\") {\n errors[key] = [String(_message)];\n break;\n } else {\n errors[key].push(String(_message));\n }\n }\n }\n\n for (const [key, value] of Object.entries(\n this.refine(input.toJSON()) ?? {},\n )) {\n if (!errors[key]) {\n errors[key] = [];\n }\n errors[key] = [...(errors[key] ?? []), value as string];\n }\n\n if (Object.keys(errors).length > 0) {\n throw new ValidationError(errors);\n } else {\n return input;\n }\n }\n\n public async input(): Promise<Input<T>> {\n return this.validateInput(await this.parseBody());\n }\n\n public async safeInput(): Promise<{\n isValid: boolean;\n errors: Record<string, string[]>;\n input: Input<T>;\n }> {\n const input = await this.parseBody();\n try {\n this.validateInput(input);\n return {\n isValid: true,\n errors: {},\n input,\n };\n } catch (err) {\n if (!(err instanceof ValidationError)) {\n throw err;\n }\n return {\n isValid: false,\n errors: err.errors,\n input,\n };\n }\n }\n\n // TODO implement this method\n public async terminate(_params: TerminateParams) {\n throw \"not implemented\";\n }\n}\n\n// class TerminateError extends RequestBreakerError {\n// constructor(\n// private requestKind: \"api\" | \"view\",\n// private payload: Record<string, any>,\n// ) {\n// super();\n// const api = requestKind === \"view\" ? {} : payload;\n// const view = requestKind === \"api\" ? {} : payload;\n\n// this.payload = { api, view };\n// }\n// }\n\ntype TerminateParams = {\n message: string;\n status: number;\n headers?: Record<string, string>;\n payload?: Record<string, any>;\n};\n",
14
+ "import { HttpRequest } from \"./HttpRequest\";\n\nexport class Middleware {\n constructor(public routePath: string) {}\n async run(_req: HttpRequest, ..._args: any[]) {\n return {};\n }\n}\n",
15
+ "export function getCookies(req: Request): Map<string, string> {\n const cookies = req.headers.get(\"cookie\");\n if (!cookies) {\n return new Map();\n }\n const _cookies = new Map();\n const cookieStrings = cookies.split(\";\");\n for (const cookieString of cookieStrings) {\n const [name, value] = cookieString.split(\"=\");\n _cookies.set(name.trim(), value);\n }\n return _cookies;\n}\n",
16
+ "import { ServiceProvider } from \"../services/ServiceProvider\";\nimport { Middleware } from \"./Middleware\";\n\nexport class MiddlewareServiceProvider extends ServiceProvider {\n aliases: Record<string, new (routePath: string) => Middleware> = {};\n\n boot() {}\n}\n",
17
+ "import { RequestBreakerError } from \"./Error\";\n\nexport class AuthorizationError extends RequestBreakerError {\n private error: string;\n constructor(error: string = \"Not authorized\") {\n super(\"Authentication error\");\n this.name = \"AuthenticationError\";\n this.error = error;\n this.payload = {\n api: {\n status: 401,\n data: { error: this.error },\n },\n view: {},\n };\n }\n}\n\nexport class InsufficientPermissionsError extends RequestBreakerError {\n private error: string;\n constructor(error: string = \"Insufficient permissions\") {\n super(\"Authentication error\");\n this.name = \"AuthenticationError\";\n this.error = error;\n this.payload = {\n api: {\n status: 401,\n data: { error: this.error },\n },\n view: {},\n };\n }\n}\n\nexport class AuthenticationError extends RequestBreakerError {\n constructor() {\n super(\"Authentication error\");\n this.name = \"AuthenticationError\";\n }\n\n payload = {\n api: {\n status: 401,\n data: { error: \"Authentication error\" },\n },\n view: {\n status: 302,\n headers: {\n \"Cache-Control\":\n \"private, no-cache, no-store, max-age=0, must-revalidate\",\n Location: \"/auth/sign-in\",\n },\n },\n };\n}\n",
18
+ "import { ServiceContainer } from \"../services/ServiceContainer\";\nimport { AuthenticationServiceProvider } from \"./AuthenticationServiceProvider\";\n\nexport class AuthenticationServiceContainer extends ServiceContainer {\n name = \"AuthenticationServiceContainer\";\n\n constructor(public provider: AuthenticationServiceProvider) {\n super();\n }\n\n async getSession(token: string, userAgent: string) {\n const session = await this.provider.adapter.findSession({\n token,\n userAgent,\n });\n let sessionExtension = null;\n if (session?.user) {\n sessionExtension = await this.provider.extendSession(session.user);\n session.user[\"extension\"] = sessionExtension;\n }\n return session;\n }\n}\n",
19
+ "import { HttpRequest } from \"./HttpRequest\";\nimport { Middleware } from \"./Middleware\";\nimport { RequestContext } from \"./requestContext\";\nimport { KernelContext } from \"../kernel/KernelContext\";\nimport { AuthenticationError } from \"./errors\";\nimport { AuthenticationServiceContainer } from \"../auth/AuthenticationServiceContainer\";\n\nexport class AuthenticationMiddleware extends Middleware {\n async run(req: HttpRequest) {\n const requestContextStore = RequestContext.getStore();\n const accessToken = requestContextStore.req.cookies.get(\"access_token\");\n\n if (!accessToken) {\n throw new AuthenticationError();\n }\n\n let user = requestContextStore.user;\n\n if (!user) {\n const session = await AuthenticationServiceContainer.use().getSession(\n accessToken,\n requestContextStore.req.headers.get(\"User-Agent\"),\n );\n if (!session) {\n throw new AuthenticationError();\n }\n user = session?.user;\n requestContextStore.setUser(user);\n }\n\n return {};\n }\n}\n",
20
+ "import { ServiceContainer } from \"../ServiceContainer\";\nimport { RateLimiterServiceProvider } from \"./RateLimiterServiceProvider\";\n\nexport class RateLimiterServiceContainer extends ServiceContainer {\n name = \"RateLimiterServiceContainer\";\n\n constructor(public service: RateLimiterServiceProvider) {\n super();\n }\n}\n",
21
+ "import { KernelContext } from \"../kernel/KernelContext\";\nimport { RateLimiterServiceContainer } from \"../services/rate-limiter/RateLimiterServiceContainer\";\nimport { RequestBreakerError } from \"./Error\";\nimport { HttpRequest } from \"./HttpRequest\";\nimport { Middleware } from \"./Middleware\";\n\nclass RateLimitExceededError extends RequestBreakerError {\n constructor() {\n super(\"Rate limit exceeded\");\n this.payload = {\n api: {\n status: 429,\n data: {\n error: {\n message: \"Rate limit exceeded\",\n },\n },\n headers: {\n \"Content-Type\": \"application/json\",\n },\n },\n view: {\n error: {\n message: \"Rate limit exceeded\",\n },\n status: 429,\n },\n };\n }\n}\n\nexport class RateLimitMiddleware extends Middleware {\n async run(req: HttpRequest, limit = 1000) {\n const userId = req.headers.get(\"x-forwarded-for\");\n const driver = RateLimiterServiceContainer.use().service.driver;\n const result = driver.consume.call(driver, userId, this.routePath);\n if (result > limit) {\n throw new RateLimitExceededError();\n }\n\n return {};\n }\n}\n",
22
+ "import { Policies } from \"./Policy\";\n\nexport class PoliciesServiceProvider {\n policiesList: Record<string, Policies> = {};\n constructor() {\n const policies = this.register();\n for (const Policy of policies) {\n const policy = new Policy();\n this.policiesList[Policy.name] = policy;\n }\n }\n\n protected register(): Array<new () => Policies> {\n return [];\n }\n}\n",
23
+ "export class Policies {\n all(_operation: string, _args: any): Promise<boolean> | boolean {\n return true;\n }\n}\n",
24
+ "import { HttpRequest } from \"./HttpRequest\";\n\nimport type { Translations } from \"../client/i18n/I18nContext\";\nimport { ServiceProvider } from \"../services/ServiceProvider\";\n\nexport class I18nServiceProvider extends ServiceProvider {\n dictionary: Translations = {};\n supportedLocales: string[] = [];\n defaultLocale = \"en-US\";\n\n async init() {}\n\n detectLocale(_req: HttpRequest) {\n return this.defaultLocale;\n }\n\n boot() {}\n}\n"
25
+ ],
26
+ "mappings": "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",
27
+ "debugId": "8AD557EF9D03F5BF64756e2164756e21",
28
+ "names": []
29
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"Kernel.d.ts","sourceRoot":"","sources":["../../kernel/Kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,uCAAuC,CAAC;AAGtF,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAC;AAC9E,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAGlE,OAAO,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AAEjG,OAAO,EAAE,wBAAwB,EAAE,MAAM,6CAA6C,CAAC;AAGvF,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AACzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAG9E,OAAO,EAAE,2BAA2B,EAAE,MAAM,gDAAgD,CAAC;AAE7F,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,qBAAa,MAAM;IACjB,SAAS,CAAC,oBAAoB,8BAAwB;IACtD,SAAS,CAAC,6BAA6B,uCAAiC;IACxE,SAAS,CAAC,yBAAyB,mCAA6B;IAChE,SAAS,CAAC,mBAAmB,6BAAuB;IACpD,SAAS,CAAC,0BAA0B,oCAA8B;IAClE,SAAS,CAAC,wBAAwB,kCAA4B;IAC9D,SAAS,CAAC,yBAAyB,mCAA6B;IAChE,SAAS,CAAC,0BAA0B,oCAA8B;IAClE,SAAS,CAAC,4BAA4B,qCAA+B;IAErE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAM;IAEhD,IAAI;IAgBJ,yBAAyB,CAAC,GAAG,UAAU,EAAE,gBAAgB,EAAE;IAM3D,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC;CAGnB"}
1
+ {"version":3,"file":"Kernel.d.ts","sourceRoot":"","sources":["../../kernel/Kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,uCAAuC,CAAC;AAGtF,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAC;AAC9E,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAGlE,OAAO,EAAE,0BAA0B,EAAE,MAAM,qDAAqD,CAAC;AAEjG,OAAO,EAAE,wBAAwB,EAAE,MAAM,6CAA6C,CAAC;AAGvF,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAC;AACzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wCAAwC,CAAC;AAG9E,OAAO,EAAE,2BAA2B,EAAE,MAAM,gDAAgD,CAAC;AAE7F,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAEhE,qBAAa,MAAM;IACjB,SAAS,CAAC,oBAAoB,8BAAwB;IACtD,SAAS,CAAC,6BAA6B,uCAAiC;IACxE,SAAS,CAAC,yBAAyB,mCAA6B;IAChE,SAAS,CAAC,mBAAmB,6BAAuB;IACpD,SAAS,CAAC,0BAA0B,oCAA8B;IAClE,SAAS,CAAC,wBAAwB,kCAA4B;IAC9D,SAAS,CAAC,yBAAyB,mCAA6B;IAChE,SAAS,CAAC,0BAA0B,oCAA8B;IAClE,SAAS,CAAC,4BAA4B,qCAA+B;IAErE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAM;IAEhD,IAAI;IAgBJ,yBAAyB,CAAC,GAAG,UAAU,EAAE,gBAAgB,EAAE;IAM3D,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC;CAKnB"}
@@ -1,2 +1,4 @@
1
1
  // @bun
2
- import{j as y,m as G,n as H,o as J} from"../http/index.js";import{p as K,r as N,s as Q,u as q,v as U,w as W} from"../facades/index.js";import{A as D,B as T,C as B,x as Z,y as _,z as $} from"../services/index.js";import"../chunk-869ca3630adc189b.js";import{G as z} from"../chunk-642b04056dab5d64.js";import"../chunk-99c32e4d937131e0.js";import"../chunk-0d97333b6af9fc45.js";import{L as X} from"../chunk-e4961d79807acd3d.js";import"../chunk-643529c2ad120db7.js";import"../chunk-2f8cf8372320b622.js";import{O as Y} from"../chunk-b84d011a2972c7d1.js";import"../chunk-23d3df5f8342ecc6.js";import"../chunk-28ec4c2b20e69deb.js";import"../chunk-6ac923265710cdd6.js";import"../chunk-efd43c1cf8f87db4.js";import"../chunk-eee44b06ba2a6e36.js";import"../chunk-931a005d4bb28ffe.js";import"../chunk-bdac4694bbb37064.js";import"../chunk-cf9df3002593e357.js";import"../chunk-96e59b185e2d1612.js";class E{emailServiceProvider=D;authenticationServiceProvider=q;middlewareServiceProvider=y;i18nServiceProvider=J;fileStorageServiceProvider=Z;apiRouterServiceProvider=_;viewRouterServiceProvider=B;rateLimiterServiceProvider=$;broadcastingsServiceProvider=T;services={};boot(){this.registerServiceContainers(new Y(new this.emailServiceProvider),new G(new this.authenticationServiceProvider),new U(new this.middlewareServiceProvider),new N(new this.i18nServiceProvider),new Q(new this.fileStorageServiceProvider),new W(new this.apiRouterServiceProvider),new X(new this.viewRouterServiceProvider),new H(new this.rateLimiterServiceProvider),new K(new this.broadcastingsServiceProvider))}registerServiceContainers(...f){for(let j of f)this.services[j.name]=j}run(f){return z.run(this.services,f)}}class F{f;constructor(f){this.prisma=f}async createSession(f){return await this.prisma.session.create({data:f,include:{user:!0}})}async createUser(f){return await this.prisma.user.create({data:f})}async deleteSession(f){return await this.prisma.session.deleteMany({where:{token:f.token}})}async findUserByEmailAddress(f){return await this.prisma.user.findUnique({where:{email:f}})}async findSession(f){if(!f.token)return null;try{return await this.prisma.session.findUnique({where:{token:f.token,userAgent:"local"},include:{user:{select:{password:!1,id:!0,email:!0,globalRole:!0,name:!0,publicId:!0,accounts:{select:{id:!0,publicId:!0,organization:!0,organizationRole:!0}}}}}})}catch(j){return console.log(j),null}}async updateSession(f){return await this.prisma.session.update({where:{token:f.token},data:{expiresAt:f.expiresAt},include:{user:{select:{password:!1,email:!0,globalRole:!0,name:!0,publicId:!0,accounts:{select:{id:!0,publicId:!0,organization:!0,organizationRole:!0}},organization:!0}}}})}async updateUserPassword(f){return await this.prisma.user.update({where:{id:f.id},data:{password:f.password}})}async createPasswordResetToken(f){return await this.prisma.passwordResetToken.create({data:{user:{connect:{id:f.user.id}},token:f.token}})}async findPasswordResetToken(f){const{token:j}=f;return await this.prisma.passwordResetToken.findUnique({where:{token:j},include:{user:!0}})}async deleteAllUserSessions(f){return await this.prisma.session.deleteMany({where:{userId:f}})}async deletePasswordResetToken(f){const{token:j}=f;return await this.prisma.passwordResetToken.delete({where:{token:j}})}}export{F as PrismaAuthenticationAdapter,E as Kernel,q as AuthenticationServiceProvider};
2
+ import{j as y,m as G,n as H,o as J} from"../http/index.js";import{p as K,r as N,s as Q,u as q,v as U,w as W} from"../facades/index.js";import{A as D,B as T,C as B,x as Z,y as _,z as $} from"../services/index.js";import"../chunk-d5b8023c223e3a60.js";import{G as z} from"../chunk-642b04056dab5d64.js";import"../chunk-99c32e4d937131e0.js";import"../chunk-0d97333b6af9fc45.js";import{L as X} from"../chunk-e4961d79807acd3d.js";import"../chunk-643529c2ad120db7.js";import"../chunk-2f8cf8372320b622.js";import{O as Y} from"../chunk-b84d011a2972c7d1.js";import"../chunk-23d3df5f8342ecc6.js";import"../chunk-28ec4c2b20e69deb.js";import"../chunk-c8c4a1285a266c51.js";import"../chunk-683905a55f8da1ad.js";import"../chunk-9f9e21f9fd0d6af1.js";import"../chunk-bd708d3c982948aa.js";import"../chunk-cd4bfdd46ec4cbb8.js";import"../chunk-201c5005a90452fa.js";import"../chunk-bace428bfab523c4.js";class E{emailServiceProvider=D;authenticationServiceProvider=q;middlewareServiceProvider=y;i18nServiceProvider=J;fileStorageServiceProvider=Z;apiRouterServiceProvider=_;viewRouterServiceProvider=B;rateLimiterServiceProvider=$;broadcastingsServiceProvider=T;services={};boot(){this.registerServiceContainers(new Y(new this.emailServiceProvider),new G(new this.authenticationServiceProvider),new U(new this.middlewareServiceProvider),new N(new this.i18nServiceProvider),new Q(new this.fileStorageServiceProvider),new W(new this.apiRouterServiceProvider),new X(new this.viewRouterServiceProvider),new H(new this.rateLimiterServiceProvider),new K(new this.broadcastingsServiceProvider))}registerServiceContainers(...f){for(let j of f)this.services[j.name]=j}run(f){const j=this.services;return console.log("services",Object.keys(j)),z.run(j,f)}}class F{f;constructor(f){this.prisma=f}async createSession(f){return await this.prisma.session.create({data:f,include:{user:!0}})}async createUser(f){return await this.prisma.user.create({data:f})}async deleteSession(f){return await this.prisma.session.deleteMany({where:{token:f.token}})}async findUserByEmailAddress(f){return await this.prisma.user.findUnique({where:{email:f}})}async findSession(f){if(!f.token)return null;try{return await this.prisma.session.findUnique({where:{token:f.token,userAgent:"local"},include:{user:{select:{password:!1,id:!0,email:!0,globalRole:!0,name:!0,publicId:!0,accounts:{select:{id:!0,publicId:!0,organization:!0,organizationRole:!0}}}}}})}catch(j){return console.log(j),null}}async updateSession(f){return await this.prisma.session.update({where:{token:f.token},data:{expiresAt:f.expiresAt},include:{user:{select:{password:!1,email:!0,globalRole:!0,name:!0,publicId:!0,accounts:{select:{id:!0,publicId:!0,organization:!0,organizationRole:!0}},organization:!0}}}})}async updateUserPassword(f){return await this.prisma.user.update({where:{id:f.id},data:{password:f.password}})}async createPasswordResetToken(f){return await this.prisma.passwordResetToken.create({data:{user:{connect:{id:f.user.id}},token:f.token}})}async findPasswordResetToken(f){const{token:j}=f;return await this.prisma.passwordResetToken.findUnique({where:{token:j},include:{user:!0}})}async deleteAllUserSessions(f){return await this.prisma.session.deleteMany({where:{userId:f}})}async deletePasswordResetToken(f){const{token:j}=f;return await this.prisma.passwordResetToken.delete({where:{token:j}})}}export{F as PrismaAuthenticationAdapter,E as Kernel,q as AuthenticationServiceProvider};
3
+
4
+ //# debugId=EC9AD6AA85C4A4F064756e2164756e21
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../kernel/Kernel.ts", "../auth/adapters/prisma.ts"],
4
+ "sourcesContent": [
5
+ "import { AuthenticationServiceProvider } from \"../auth/AuthenticationServiceProvider\";\nimport { AuthenticationServiceContainer } from \"../auth/AuthenticationServiceContainer\";\nimport { kernelContext } from \"./context\";\nimport { MiddlewareServiceProvider } from \"../http/MiddlewareServiceProvider\";\nimport { I18nServiceProvider } from \"../http/I18nServiceProvider\";\nimport { I18nServiceContainer } from \"../http/I18nServiceContainer\";\nimport { FileStorageServiceContainer } from \"../services/file-storage/FileStorageServiceContainer\";\nimport { FileStorageServiceProvider } from \"../services/file-storage/FileStorageServiceProvider\";\nimport { ApiRouterServiceContainer } from \"../services/router/ApiRouterServiceContainer\";\nimport { ApiRouterServiceProvider } from \"../services/router/ApiRouterServiceProvider\";\nimport { MiddlewareServiceContainer } from \"../services/middleware/MiddlewareServiceContainer\";\nimport { RateLimiterServiceContainer } from \"../services/rate-limiter/RateLimiterServiceContainer\";\nimport { RateLimiterServiceProvider } from \"../services\";\nimport { EmailServiceProvider } from \"../services/email/EmailServiceProvider\";\nimport { EmailServiceContainer } from \"../services/email/EmailServiceContainer\";\nimport { BroadcastingServiceContainer } from \"../services/pubsub/BroadcastingServiceContainer\";\nimport { BroadcastingServiceProvider } from \"../services/pubsub/BroadcastingServiceProvider\";\nimport { ViewRouterServiceContainer } from \"../services/router/ViewRouterServiceContainer\";\nimport { ViewRouterServiceProvider } from \"../services/router/ViewRouterServiceProvider\";\nimport { ServiceContainer } from \"../services/ServiceContainer\";\n\nexport class Kernel {\n protected emailServiceProvider = EmailServiceProvider;\n protected authenticationServiceProvider = AuthenticationServiceProvider;\n protected middlewareServiceProvider = MiddlewareServiceProvider;\n protected i18nServiceProvider = I18nServiceProvider;\n protected fileStorageServiceProvider = FileStorageServiceProvider;\n protected apiRouterServiceProvider = ApiRouterServiceProvider;\n protected viewRouterServiceProvider = ViewRouterServiceProvider;\n protected rateLimiterServiceProvider = RateLimiterServiceProvider;\n protected broadcastingsServiceProvider = BroadcastingServiceProvider;\n\n services: Record<string, ServiceContainer> = {};\n\n boot() {\n this.registerServiceContainers(\n new EmailServiceContainer(new this.emailServiceProvider()),\n new AuthenticationServiceContainer(\n new this.authenticationServiceProvider(),\n ),\n new MiddlewareServiceContainer(new this.middlewareServiceProvider()),\n new I18nServiceContainer(new this.i18nServiceProvider()),\n new FileStorageServiceContainer(new this.fileStorageServiceProvider()),\n new ApiRouterServiceContainer(new this.apiRouterServiceProvider()),\n new ViewRouterServiceContainer(new this.viewRouterServiceProvider()),\n new RateLimiterServiceContainer(new this.rateLimiterServiceProvider()),\n new BroadcastingServiceContainer(new this.broadcastingsServiceProvider()),\n );\n }\n\n registerServiceContainers(...containers: ServiceContainer[]) {\n for (const container of containers) {\n this.services[container.name] = container;\n }\n }\n\n run<T>(cb: () => T) {\n const services = this.services;\n console.log(\"services\", Object.keys(services));\n return kernelContext.run(services, cb);\n }\n}\n",
6
+ "import type {\n User,\n CreateSessionArgs,\n DeleteSessionArgs,\n SessionWithUser,\n CreateUserArgs,\n FindSessionArgs,\n UpdateSessionArgs,\n IAuthenticationAdapter,\n CreatePasswordResetTokenArgs,\n PasswordResetToken,\n FindPasswordResetTokenArgs,\n DeletePasswordResetTokenArgs,\n} from \"./types\";\n\nexport class PrismaAuthenticationAdapter implements IAuthenticationAdapter {\n constructor(private prisma: any) {}\n\n async createSession(args: CreateSessionArgs): Promise<SessionWithUser> {\n return await this.prisma.session.create({\n data: args,\n include: { user: true },\n });\n }\n\n async createUser(args: CreateUserArgs): Promise<User> {\n return await this.prisma.user.create({ data: args });\n }\n\n async deleteSession(args: DeleteSessionArgs): Promise<void> {\n return await this.prisma.session.deleteMany({\n where: { token: args.token },\n });\n }\n\n async findUserByEmailAddress(email: string): Promise<User> {\n return await this.prisma.user.findUnique({ where: { email } });\n }\n\n // TODO: extend the session until absolute expiration\n async findSession(args: FindSessionArgs): Promise<SessionWithUser | null> {\n if (!args.token) return null;\n try {\n const session = await this.prisma.session.findUnique({\n where: {\n token: args.token,\n userAgent:\n process.env.NODE_ENV === \"development\" ? \"local\" : args.userAgent,\n },\n include: {\n user: {\n select: {\n password: false,\n id: true,\n email: true,\n globalRole: true,\n name: true,\n publicId: true,\n accounts: {\n select: {\n id: true,\n publicId: true,\n organization: true,\n organizationRole: true,\n },\n },\n },\n },\n },\n });\n\n return session;\n } catch (err) {\n console.log(err);\n return null;\n }\n }\n\n async updateSession(\n args: UpdateSessionArgs,\n ): Promise<SessionWithUser | null> {\n return await this.prisma.session.update({\n where: { token: args.token },\n data: { expiresAt: args.expiresAt },\n include: {\n user: {\n select: {\n password: false,\n email: true,\n globalRole: true,\n name: true,\n publicId: true,\n accounts: {\n select: {\n id: true,\n publicId: true,\n organization: true,\n organizationRole: true,\n },\n },\n organization: true,\n },\n },\n },\n });\n }\n\n async updateUserPassword(args: {\n id: number;\n password: string;\n }): Promise<User> {\n return await this.prisma.user.update({\n where: { id: args.id },\n data: { password: args.password },\n });\n }\n\n async createPasswordResetToken(args: CreatePasswordResetTokenArgs) {\n return await this.prisma.passwordResetToken.create({\n data: {\n user: { connect: { id: args.user.id } },\n token: args.token,\n },\n });\n }\n\n async findPasswordResetToken(\n args: FindPasswordResetTokenArgs,\n ): Promise<PasswordResetToken | null> {\n const { token } = args;\n return await this.prisma.passwordResetToken.findUnique({\n where: { token },\n include: { user: true },\n });\n }\n\n async deleteAllUserSessions(userId: number) {\n return await this.prisma.session.deleteMany({ where: { userId } });\n }\n\n async deletePasswordResetToken(args: DeletePasswordResetTokenArgs) {\n const { token } = args;\n return await this.prisma.passwordResetToken.delete({ where: { token } });\n }\n}\n"
7
+ ],
8
+ "mappings": "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",
9
+ "debugId": "EC9AD6AA85C4A4F064756e2164756e21",
10
+ "names": []
11
+ }
@@ -38,3 +38,5 @@ import{J as k} from"../chunk-0d97333b6af9fc45.js";import{M as F} from"../chunk-6
38
38
  window.\$RefreshSig\$ = () => (type) => type;
39
39
  window.__vite_plugin_react_preamble_installed__ = true;
40
40
  `,{headers:{"Content-Type":"application/javascript"}});try{const f=await fetch(`http://localhost:5174${r}`);if(f.ok)return f}catch(f){console.log(f)}return await t.fetch.bind(t)(e,{RootLayout:i,options:{bootstrapModules:["/refresh.js","/app/client.tsx","http://localhost:5173/@vite/client"]}})}return c.watcher.on("change",async(e)=>{if(e.includes("app/views"))return;if(console.log(`[vite] ${e} changed. Updating...`),await c.moduleGraph.getModuleByUrl(`/${e}`))console.log(`[vite] ${e} changed. Updating...`)}),await c.listen(5174),Bun.serve({fetch:async(e)=>{return await m(e)},port:process.env.PORT||5173})}async function H(n){await E(n)}export{J as startProdServer,U as startDevServer,H as createServer};
41
+
42
+ //# debugId=464EA53A369E5B1164756e2164756e21
@@ -0,0 +1,17 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../server/dev.ts", "../server/styles.tsx", "../server/imageHandler.ts", "../server/renderErrorPage.ts", "../server/prod.ts", "../server/generateEtag.ts", "../server/createDevServer.ts", "../server/createServer.ts"],
4
+ "sourcesContent": [
5
+ "import { join } from \"path\";\nimport type { App } from \"../app/App\";\nimport { createStyles } from \"./styles\";\nimport { imageHandler } from \"./imageHandler\";\nimport { renderErrorPage } from \"./renderErrorPage\";\nimport { Serve } from \"bun\";\n\nconst rootDir = process.cwd();\nconst appDir = join(rootDir, \"app\");\n\nexport async function startDevServer() {\n const root = process.cwd();\n\n const vite = await (\n await import(\"vite\")\n ).createServer({\n root,\n logLevel: \"error\",\n server: {\n watch: {\n usePolling: true,\n interval: 100,\n },\n hmr: {\n clientPort: 5174,\n },\n },\n appType: \"custom\",\n resolve: {\n alias: {\n \"@/app\": appDir,\n },\n },\n });\n\n process.env.ROOT_DIR = rootDir;\n process.env.APP_DIR = appDir;\n\n async function handleDevRequests(req: Request): Promise<Response> {\n const { pathname } = new URL(req.url);\n if (pathname.startsWith(\"/refresh.js\")) {\n return new Response(\n `\n import RefreshRuntime from \"http://localhost:5173/@react-refresh\";\n RefreshRuntime.injectIntoGlobalHook(window);\n window.$RefreshReg$ = () => {};\n window.$RefreshSig$ = () => (type) => type;\n window.__vite_plugin_react_preamble_installed__ = true;\n `,\n {\n headers: {\n \"Content-Type\": \"application/javascript\",\n },\n },\n );\n }\n\n try {\n const res = await fetch(`http://localhost:5174${pathname}`);\n\n if (res.ok) {\n return res;\n }\n } catch (err) {\n console.log(err);\n }\n }\n\n async function getApp(): Promise<App> {\n try {\n return (await vite.ssrLoadModule(join(appDir, \"bootstrap.ts\"))).app;\n } catch (err) {\n console.log(\"Can't load bootstrap.ts\");\n console.error(err);\n }\n }\n\n async function createServe(app: App): Promise<Serve> {\n const handler = app.fetch.bind(app);\n return {\n fetch: async (req, server) => {\n if (server.upgrade(req, { data: { headers: req.headers } })) {\n return; // do not return a Response\n }\n if (!req.headers.get(\"x-forwarded-for\")) {\n const ip = server.requestIP(req);\n req.headers.set(\"x-forwarded-for\", ip.address);\n }\n\n const { pathname } = new URL(req.url);\n\n const devResponse = await handleDevRequests(req);\n if (devResponse instanceof Response) {\n return devResponse;\n }\n\n if (pathname.startsWith(\"/__gemi/image\")) {\n return await imageHandler(req);\n }\n\n try {\n const result = await handler(req);\n if (result instanceof Response) {\n return result;\n } else {\n const viewImportMap = {};\n const template = (viewName: string, path: string) =>\n `\"${viewName}\": () => import(\"${path}\")`;\n const templates = [];\n\n for (const fileName of [\n \"404\",\n ...app.getFlatComponentTree.call(app),\n ]) {\n if (process.env.NODE_ENV === \"test\") {\n break;\n }\n const appDir = `${process.env.APP_DIR}`;\n const mod = await vite.ssrLoadModule(\n `${appDir}/views/${fileName}.tsx`,\n );\n viewImportMap[fileName] = mod.default;\n templates.push(\n template(fileName, `${appDir}/views/${fileName}.tsx`),\n );\n }\n\n const loaders = `{${templates.join(\",\")}}`;\n const { default: css } = await vite.ssrLoadModule(\n `${appDir}/app.css`,\n );\n\n const styles = [];\n styles.push({\n isDev: true,\n id: `${appDir}/app.css`,\n content: css,\n });\n return await result({\n styles: createStyles(styles),\n bootstrapModules: [\n \"/refresh.js\",\n \"/app/client.tsx\",\n \"http://localhost:5173/@vite/client\",\n ],\n viewImportMap,\n loaders,\n });\n }\n } catch (err) {\n console.error(err);\n if (pathname.startsWith(\"/api\")) {\n return new Response(JSON.stringify({ error: err.message }), {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n });\n }\n return new Response(renderErrorPage(err), {\n headers: { \"Content-Type\": \"text/html\" },\n });\n }\n },\n port: process.env.PORT || 5173,\n websocket: app.websocket,\n };\n }\n\n await vite.listen(5174);\n\n const app = await getApp();\n const serve = await createServe(app);\n const server = Bun.serve(serve);\n app.onPublish(\n (\n topic: string,\n data: string | ArrayBufferView | ArrayBuffer | SharedArrayBuffer,\n compress?: boolean,\n ) => {\n server.publish(topic, data, compress);\n },\n );\n\n console.log(`Server started on http://localhost:${process.env.PORT || 5173}`);\n\n vite.watcher.on(\"change\", async (file) => {\n const fileRelativePath = file.replace(rootDir, \"\");\n if (fileRelativePath.startsWith(\"/app/views\")) {\n console.log(`[vite] ${fileRelativePath} changed. 🍜 Hot reloading...`);\n return;\n }\n\n console.log(`[vite] ${fileRelativePath} changed. Reloading...`);\n const modules = vite.moduleGraph.getModulesByFile(file);\n for (const mod of Array.from(modules)) {\n await vite.reloadModule(mod);\n }\n\n try {\n const app = await getApp();\n const serve = await createServe(app);\n app.onPublish(\n (\n topic: string,\n data: string | ArrayBufferView | ArrayBuffer | SharedArrayBuffer,\n compress?: boolean,\n ) => {\n server.publish(topic, data, compress);\n },\n );\n server.reload(serve);\n } catch (err) {\n console.log(\"Error on server reload\");\n console.log(err);\n }\n });\n\n return server;\n}\n",
6
+ "export function createStyles(styles) {\n return styles.map((style, i) => {\n if (style.isDev) {\n return (\n <style key={style.id} type=\"text/css\" data-vite-dev-id={style.id}>\n {style.content}\n </style>\n );\n } else {\n return (\n <style key={i} type=\"text/css\">\n {style.content}\n </style>\n );\n }\n });\n}\n",
7
+ "import sharp, { type FitEnum } from \"sharp\";\n\nexport async function imageHandler(req: Request): Promise<Response> {\n const url = new URL(req.url);\n const rawImageUrl = url.searchParams.get(\"url\");\n const width = Number(url.searchParams.get(\"w\"));\n const height = Number(url.searchParams.get(\"h\"));\n const fit = (url.searchParams.get(\"fit\") ??\n \"cover\") as unknown as keyof FitEnum;\n const quality = Number(url.searchParams.get(\"q\"));\n\n if (!rawImageUrl) {\n return new Response(\n JSON.stringify({\n error: \"url query parameter is required\",\n }),\n {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n status: 404,\n },\n );\n }\n const prefix = rawImageUrl.startsWith(\"http\")\n ? \"\"\n : `http://localhost:${process.env.PORT || 5173}`;\n const fullImageUrl = `${prefix}${rawImageUrl}`;\n const res = await fetch(fullImageUrl);\n if (!res.ok) {\n return new Response(\n JSON.stringify({\n error: \"Image not found\",\n info: fullImageUrl,\n }),\n {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n status: 404,\n },\n );\n }\n const imageBuffer = Buffer.from(await res.arrayBuffer());\n\n const buffer = await sharp(imageBuffer)\n .resize(width > 0 ? width : undefined, height > 0 ? height : undefined, {\n fit,\n })\n .webp({ quality: quality > 0 ? quality : 80, force: true })\n .toBuffer();\n\n res.headers.delete(\"Content-Type\");\n res.headers.delete(\"Content-Length\");\n return new Response(buffer, {\n headers: {\n \"Content-Type\": \"image/webp\",\n \"Content-Length\": `${buffer.byteLength}`,\n ...res.headers.toJSON(),\n },\n });\n}\n",
8
+ "export function renderErrorPage(err: any) {\n return `\n<!DOCTYPE html>\n<html lang=\"en\">\n <head>\n <meta charset=\"UTF-8\" />\n <meta\n name=\"viewport\"\n content=\"width=device-width, initial-scale=1.0\"\n />\n <title>Error</title>\n <style>\n body {\n font-family: Arial, sans-serif;\n padding: 20px;\n }\n h1 {\n color: red;\n }\n </style>\n </head>\n <body>\n <h1>Error</h1>\n <pre>${JSON.stringify(err, null, 2)}</pre>\n <script type=\"module\" src=\"/refresh.js\"></script>\n </body>\n</html>\n`;\n}\n",
9
+ "import { join } from \"path\";\nimport { imageHandler } from \"./imageHandler\";\nimport { generateETag } from \"./generateEtag\";\nimport { URLPattern } from \"urlpattern-polyfill\";\nimport { createStyles } from \"./styles\";\n\nconst rootDir = process.cwd();\n\nconst appDir = join(rootDir, \"app\");\nconst distDir = join(rootDir, \"dist\");\n\nexport async function startProdServer() {\n const { app } = await import(`${distDir}/server/bootstrap.mjs`);\n const manifest = await import(`${distDir}/client/.vite/manifest.json`);\n const serverManifest = await import(`${distDir}/server/.vite/manifest.json`);\n\n process.env.ROOT_DIR = rootDir;\n process.env.APP_DIR = appDir;\n process.env.DIST_DIR = distDir;\n\n async function requestHandler(req: Request) {\n const { pathname } = new URL(req.url);\n\n if (pathname.startsWith(\"/__gemi/image\")) {\n return await imageHandler(req);\n }\n\n const pattern = new URLPattern({\n pathname: \"/*.:filetype(png|txt|js|css|jpg|svg|jpeg|ico|ttf)\",\n });\n\n const isApi = pathname.startsWith(\"/api\");\n\n if (pattern.test({ pathname }) && !isApi) {\n const url = new URL(req.url);\n const filePath = req.url.replace(url.origin, \"\").split(\"?\")[0];\n const file = Bun.file(\n `dist/client${filePath.replace(\"/assets/assets\", \"/assets\")}`,\n );\n if (!file) {\n return new Response(\"Not found\", { status: 404 });\n }\n const etag = generateETag(file.lastModified);\n return new Response(file.stream(), {\n headers: {\n \"Content-Type\": file.type,\n \"Cache-Control\": \"public, max-age=31536000, must-revalidate\",\n \"Content-Length\": String(file.size),\n ETag: etag,\n },\n });\n }\n\n const styles = [];\n const cssFile = Bun.file(\n `${distDir}/client/${manifest[\"app/client.tsx\"].css}`,\n );\n const cssContent = await cssFile.text();\n styles.push({\n content: cssContent,\n });\n\n const viewImportMap = {};\n const template = (viewName: string, path: string) =>\n `\"${viewName}\": () => import(\"${path}\")`;\n const templates = [];\n\n for (const fileName of [\"404\", ...app.getFlatComponentTree.call(app)]) {\n const serverFile = serverManifest[`app/views/${fileName}.tsx`];\n if (!serverFile?.file) {\n console.log(`Server file not found for ${fileName}`);\n console.log(serverFile);\n const files = Object.keys(serverManifest);\n const path = `app/views/${fileName}.tsx`;\n console.log(`${path} not found in server manifest`);\n console.log(files);\n }\n const mod = await import(\n `${process.env.DIST_DIR}/server/${serverFile?.file}`\n );\n viewImportMap[fileName] = mod.default;\n const clientFile = manifest[`app/views/${fileName}.tsx`];\n if (clientFile) {\n templates.push(template(fileName, `/${clientFile?.file}`));\n }\n }\n\n const loaders = `{${templates.join(\",\")}}`;\n\n const handler = app.fetch.bind(app);\n\n try {\n const result = await handler(req);\n if (result instanceof Response) {\n return result;\n } else {\n return await result({\n styles: createStyles(styles),\n bootstrapModules: [`/${manifest[\"app/client.tsx\"].file}`],\n loaders,\n viewImportMap,\n });\n }\n } catch (err) {\n console.error(err);\n if (pathname.startsWith(\"/api\")) {\n return new Response(JSON.stringify({ error: err.message }), {\n status: 500,\n headers: { \"Content-Type\": \"application/json\" },\n });\n }\n return new Response(err.stack, { status: 500 });\n }\n }\n\n const server = Bun.serve({\n fetch: async (req, server) => {\n if (!req.headers.get(\"x-forwarded-for\")) {\n const ip = server.requestIP(req);\n req.headers.set(\"x-forwarded-for\", ip.address);\n }\n return await requestHandler(req);\n },\n port: process.env.PORT || 5173,\n });\n\n console.log(\"Production server running on\", server.url.href);\n\n return server;\n}\n",
10
+ "export function generateETag(lastModified: number): string {\n // Assuming the last modified timestamp is in milliseconds\n const lastModifiedStr = lastModified.toString();\n\n const hasher = new Bun.CryptoHasher(\"sha1\");\n hasher.update(lastModifiedStr);\n const hash = hasher.digest(\"hex\");\n\n return hash;\n}\n",
11
+ "import { type App } from \"../app/App\";\nimport path from \"path\";\n\ninterface Params {\n app: App;\n RootLayout: () => JSX.Element;\n}\n\nexport async function createDevServer(params: Params) {\n const { app, RootLayout } = params;\n const rootDir = process.cwd();\n\n const appDir = path.join(rootDir, \"app\");\n const root = process.cwd();\n\n const vite = await (\n await import(\"vite\")\n ).createServer({\n root,\n logLevel: \"error\",\n server: {\n watch: {\n usePolling: true,\n interval: 100,\n // ignored: (str) => str.includes(\"app/http\"),\n },\n hmr: {\n clientPort: 5174,\n },\n },\n appType: \"custom\",\n resolve: {\n alias: {\n \"@/app\": appDir,\n },\n },\n });\n process.env.ROOT_DIR = rootDir;\n process.env.APP_DIR = appDir;\n\n async function requestHandler(req: Request) {\n const { pathname } = new URL(req.url);\n\n if (pathname.startsWith(\"/refresh.js\")) {\n return new Response(\n `\n import RefreshRuntime from \"http://localhost:5173/@react-refresh\";\n RefreshRuntime.injectIntoGlobalHook(window);\n window.$RefreshReg$ = () => {};\n window.$RefreshSig$ = () => (type) => type;\n window.__vite_plugin_react_preamble_installed__ = true;\n `,\n {\n headers: {\n \"Content-Type\": \"application/javascript\",\n },\n },\n );\n }\n\n try {\n const res = await fetch(`http://localhost:5174${pathname}`);\n\n if (res.ok) {\n return res;\n }\n } catch (err) {\n console.log(err);\n }\n\n const handler = app.fetch.bind(app);\n\n return await handler(req, {\n RootLayout,\n options: {\n bootstrapModules: [\n \"/refresh.js\",\n \"/app/client.tsx\",\n \"http://localhost:5173/@vite/client\",\n ],\n },\n });\n }\n\n vite.watcher.on(\"change\", async (file) => {\n if (file.includes(\"app/views\")) {\n return;\n }\n\n console.log(`[vite] ${file} changed. Updating...`);\n\n const mod = await vite.moduleGraph.getModuleByUrl(`/${file}`);\n if (mod) {\n console.log(`[vite] ${file} changed. Updating...`);\n // await vite.reloadModule(mod);\n }\n });\n\n await vite.listen(5174);\n\n const server = Bun.serve({\n fetch: async (req) => {\n return await requestHandler(req);\n },\n port: process.env.PORT || 5173,\n });\n\n return server;\n}\n",
12
+ "import { type App } from \"../app/App\";\nimport { createDevServer } from \"./createDevServer\";\n\ninterface Params {\n app: App;\n RootLayout: () => JSX.Element;\n}\n\nexport async function createServer(params: Params) {\n if (process.env.NODE_ENV === \"development\") {\n await createDevServer(params);\n }\n}\n"
13
+ ],
14
+ "mappings": "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",
15
+ "debugId": "464EA53A369E5B1164756e2164756e21",
16
+ "names": []
17
+ }