arcanajs 3.0.1 → 4.0.0

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 (50) hide show
  1. package/dist/arcanajs.js +2 -1
  2. package/dist/arcanajs.js.LICENSE.txt +14 -0
  3. package/dist/arcanajs.js.map +1 -1
  4. package/dist/arcanox.js +2 -0
  5. package/dist/arcanox.js.map +1 -0
  6. package/dist/cli/commands/db.d.ts +1 -0
  7. package/dist/cli/commands/make.d.ts +1 -0
  8. package/dist/cli/commands/migrate.d.ts +1 -0
  9. package/dist/cli/index.d.ts +1 -0
  10. package/dist/cli/index.js +1 -1
  11. package/dist/cli/index.js.map +1 -1
  12. package/dist/lib/arcanox/Model.d.ts +203 -0
  13. package/dist/lib/arcanox/QueryBuilder.d.ts +141 -0
  14. package/dist/lib/arcanox/adapters/MongoAdapter.d.ts +22 -0
  15. package/dist/lib/arcanox/adapters/MySQLAdapter.d.ts +27 -0
  16. package/dist/lib/arcanox/adapters/PostgresAdapter.d.ts +27 -0
  17. package/dist/lib/arcanox/extensions/MongoExtensions.d.ts +33 -0
  18. package/dist/lib/arcanox/factory/Factory.d.ts +26 -0
  19. package/dist/lib/arcanox/factory/index.d.ts +1 -0
  20. package/dist/lib/arcanox/index.d.ts +13 -0
  21. package/dist/lib/arcanox/providers/DatabaseProvider.d.ts +5 -0
  22. package/dist/lib/arcanox/relations/BelongsTo.d.ts +11 -0
  23. package/dist/lib/arcanox/relations/BelongsToMany.d.ts +15 -0
  24. package/dist/lib/arcanox/relations/HasMany.d.ts +11 -0
  25. package/dist/lib/arcanox/relations/HasOne.d.ts +11 -0
  26. package/dist/lib/arcanox/relations/Relation.d.ts +14 -0
  27. package/dist/lib/arcanox/schema/Blueprint.d.ts +183 -0
  28. package/dist/lib/arcanox/schema/Migration.d.ts +76 -0
  29. package/dist/lib/arcanox/schema/Schema.d.ts +49 -0
  30. package/dist/lib/arcanox/schema/index.d.ts +4 -0
  31. package/dist/lib/arcanox/seeder/Seeder.d.ts +13 -0
  32. package/dist/lib/arcanox/seeder/index.d.ts +1 -0
  33. package/dist/lib/arcanox/support/Macroable.d.ts +19 -0
  34. package/dist/lib/arcanox/types.d.ts +76 -0
  35. package/dist/lib/index.arcanox.d.ts +6 -0
  36. package/dist/lib/{index.d.ts → index.server.d.ts} +7 -11
  37. package/dist/lib/server/ArcanaJSServer.d.ts +35 -9
  38. package/dist/lib/server/Container.d.ts +31 -0
  39. package/dist/lib/server/MiddlewareBinder.d.ts +4 -0
  40. package/dist/lib/server/ResponseHandlerMiddleware.d.ts +0 -25
  41. package/dist/lib/server/Router.d.ts +12 -3
  42. package/dist/lib/server/http/FormRequest.d.ts +10 -0
  43. package/dist/lib/server/http/JsonResource.d.ts +13 -0
  44. package/dist/lib/server/http/Middleware.d.ts +4 -0
  45. package/dist/lib/server/support/ServiceProvider.d.ts +13 -0
  46. package/dist/lib/server/utils/dynamicRequire.d.ts +6 -0
  47. package/dist/lib/server/validation/ValidationException.d.ts +5 -0
  48. package/dist/lib/server/validation/Validator.d.ts +12 -0
  49. package/package.json +26 -14
  50. package/dist/lib/global.d.ts +0 -61
package/dist/arcanajs.js CHANGED
@@ -1,2 +1,3 @@
1
- (()=>{"use strict";var __webpack_modules__={3:(e,t,r)=>{r.d(t,{g:()=>a});const a=(0,r(100).$)("HeadContext",null)},15:e=>{e.exports=require("react")},38:(e,t,r)=>{r.d(t,{p:()=>a});const a=e=>(t,r,a)=>{let n=t.path.substring(1);if(""===n&&(n="index"),e[n])return r.renderPage(n,{});for(const t of Object.keys(e)){if(!t.includes("["))continue;const e=t.split("/"),a=n.split("/");if(e.length!==a.length)continue;let o=!0;const s={};for(let t=0;t<e.length;t++){const r=e[t],n=a[t];if(r.startsWith("[")&&r.endsWith("]"))s[r.slice(1,-1)]=n;else if(r!==n){o=!1;break}}if(o)return r.renderPage(t,{},s)}a()}},47:(e,t,r)=>{r.d(t,{C:()=>u}),r(252);var a=r(896),n=r.n(a),o=r(15),s=r.n(o);const c=require("react-dom/server");var i=r(3),l=r(178);const _='<!DOCTYPE html>\n<html lang="en">\n <head>\n <meta charset="UTF-8" />\n <meta name="viewport" content="width=device-width, initial-scale=1.0" />\n \x3c!--HEAD_CONTENT--\x3e\n </head>\n <body>\n <div id="root">\x3c!--APP_CONTENT--\x3e</div>\n \x3c!--ARCANAJS_DATA_SCRIPT--\x3e\n </body>\n</html>',u=e=>{const{views:t,indexFile:r,layout:a}=e;let o=null;return(e,u,d)=>{u.renderPage=(d,p={},h={})=>{const m=u.locals.csrfToken;if(e.get("X-ArcanaJS-Request")||"json"===e.query.format)return u.json({page:d,data:p,params:h,csrfToken:m});try{const f=[],E={tags:f,push:e=>f.push(e)},w=(0,c.renderToString)(s().createElement(i.g.Provider,{value:E},s().createElement(l.l,{initialPage:d,initialData:p,initialParams:h,initialUrl:e.path,csrfToken:m,views:t,layout:a}))),g=(0,c.renderToString)(s().createElement(s().Fragment,null,...f));(e=>{if("production"===process.env.NODE_ENV&&o)return e(null,o);r&&n().existsSync(r)?n().readFile(r,"utf8",(t,r)=>{t||"production"!==process.env.NODE_ENV||(o=r),e(t,r)}):("production"===process.env.NODE_ENV&&(o=_),e(null,_))})((e,t)=>{if(e)return console.error("Error reading index.html",e),u.status(500).send("Server Error");var r;const a=`<script id="__ARCANAJS_DATA__" type="application/json">${r={page:d,data:p,params:h,csrfToken:m},JSON.stringify(r).replace(/</g,"\\u003c")}<\/script>`,n=process.env.ARCANA_HMR_PORT?`\n <script>\n (function() {\n const socket = new WebSocket("ws://localhost:${process.env.ARCANA_HMR_PORT}");\n socket.onmessage = function(event) {\n const data = JSON.parse(event.data);\n if (data.type === "reload") {\n window.location.reload();\n }\n };\n })();\n <\/script>`:"",o=t.replace("\x3c!--HEAD_CONTENT--\x3e",g).replace("\x3c!--APP_CONTENT--\x3e",w).replace("\x3c!--ARCANAJS_DATA_SCRIPT--\x3e",a+n);u.send(o)})}catch(e){return console.error("SSR Error:",e),u.status(500).send("Internal Server Error")}return u},d()}}},100:(e,t,r)=>{r.d(t,{$:()=>n});var a=r(15);function n(e,t){const r=global,n=Symbol.for(`ARCANAJS_CONTEXT_${e}`);return r[n]||(r[n]=(0,a.createContext)(t)),r[n]}},174:e=>{e.exports=require("compression")},178:(e,t,r)=>{r.d(t,{l:()=>c});var a=r(15),n=r.n(a),o=r(226),s=r(680);const c=e=>{const{initialPage:t,initialData:r,initialParams:c={},initialUrl:i,csrfToken:l,views:_,layout:u,onNavigate:d,cacheLimit:p=50}=e,[h,m]=(0,a.useState)(t),[f,E]=(0,a.useState)(r),[w,g]=(0,a.useState)(c),[v,x]=(0,a.useState)(i||("undefined"!=typeof window?window.location.pathname:"/")),[b,y]=(0,a.useState)(!1),P=n().useRef(new Map),R=n().useRef(null);(0,a.useEffect)(()=>{"undefined"==typeof window||window.history.state||window.history.replaceState({page:t,data:r,params:c},"",window.location.href);const e=e=>{if(e.state)m(e.state.page),E(e.state.data),g(e.state.params||{}),x(window.location.pathname);else{const e=window.location.pathname;k(e).catch(()=>{window.location.reload()})}};return window.addEventListener("popstate",e),()=>{var t;window.removeEventListener("popstate",e),null===(t=R.current)||void 0===t||t.abort()}},[]);const k=async e=>{var t;const r=P.current;if(r.has(e)){const t=r.get(e);if(m(t.page),E(t.data),g(t.params||{}),x(e),window.history.pushState(t,"",e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}return void(d&&d(e))}y(!0),null===(t=R.current)||void 0===t||t.abort();const a=new AbortController;R.current=a;try{const t=await fetch(e,{headers:{"X-ArcanaJS-Request":"true"},cache:"no-store",signal:a.signal});if(!t.ok){if(404===t.status)return m("NotFoundPage"),x(e),void window.history.pushState({page:"NotFoundPage",data:{}},"",e);throw new Error(`Navigation failed: ${t.status} ${t.statusText}`)}if(!(t.headers.get("content-type")||"").includes("application/json"))return void(window.location.href=e);const r=await t.json(),n={page:r.page,data:r.data,params:r.params||{}};if(((e,t)=>{const r=P.current;if(r.has(e)&&r.delete(e),r.set(e,t),r.size>p){const e=r.keys().next().value;void 0!==e&&r.delete(e)}})(e,n),window.history.pushState({page:n.page,data:n.data,params:n.params},"",e),m(n.page),E(n.data),g(n.params||{}),x(e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}d&&d(e)}catch(e){if("AbortError"===(null==e?void 0:e.name))return;throw console.error("Navigation failed",e),e}finally{R.current===a&&(R.current=null),y(!1)}},A=(()=>{const e=_[h]||_.NotFoundPage||(()=>n().createElement("div",null,"404 Not Found"));return n().createElement(o.A,{data:f},n().createElement(e,{data:f,navigateTo:k,params:w}))})();return n().createElement(s.p,{value:{navigateTo:(...e)=>{k(e[0])},navigateToAsync:k,currentPage:h,currentUrl:v,params:w,csrfToken:l,onNavigate:d,isNavigating:b}},u?n().createElement(u,null,A):n().createElement(n().Fragment,null,A))}},226:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(15),n=r.n(a),o=r(854),s=r(509);const c=({data:e,title:t,children:r})=>n().createElement(o.N.Provider,{value:e},t&&n().createElement(s.A,null,n().createElement("title",null,t)),r)},252:e=>{e.exports=require("express")},287:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(507),n=r(509),o=r(703),s=r(226);function c({url:e}){return React.createElement(s.A,null,React.createElement(n.A,null,React.createElement("title",null,"404 - Page Not Found"),React.createElement("meta",{name:"description",content:"The page you're looking for doesn't exist"})),React.createElement(a.A,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 left-1/4 w-96 h-96 bg-orange-500 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 right-1/4 w-96 h-96 bg-purple-500 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-lg w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("h1",{className:"text-9xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-white to-gray-500 mb-4 animate-float"},"404"),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Page Not Found"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e?React.createElement(React.Fragment,null,"The page ",React.createElement("span",{className:"text-orange-400"},'"',e,'"')," ","you're looking for doesn't exist."):"The page you're looking for doesn't exist.")),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center"},React.createElement(o.A,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.history.back(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 19l-7-7m0 0l7-7m-7 7h18"})),"Go Back"))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If you believe this is an error, please"," ",React.createElement(o.A,{href:"/contact",className:"text-orange-400 hover:text-orange-300 underline transition-colors"},"contact support"),".")))))}},322:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{__webpack_require__.d(__webpack_exports__,{A:()=>__WEBPACK_DEFAULT_EXPORT__});var compression__WEBPACK_IMPORTED_MODULE_0__=__webpack_require__(174),compression__WEBPACK_IMPORTED_MODULE_0___default=__webpack_require__.n(compression__WEBPACK_IMPORTED_MODULE_0__),cookie_parser__WEBPACK_IMPORTED_MODULE_1__=__webpack_require__(898),cookie_parser__WEBPACK_IMPORTED_MODULE_1___default=__webpack_require__.n(cookie_parser__WEBPACK_IMPORTED_MODULE_1__),express__WEBPACK_IMPORTED_MODULE_2__=__webpack_require__(252),express__WEBPACK_IMPORTED_MODULE_2___default=__webpack_require__.n(express__WEBPACK_IMPORTED_MODULE_2__),fs__WEBPACK_IMPORTED_MODULE_3__=__webpack_require__(896),fs__WEBPACK_IMPORTED_MODULE_3___default=__webpack_require__.n(fs__WEBPACK_IMPORTED_MODULE_3__),helmet__WEBPACK_IMPORTED_MODULE_4__=__webpack_require__(525),helmet__WEBPACK_IMPORTED_MODULE_4___default=__webpack_require__.n(helmet__WEBPACK_IMPORTED_MODULE_4__),path__WEBPACK_IMPORTED_MODULE_5__=__webpack_require__(928),path__WEBPACK_IMPORTED_MODULE_5___default=__webpack_require__.n(path__WEBPACK_IMPORTED_MODULE_5__),_shared_views_ErrorPage__WEBPACK_IMPORTED_MODULE_6__=__webpack_require__(944),_shared_views_NotFoundPage__WEBPACK_IMPORTED_MODULE_7__=__webpack_require__(287),_ArcanaJSMiddleware__WEBPACK_IMPORTED_MODULE_8__=__webpack_require__(47),_CsrfMiddleware__WEBPACK_IMPORTED_MODULE_9__=__webpack_require__(570),_DynamicRouter__WEBPACK_IMPORTED_MODULE_10__=__webpack_require__(38),_ResponseHandlerMiddleware__WEBPACK_IMPORTED_MODULE_11__=__webpack_require__(615);class ArcanaJSServer{constructor(e){this.config=e,this.app=express__WEBPACK_IMPORTED_MODULE_2___default()(),this.initialize()}normalizeDb(e){if(!e)return e;if("function"==typeof e.close)return e;if("function"==typeof e.disconnect)return{client:e,close:async()=>{await e.disconnect()}};if(e.client&&e.db){const t=e.client;return{client:t,db:e.db,close:async()=>{if(t&&"function"==typeof t.close)await t.close();else{if(!t||"function"!=typeof t.disconnect)throw new Error("No close method on client");await t.disconnect()}}}}return e&&"function"==typeof e.close&&e.connect?{client:e,close:async()=>{await e.close()}}:"function"==typeof e.end||"function"==typeof e.query?{client:e,close:async()=>{if("function"==typeof e.end)await e.end();else{if("function"!=typeof e.close)throw new Error("No close/end method on SQL client");await e.close()}}}:e.s&&e.s.client&&"function"==typeof e.s.client.close?{client:e.s.client,db:e,close:async()=>{await e.s.client.close()}}:{client:e,close:async()=>{throw new Error("No known close method on DB client")}}}initialize(){const{staticDir:e="public",distDir:t="dist/public",indexFile:r="dist/public/index.html",views:a,viewsContext:n,routes:o,layout:s,apiRoutes:c,apiBase:i="/api"}=this.config,l=process.cwd();let _=a;!_&&n&&(_=this.loadViewsFromContext(n)),_||(_=this.loadViewsFromAlias()),_||(_=this.discoverViews()),_&&0!==Object.keys(_).length||(console.warn("No views found. Please check your views directory."),_={}),_.NotFoundPage=_.NotFoundPage||_shared_views_NotFoundPage__WEBPACK_IMPORTED_MODULE_7__.A,_.ErrorPage=_.ErrorPage||_shared_views_ErrorPage__WEBPACK_IMPORTED_MODULE_6__.A,this.app.use(helmet__WEBPACK_IMPORTED_MODULE_4___default()({contentSecurityPolicy:!1})),this.app.use(cookie_parser__WEBPACK_IMPORTED_MODULE_1___default()()),this.app.use((0,_CsrfMiddleware__WEBPACK_IMPORTED_MODULE_9__.V)()),this.app.use(_ResponseHandlerMiddleware__WEBPACK_IMPORTED_MODULE_11__.s),this.app.use((e,t,r)=>{e.db=this.app.locals.db,r()});const u={index:!1,maxAge:"production"===process.env.NODE_ENV?"1y":"0"},d=[path__WEBPACK_IMPORTED_MODULE_5___default().resolve(l,t),path__WEBPACK_IMPORTED_MODULE_5___default().resolve(l,e)].filter((e,t,r)=>r.indexOf(e)===t);for(const e of d)this.app.use(express__WEBPACK_IMPORTED_MODULE_2___default().static(e,u));if(this.app.use(compression__WEBPACK_IMPORTED_MODULE_0___default()()),this.app.use((0,_ArcanaJSMiddleware__WEBPACK_IMPORTED_MODULE_8__.C)({views:_,indexFile:path__WEBPACK_IMPORTED_MODULE_5___default().resolve(l,r),layout:s})),this.config.dbConnect)try{const e=this.config.dbConnect(),t=e=>{try{this.app.locals.db=this.normalizeDb(e)||e,console.log("Database connection attached to app.locals.db")}catch(t){this.app.locals.db=e,console.warn("DB connection attached without full normalization",t)}};e&&e.then&&"function"==typeof e.then?e.then(t).catch(e=>console.error("Error establishing DB connection:",e)):t(e)}catch(e){console.error("Error calling dbConnect:",e)}const p=(e,t)=>{if(!e)return;const r=Array.isArray(e)?e:[e];for(const e of r)e&&("function"==typeof e.getRouter?this.app.use(t||"/",e.getRouter()):this.app.use(t||"/",e))};try{p(c,i),c&&console.log(`API routes mounted at ${i}`)}catch(e){console.error("Error mounting apiRoutes:",e)}try{p(o)}catch(e){console.error("Error mounting routes:",e)}this.app.use((0,_DynamicRouter__WEBPACK_IMPORTED_MODULE_10__.p)(_)),this.app.use((e,t)=>{e.get("X-ArcanaJS-Request")||"json"===e.query.format?t.status(404).json({page:"NotFoundPage",data:{},params:{},csrfToken:t.locals.csrfToken}):t.status(404).renderPage("NotFoundPage")}),this.app.use((e,t,r,a)=>{console.error(e);const n="production"===process.env.NODE_ENV?"Internal Server Error":e.message;t.get("X-ArcanaJS-Request")||"json"===t.query.format?r.status(500).json({page:"ErrorPage",data:{message:n},params:{},csrfToken:r.locals.csrfToken}):r.status(500).renderPage("ErrorPage",{message:n})})}loadViewsFromContext(e){const t={};return e.keys().forEach(r=>{const a=r.replace(/^\.\/(.*)\.tsx$/,"$1");t[a]=e(r).default}),t}loadViewsFromAlias(){try{const e=__webpack_require__(369);if(e)return this.loadViewsFromContext(e)}catch(e){}}discoverViews(){const views={},viewsDir=this.config.viewsDir?path__WEBPACK_IMPORTED_MODULE_5___default().resolve(process.cwd(),this.config.viewsDir):path__WEBPACK_IMPORTED_MODULE_5___default().resolve(process.cwd(),"src/views");if(!fs__WEBPACK_IMPORTED_MODULE_3___default().existsSync(viewsDir))return views;const traverse=dir=>{const files=fs__WEBPACK_IMPORTED_MODULE_3___default().readdirSync(dir);files.forEach(file=>{const fullPath=path__WEBPACK_IMPORTED_MODULE_5___default().join(dir,file),stat=fs__WEBPACK_IMPORTED_MODULE_3___default().statSync(fullPath);if(stat.isDirectory())traverse(fullPath);else if(file.endsWith(".tsx")||file.endsWith(".jsx")){const relativePath=path__WEBPACK_IMPORTED_MODULE_5___default().relative(viewsDir,fullPath),viewName=relativePath.replace(/\.(tsx|jsx)$/,"");try{const requireFunc="undefined"!=typeof require?require:eval("require");if(file.endsWith(".tsx")||file.endsWith(".ts"))try{requireFunc("ts-node/register")}catch(e){}const pageModule=requireFunc(fullPath);views[viewName]=pageModule.default||pageModule}catch(e){console.error(`Failed to load view ${viewName}:`,e)}}})};return traverse(viewsDir),views}start(){const e=this.config.port||process.env.PORT||3e3;if(this.serverInstance=this.app.listen(e,()=>{console.log(`Server is running on http://localhost:${e}`)}),!1!==this.config.autoHandleSignals){const e=async()=>{try{await this.stop(),process.exit(0)}catch(e){console.error("Error during shutdown:",e),process.exit(1)}};this._sigintHandler=e,this._sigtermHandler=e,process.on("SIGINT",this._sigintHandler),process.on("SIGTERM",this._sigtermHandler)}}async stop(){this.serverInstance&&(await new Promise((e,t)=>{this.serverInstance.close(r=>{if(r)return t(r);e()})}),this.serverInstance=void 0,console.log("HTTP server stopped"));const e=this.app.locals.db;if(e){let t=!1;try{"function"==typeof e.disconnect&&(await e.disconnect(),t=!0,console.log("Database connection closed via disconnect()."))}catch(e){console.error("Error calling disconnect() on DB client:",e)}if(!t)try{"function"==typeof e.close&&(await e.close(),t=!0,console.log("Database connection closed via close()."))}catch(e){console.error("Error calling close() on DB client:",e)}if(!t)try{"function"==typeof e.end&&(await e.end(),t=!0,console.log("Database connection closed via end()."))}catch(e){console.error("Error calling end() on DB client:",e)}if(!t)try{const r=e.client&&e.client.close;r&&"function"==typeof r&&(await e.client.close(),t=!0,console.log("Database connection closed via db.client.close()."))}catch(e){console.error("Error calling db.client.close() on DB client:",e)}if(!t)try{const r=e.s&&e.s.client&&e.s.client.close;r&&"function"==typeof r&&(await e.s.client.close(),t=!0,console.log("Database connection closed via db.s.client.close()."))}catch(e){console.error("Error calling db.s.client.close() on DB client:",e)}t||console.warn("Could not find a supported close method on the DB client; connection may remain open.")}try{this._sigintHandler&&(process.removeListener("SIGINT",this._sigintHandler),this._sigintHandler=void 0),this._sigtermHandler&&(process.removeListener("SIGTERM",this._sigtermHandler),this._sigtermHandler=void 0)}catch(e){}}}const __WEBPACK_DEFAULT_EXPORT__=ArcanaJSServer},369:e=>{e.exports=require("arcana-views")},507:(e,t,r)=>{r.d(t,{A:()=>o});var a=r(15),n=r.n(a);const o=({children:e})=>n().createElement(n().Fragment,null,e)},509:(e,t,r)=>{r.d(t,{A:()=>s});var a=r(15),n=r.n(a),o=r(554);const s=({children:e})=>{const t=(0,o.o)();return"undefined"==typeof window&&t&&n().Children.forEach(e,e=>{n().isValidElement(e)&&t.push(n().cloneElement(e,{"data-arcanajs-head":"true"}))}),(0,a.useEffect)(()=>{const t=[];return n().Children.forEach(e,e=>{if(n().isValidElement(e)){const r=e;if("title"===r.type)document.title=r.props.children;else if("meta"===r.type){const e=r.props;let a="meta";if(e.name&&(a+=`[name="${e.name}"]`),e.property&&(a+=`[property="${e.property}"]`),e.name||e.property){let r=document.querySelector(a+'[data-arcanajs-head="true"]')||document.querySelector(a);if(r)r.setAttribute("content",e.content),r.setAttribute("data-arcanajs-head","true"),t.push(r);else{const r=document.createElement("meta");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}else if("link"===r.type){const e=r.props;let a="link";e.rel&&(a+=`[rel="${e.rel}"]`),e.href&&(a+=`[href="${e.href}"]`);let n=document.querySelector(a+'[data-arcanajs-head="true"]')||document.querySelector(a);if(n)n.setAttribute("data-arcanajs-head","true"),t.push(n);else{const r=document.createElement("link");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}}),()=>{t.forEach(e=>{e.remove()})}},[e]),null}},525:e=>{e.exports=require("helmet")},554:(e,t,r)=>{r.d(t,{o:()=>o});var a=r(15),n=r(3);const o=()=>(0,a.useContext)(n.g)},570:(e,t,r)=>{r.d(t,{V:()=>s});const a=require("crypto");var n=r.n(a);const o="_csrf",s=()=>(e,t,r)=>{let a=e.cookies[o];a||(a=n().randomBytes(32).toString("hex"),t.cookie(o,a,{httpOnly:!0,secure:"production"===process.env.NODE_ENV,sameSite:"strict"})),t.locals.csrfToken=a;const s=e.method.toUpperCase();if(["POST","PUT","DELETE","PATCH"].includes(s)){const r=e.headers["x-csrf-token"];if(!r||r!==a)return t.status(403).json({error:"Invalid CSRF Token"})}r()}},615:(e,t,r)=>{r.d(t,{s:()=>a});const a=(e,t,r)=>{t.success=(e={},r="Success",a=200)=>t.status(a).json({success:!0,message:r,data:e,error:null}),t.error=(e="Error",r=500,a=null,n=null)=>{const o=a?"object"==typeof a&&null!==a?a instanceof Error?a.toString():a:a.toString():null;return t.status(r).json({success:!1,message:e,data:n,error:o})},r()}},680:(e,t,r)=>{r.d(t,{p:()=>s,z:()=>o});var a=r(15),n=r.n(a);const o=(0,r(100).$)("RouterContext",null),s=({value:e,children:t})=>n().createElement(o.Provider,{value:e},t)},703:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(15),n=r.n(a),o=r(981);function s(){return s=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var a in r)({}).hasOwnProperty.call(r,a)&&(e[a]=r[a])}return e},s.apply(null,arguments)}const c=({href:e,children:t,prefetch:r=!1,...a})=>{const{navigateTo:c,navigateToAsync:i}=(0,o.A)(),l=/^https?:\/\//.test(e);return n().createElement("a",s({href:e,onClick:async t=>{t.preventDefault(),l?window.open(e,"_blank","noopener,noreferrer"):i?await i(e):c(e)},onMouseEnter:()=>{r&&!l&&fetch(e,{method:"HEAD"}).catch(()=>{})},target:l?"_blank":void 0,rel:l?"noopener noreferrer":void 0},a),t)}},854:(e,t,r)=>{r.d(t,{N:()=>a});const a=(0,r(100).$)("PageContext",null)},896:e=>{e.exports=require("fs")},898:e=>{e.exports=require("cookie-parser")},928:e=>{e.exports=require("path")},944:(e,t,r)=>{r.d(t,{A:()=>c});var a=r(507),n=r(509),o=r(703),s=r(226);function c({message:e="Something went wrong",statusCode:t=500,stack:r}){const c="development"===process.env.NODE_ENV;return React.createElement(s.A,null,React.createElement(n.A,null,React.createElement("title",null,t," - Server Error"),React.createElement("meta",{name:"description",content:"An error occurred on the server"})),React.createElement(a.A,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 right-1/4 w-96 h-96 bg-red-600 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 left-1/4 w-96 h-96 bg-orange-600 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-2xl w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("div",{className:"text-6xl mb-6 animate-float"},React.createElement("span",{className:"text-red-500 drop-shadow-lg filter"},"⚠️")),React.createElement("h1",{className:"text-8xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-red-500 to-orange-500 mb-4"},t),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Server Error"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e)),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center mb-8"},React.createElement(o.A,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto bg-gradient-to-r from-red-600 to-orange-600 hover:from-red-500 hover:to-orange-500 border-none shadow-red-900/20"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.location.reload(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})),"Try Again")),c&&r&&React.createElement("div",{className:"mt-8 text-left animate-slide-up"},React.createElement("details",{className:"bg-black/40 border border-white/10 rounded-xl overflow-hidden group"},React.createElement("summary",{className:"cursor-pointer font-medium text-gray-300 p-4 hover:bg-white/5 transition-colors flex items-center justify-between select-none"},React.createElement("span",null,"Stack Trace (Development Only)"),React.createElement("svg",{className:"w-5 h-5 text-gray-500 group-open:rotate-180 transition-transform",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"}))),React.createElement("pre",{className:"text-xs text-red-300/80 p-4 overflow-x-auto whitespace-pre-wrap font-mono border-t border-white/5 bg-black/20"},r)))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If this problem persists, please"," ",React.createElement(o.A,{href:"/contact",className:"text-red-400 hover:text-red-300 underline transition-colors"},"contact support"),".")))))}},981:(e,t,r)=>{r.d(t,{A:()=>o});var a=r(15),n=r(680);const o=()=>{const e=(0,a.useContext)(n.z);if(!e)throw new Error("useRouter must be used within an ArcanaJSApp");return e}}},__webpack_module_cache__={};function __webpack_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var r=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.exports}__webpack_require__.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return __webpack_require__.d(t,{a:t}),t},__webpack_require__.d=(e,t)=>{for(var r in t)__webpack_require__.o(t,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},__webpack_require__.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var __webpack_exports__={};__webpack_require__.r(__webpack_exports__),__webpack_require__.d(__webpack_exports__,{ArcanaJSServer:()=>ArcanaJSServer.A,Body:()=>Body.A,Express:()=>external_express_.Express,Head:()=>Head.A,Link:()=>Link.A,NavLink:()=>components_NavLink,NextFunction:()=>external_express_.NextFunction,Page:()=>Page.A,Request:()=>external_express_.Request,Response:()=>external_express_.Response,Route:()=>server_Router,createArcanaServer:()=>createArcanaServer,hydrateArcanaJS:()=>client,useLocation:()=>hooks_useLocation,usePage:()=>hooks_usePage,useParams:()=>hooks_useParams,useQuery:()=>hooks_useQuery,useRouter:()=>useRouter.A});var ArcanaJSServer=__webpack_require__(322),Body=__webpack_require__(507),Head=__webpack_require__(509),Link=__webpack_require__(703),external_react_=__webpack_require__(15),external_react_default=__webpack_require__.n(external_react_),useRouter=__webpack_require__(981);function _extends(){return _extends=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var a in r)({}).hasOwnProperty.call(r,a)&&(e[a]=r[a])}return e},_extends.apply(null,arguments)}const NavLink=({href:e,activeClassName:t="active",className:r="",exact:a=!1,prefetch:n=!1,children:o,...s})=>{const{currentUrl:c}=(0,useRouter.A)(),i=`${r} ${(a?c===e:c.startsWith(e))?t:""}`.trim();return external_react_default().createElement(Link.A,_extends({href:e,className:i,prefetch:n},s),o)},components_NavLink=NavLink;var Page=__webpack_require__(226);const client_namespaceObject=require("react-dom/client");var HeadContext=__webpack_require__(3),ArcanaJSApp=__webpack_require__(178),ErrorPage=__webpack_require__(944),NotFoundPage=__webpack_require__(287);const hydrateArcanaJS=(e,t,r)=>{let a={};e.keys&&"function"==typeof e.keys?e.keys().forEach(t=>{const r=t.replace(/^\.\/(.*)\.tsx$/,"$1");a[r]=e(t).default}):a=e,a.NotFoundPage||(a.NotFoundPage=NotFoundPage.A),a.ErrorPage||(a.ErrorPage=ErrorPage.A);const n=document.getElementById("root"),o=document.getElementById("__ARCANAJS_DATA__"),s={tags:[],push:()=>{}};if(n&&o)try{const{page:e,data:c,params:i,csrfToken:l}=JSON.parse(o.textContent||"{}");(0,client_namespaceObject.hydrateRoot)(n,external_react_default().createElement(HeadContext.g.Provider,{value:s},external_react_default().createElement(ArcanaJSApp.l,{initialPage:e,initialData:c,initialParams:i,csrfToken:l,views:a,layout:t,onNavigate:(null==r?void 0:r.onNavigate)||(()=>{})})))}catch(e){console.error("Failed to parse initial data",e)}},client=hydrateArcanaJS,useLocation=()=>{const{currentUrl:e}=(0,useRouter.A)();return{pathname:e,search:"undefined"!=typeof window?window.location.search:"",hash:"undefined"!=typeof window?window.location.hash:""}},hooks_useLocation=useLocation;var PageContext=__webpack_require__(854);const usePage=()=>(0,external_react_.useContext)(PageContext.N),hooks_usePage=usePage;var RouterContext=__webpack_require__(680);const useParams=()=>{const e=(0,external_react_.useContext)(RouterContext.z);if(!e)throw new Error("useParams must be used within an ArcanaJSApp");return e.params},hooks_useParams=useParams,useQuery=()=>{const{search:e}=hooks_useLocation();return new URLSearchParams(e)},hooks_useQuery=useQuery;var external_express_=__webpack_require__(252),external_express_default=__webpack_require__.n(external_express_);class ControllerBinder{static handle(e,t){let r;try{r=new e}catch(t){console.warn(`Failed to instantiate controller ${e.name}`,t),r=e}return async(a,n,o)=>{try{if("function"!=typeof r[t])throw new Error(`Method ${t} not found on controller ${e.name}`);await r[t](a,n,o)}catch(e){o(e)}}}}class Router{constructor(){this.router=external_express_default().Router(),this.middlewareStack=[],this.prefixStack=[]}static create(){return new Router}middleware(...e){const t=this._clone();return t.middlewareStack=[...this.middlewareStack,...e],t}prefix(e){const t=this._clone();return t.prefixStack=[...this.prefixStack,e.replace(/^\/|\/$/g,"")],t}group(e){return e(this),this}get(e,...t){const r=t.pop(),a=t;return this._addRoute("get",e,r,a)}post(e,...t){const r=t.pop(),a=t;return this._addRoute("post",e,r,a)}put(e,...t){const r=t.pop(),a=t;return this._addRoute("put",e,r,a)}delete(e,...t){const r=t.pop(),a=t;return this._addRoute("delete",e,r,a)}patch(e,...t){const r=t.pop(),a=t;return this._addRoute("patch",e,r,a)}options(e,...t){const r=t.pop(),a=t;return this._addRoute("options",e,r,a)}getRouter(){return this.router}mount(e,t="/"){e.use(t,this.router)}_clone(){const e=new Router;return e.router=this.router,e.middlewareStack=[...this.middlewareStack],e.prefixStack=[...this.prefixStack],e}_addRoute(e,t,r,a=[]){const n=this._buildPath(t),o=this._buildHandler(r),s=a.flat(1/0),c=[...this.middlewareStack,...s,o];return this.router[e](n,...c),this}_buildPath(e){const t=e.replace(/^\//,""),r=this.prefixStack.filter(e=>""!==e);return 0===r.length?`/${t}`:`/${r.join("/")}/${t}`.replace(/\/+/g,"/")}_buildHandler(e){if("function"==typeof e)return e;if(Array.isArray(e)&&2===e.length){const[t,r]=e;return ControllerBinder.handle(t,r)}throw new Error('Action must be a function or array [Controller, "method"]')}}class Route{static _router=new Router;static create(){return Router.create()}static middleware(...e){return this._router.middleware(...e)}static prefix(e){return this._router.prefix(e)}static group(e){return this._router.group(e)}static get(e,...t){return this._router.get(e,...t)}static post(e,...t){return this._router.post(e,...t)}static put(e,...t){return this._router.put(e,...t)}static delete(e,...t){return this._router.delete(e,...t)}static patch(e,...t){return this._router.patch(e,...t)}static options(e,...t){return this._router.options(e,...t)}static getRouter(){return this._router.getRouter()}static mount(e,t="/"){return this._router.mount(e,t)}static reset(){this._router=new Router}}const server_Router=Route;function createArcanaServer(e,t){return new ArcanaJSServer.A({...t})}var __webpack_export_target__=exports;for(var __webpack_i__ in __webpack_exports__)__webpack_export_target__[__webpack_i__]=__webpack_exports__[__webpack_i__];__webpack_exports__.__esModule&&Object.defineProperty(__webpack_export_target__,"__esModule",{value:!0})})();
1
+ /*! For license information please see arcanajs.js.LICENSE.txt */
2
+ (()=>{var __webpack_modules__={14:(__unused_webpack_module,__webpack_exports__,__webpack_require__)=>{"use strict";__webpack_require__.d(__webpack_exports__,{dynamicRequire:()=>dynamicRequire});const dynamicRequire=id=>"undefined"!=typeof require?require(id):eval("require")(id)},369:e=>{"use strict";e.exports=require("arcana-views")},590:(e,t,r)=>{},630:()=>{var e;!function(e){!function(){var t="object"==typeof globalThis?globalThis:"object"==typeof global?global:"object"==typeof self?self:"object"==typeof this?this:function(){try{return Function("return this;")()}catch(e){}}()||function(){try{return(0,eval)("(function() { return this; })()")}catch(e){}}(),r=n(e);function n(e,t){return function(r,n){Object.defineProperty(e,r,{configurable:!0,writable:!0,value:n}),t&&t(r,n)}}void 0!==t.Reflect&&(r=n(t.Reflect,r)),function(e,t){var r=Object.prototype.hasOwnProperty,n="function"==typeof Symbol,s=n&&void 0!==Symbol.toPrimitive?Symbol.toPrimitive:"@@toPrimitive",i=n&&void 0!==Symbol.iterator?Symbol.iterator:"@@iterator",a="function"==typeof Object.create,o={__proto__:[]}instanceof Array,c=!a&&!o,u={create:a?function(){return V(Object.create(null))}:o?function(){return V({__proto__:null})}:function(){return V({})},has:c?function(e,t){return r.call(e,t)}:function(e,t){return t in e},get:c?function(e,t){return r.call(e,t)?e[t]:void 0}:function(e,t){return e[t]}},l=Object.getPrototypeOf(Function),h="function"==typeof Map&&"function"==typeof Map.prototype.entries?Map:function(){var e={},t=[],r=function(){function e(e,t,r){this._index=0,this._keys=e,this._values=t,this._selector=r}return e.prototype["@@iterator"]=function(){return this},e.prototype[i]=function(){return this},e.prototype.next=function(){var e=this._index;if(e>=0&&e<this._keys.length){var r=this._selector(this._keys[e],this._values[e]);return e+1>=this._keys.length?(this._index=-1,this._keys=t,this._values=t):this._index++,{value:r,done:!1}}return{value:void 0,done:!0}},e.prototype.throw=function(e){throw this._index>=0&&(this._index=-1,this._keys=t,this._values=t),e},e.prototype.return=function(e){return this._index>=0&&(this._index=-1,this._keys=t,this._values=t),{value:e,done:!0}},e}();return function(){function t(){this._keys=[],this._values=[],this._cacheKey=e,this._cacheIndex=-2}return Object.defineProperty(t.prototype,"size",{get:function(){return this._keys.length},enumerable:!0,configurable:!0}),t.prototype.has=function(e){return this._find(e,!1)>=0},t.prototype.get=function(e){var t=this._find(e,!1);return t>=0?this._values[t]:void 0},t.prototype.set=function(e,t){var r=this._find(e,!0);return this._values[r]=t,this},t.prototype.delete=function(t){var r=this._find(t,!1);if(r>=0){for(var n=this._keys.length,s=r+1;s<n;s++)this._keys[s-1]=this._keys[s],this._values[s-1]=this._values[s];return this._keys.length--,this._values.length--,q(t,this._cacheKey)&&(this._cacheKey=e,this._cacheIndex=-2),!0}return!1},t.prototype.clear=function(){this._keys.length=0,this._values.length=0,this._cacheKey=e,this._cacheIndex=-2},t.prototype.keys=function(){return new r(this._keys,this._values,n)},t.prototype.values=function(){return new r(this._keys,this._values,s)},t.prototype.entries=function(){return new r(this._keys,this._values,a)},t.prototype["@@iterator"]=function(){return this.entries()},t.prototype[i]=function(){return this.entries()},t.prototype._find=function(e,t){if(!q(this._cacheKey,e)){this._cacheIndex=-1;for(var r=0;r<this._keys.length;r++)if(q(this._keys[r],e)){this._cacheIndex=r;break}}return this._cacheIndex<0&&t&&(this._cacheIndex=this._keys.length,this._keys.push(e),this._values.push(void 0)),this._cacheIndex},t}();function n(e,t){return e}function s(e,t){return t}function a(e,t){return[e,t]}}(),d="function"==typeof Set&&"function"==typeof Set.prototype.entries?Set:function(){function e(){this._map=new h}return Object.defineProperty(e.prototype,"size",{get:function(){return this._map.size},enumerable:!0,configurable:!0}),e.prototype.has=function(e){return this._map.has(e)},e.prototype.add=function(e){return this._map.set(e,e),this},e.prototype.delete=function(e){return this._map.delete(e)},e.prototype.clear=function(){this._map.clear()},e.prototype.keys=function(){return this._map.keys()},e.prototype.values=function(){return this._map.keys()},e.prototype.entries=function(){return this._map.entries()},e.prototype["@@iterator"]=function(){return this.keys()},e.prototype[i]=function(){return this.keys()},e}(),p="function"==typeof WeakMap?WeakMap:function(){var e=u.create(),t=n();return function(){function e(){this._key=n()}return e.prototype.has=function(e){var t=s(e,!1);return void 0!==t&&u.has(t,this._key)},e.prototype.get=function(e){var t=s(e,!1);return void 0!==t?u.get(t,this._key):void 0},e.prototype.set=function(e,t){return s(e,!0)[this._key]=t,this},e.prototype.delete=function(e){var t=s(e,!1);return void 0!==t&&delete t[this._key]},e.prototype.clear=function(){this._key=n()},e}();function n(){var t;do{t="@@WeakMap@@"+a()}while(u.has(e,t));return e[t]=!0,t}function s(e,n){if(!r.call(e,t)){if(!n)return;Object.defineProperty(e,t,{value:u.create()})}return e[t]}function i(e,t){for(var r=0;r<t;++r)e[r]=255*Math.random()|0;return e}function a(){var e=function(e){if("function"==typeof Uint8Array){var t=new Uint8Array(e);return"undefined"!=typeof crypto?crypto.getRandomValues(t):"undefined"!=typeof msCrypto?msCrypto.getRandomValues(t):i(t,e),t}return i(new Array(e),e)}(16);e[6]=79&e[6]|64,e[8]=191&e[8]|128;for(var t="",r=0;r<16;++r){var n=e[r];4!==r&&6!==r&&8!==r||(t+="-"),n<16&&(t+="0"),t+=n.toString(16).toLowerCase()}return t}}(),f=n?Symbol.for("@reflect-metadata:registry"):void 0,m=function(){var e;return!R(f)&&N(t.Reflect)&&Object.isExtensible(t.Reflect)&&(e=t.Reflect[f]),R(e)&&(e=function(){var e,r,n,s;R(f)||void 0===t.Reflect||f in t.Reflect||"function"!=typeof t.Reflect.defineMetadata||(e=function(e){var t=e.defineMetadata,r=e.hasOwnMetadata,n=e.getOwnMetadata,s=e.getOwnMetadataKeys,i=e.deleteMetadata,a=new p;return{isProviderFor:function(e,t){var r=a.get(e);return!(R(r)||!r.has(t))||!!s(e,t).length&&(R(r)&&(r=new d,a.set(e,r)),r.add(t),!0)},OrdinaryDefineOwnMetadata:t,OrdinaryHasOwnMetadata:r,OrdinaryGetOwnMetadata:n,OrdinaryOwnMetadataKeys:s,OrdinaryDeleteMetadata:i}}(t.Reflect));var i=new p,a={registerProvider:o,getProvider:u,setProvider:m};return a;function o(t){if(!Object.isExtensible(a))throw new Error("Cannot add provider to a frozen registry.");switch(!0){case e===t:break;case R(r):r=t;break;case r===t:break;case R(n):n=t;break;case n===t:break;default:void 0===s&&(s=new d),s.add(t)}}function c(t,i){if(!R(r)){if(r.isProviderFor(t,i))return r;if(!R(n)){if(n.isProviderFor(t,i))return r;if(!R(s))for(var a=$(s);;){var o=K(a);if(!o)return;var c=M(o);if(c.isProviderFor(t,i))return I(a),c}}}if(!R(e)&&e.isProviderFor(t,i))return e}function u(e,t){var r,n=i.get(e);return R(n)||(r=n.get(t)),R(r)?(R(r=c(e,t))||(R(n)&&(n=new h,i.set(e,n)),n.set(t,r)),r):r}function l(e){if(R(e))throw new TypeError;return r===e||n===e||!R(s)&&s.has(e)}function m(e,t,r){if(!l(r))throw new Error("Metadata provider not registered.");var n=u(e,t);if(n!==r){if(!R(n))return!1;var s=i.get(e);R(s)&&(s=new h,i.set(e,s)),s.set(t,r)}return!0}}()),!R(f)&&N(t.Reflect)&&Object.isExtensible(t.Reflect)&&Object.defineProperty(t.Reflect,f,{enumerable:!1,configurable:!1,writable:!1,value:e}),e}(),y=function(e){var t=new p,r={isProviderFor:function(e,r){var n=t.get(e);return!R(n)&&n.has(r)},OrdinaryDefineOwnMetadata:function(e,t,r,s){n(r,s,!0).set(e,t)},OrdinaryHasOwnMetadata:function(e,t,r){var s=n(t,r,!1);return!R(s)&&O(s.has(e))},OrdinaryGetOwnMetadata:function(e,t,r){var s=n(t,r,!1);if(!R(s))return s.get(e)},OrdinaryOwnMetadataKeys:function(e,t){var r=[],s=n(e,t,!1);if(R(s))return r;for(var i=$(s.keys()),a=0;;){var o=K(i);if(!o)return r.length=a,r;var c=M(o);try{r[a]=c}catch(e){try{I(i)}finally{throw e}}a++}},OrdinaryDeleteMetadata:function(e,r,s){var i=n(r,s,!1);if(R(i))return!1;if(!i.delete(e))return!1;if(0===i.size){var a=t.get(r);R(a)||(a.delete(s),0===a.size&&t.delete(a))}return!0}};return m.registerProvider(r),r;function n(n,s,i){var a=t.get(n),o=!1;if(R(a)){if(!i)return;a=new h,t.set(n,a),o=!0}var c=a.get(s);if(R(c)){if(!i)return;if(c=new h,a.set(s,c),!e.setProvider(n,s,r))throw a.delete(s),o&&t.delete(n),new Error("Wrong provider for target.")}return c}}(m);function w(e,t,r){if(g(e,t,r))return!0;var n=F(t);return!A(n)&&w(e,n,r)}function g(e,t,r){var n=L(t,r,!1);return!R(n)&&O(n.OrdinaryHasOwnMetadata(e,t,r))}function _(e,t,r){if(g(e,t,r))return b(e,t,r);var n=F(t);return A(n)?void 0:_(e,n,r)}function b(e,t,r){var n=L(t,r,!1);if(!R(n))return n.OrdinaryGetOwnMetadata(e,t,r)}function v(e,t,r,n){L(r,n,!0).OrdinaryDefineOwnMetadata(e,t,r,n)}function E(e,t){var r=x(e,t),n=F(e);if(null===n)return r;var s=E(n,t);if(s.length<=0)return r;if(r.length<=0)return s;for(var i=new d,a=[],o=0,c=r;o<c.length;o++){var u=c[o];i.has(u)||(i.add(u),a.push(u))}for(var l=0,h=s;l<h.length;l++)u=h[l],i.has(u)||(i.add(u),a.push(u));return a}function x(e,t){var r=L(e,t,!1);return r?r.OrdinaryOwnMetadataKeys(e,t):[]}function k(e){if(null===e)return 1;switch(typeof e){case"undefined":return 0;case"boolean":return 2;case"string":return 3;case"symbol":return 4;case"number":return 5;case"object":return null===e?1:6;default:return 6}}function R(e){return void 0===e}function A(e){return null===e}function N(e){return"object"==typeof e?null!==e:"function"==typeof e}function C(e,t){switch(k(e)){case 0:case 1:case 2:case 3:case 4:case 5:return e}var r=3===t?"string":5===t?"number":"default",n=D(e,s);if(void 0!==n){var i=n.call(e,r);if(N(i))throw new TypeError;return i}return function(e,t){if("string"===t){var r=e.toString;if(j(r)&&!N(s=r.call(e)))return s;if(j(n=e.valueOf)&&!N(s=n.call(e)))return s}else{var n;if(j(n=e.valueOf)&&!N(s=n.call(e)))return s;var s,i=e.toString;if(j(i)&&!N(s=i.call(e)))return s}throw new TypeError}(e,"default"===r?"number":r)}function O(e){return!!e}function T(e){var t=C(e,3);return"symbol"==typeof t?t:function(e){return""+e}(t)}function S(e){return Array.isArray?Array.isArray(e):e instanceof Object?e instanceof Array:"[object Array]"===Object.prototype.toString.call(e)}function j(e){return"function"==typeof e}function P(e){return"function"==typeof e}function q(e,t){return e===t||e!=e&&t!=t}function D(e,t){var r=e[t];if(null!=r){if(!j(r))throw new TypeError;return r}}function $(e){var t=D(e,i);if(!j(t))throw new TypeError;var r=t.call(e);if(!N(r))throw new TypeError;return r}function M(e){return e.value}function K(e){var t=e.next();return!t.done&&t}function I(e){var t=e.return;t&&t.call(e)}function F(e){var t=Object.getPrototypeOf(e);if("function"!=typeof e||e===l)return t;if(t!==l)return t;var r=e.prototype,n=r&&Object.getPrototypeOf(r);if(null==n||n===Object.prototype)return t;var s=n.constructor;return"function"!=typeof s||s===e?t:s}function L(e,t,r){var n=m.getProvider(e,t);if(!R(n))return n;if(r){if(m.setProvider(e,t,y))return y;throw new Error("Illegal state.")}}function V(e){return e.__=void 0,delete e.__,e}e("decorate",function(e,t,r,n){if(R(r)){if(!S(e))throw new TypeError;if(!P(t))throw new TypeError;return function(e,t){for(var r=e.length-1;r>=0;--r){var n=(0,e[r])(t);if(!R(n)&&!A(n)){if(!P(n))throw new TypeError;t=n}}return t}(e,t)}if(!S(e))throw new TypeError;if(!N(t))throw new TypeError;if(!N(n)&&!R(n)&&!A(n))throw new TypeError;return A(n)&&(n=void 0),function(e,t,r,n){for(var s=e.length-1;s>=0;--s){var i=(0,e[s])(t,r,n);if(!R(i)&&!A(i)){if(!N(i))throw new TypeError;n=i}}return n}(e,t,r=T(r),n)}),e("metadata",function(e,t){return function(r,n){if(!N(r))throw new TypeError;if(!R(n)&&!function(e){switch(k(e)){case 3:case 4:return!0;default:return!1}}(n))throw new TypeError;v(e,t,r,n)}}),e("defineMetadata",function(e,t,r,n){if(!N(r))throw new TypeError;return R(n)||(n=T(n)),v(e,t,r,n)}),e("hasMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),w(e,t,r)}),e("hasOwnMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),g(e,t,r)}),e("getMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),_(e,t,r)}),e("getOwnMetadata",function(e,t,r){if(!N(t))throw new TypeError;return R(r)||(r=T(r)),b(e,t,r)}),e("getMetadataKeys",function(e,t){if(!N(e))throw new TypeError;return R(t)||(t=T(t)),E(e,t)}),e("getOwnMetadataKeys",function(e,t){if(!N(e))throw new TypeError;return R(t)||(t=T(t)),x(e,t)}),e("deleteMetadata",function(e,t,r){if(!N(t))throw new TypeError;if(R(r)||(r=T(r)),!N(t))throw new TypeError;R(r)||(r=T(r));var n=L(t,r,!1);return!R(n)&&n.OrdinaryDeleteMetadata(e,t,r)})}(r,t),void 0===t.Reflect&&(t.Reflect=e)}()}(e||(e={}))},697:(e,t,r)=>{},707:(e,t,r)=>{}},__webpack_module_cache__={};function __webpack_require__(e){var t=__webpack_module_cache__[e];if(void 0!==t)return t.exports;var r=__webpack_module_cache__[e]={exports:{}};return __webpack_modules__[e](r,r.exports,__webpack_require__),r.exports}__webpack_require__.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return __webpack_require__.d(t,{a:t}),t},__webpack_require__.d=(e,t)=>{for(var r in t)__webpack_require__.o(t,r)&&!__webpack_require__.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},__webpack_require__.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),__webpack_require__.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})};var __webpack_exports__={};(()=>{"use strict";__webpack_require__.r(__webpack_exports__),__webpack_require__.d(__webpack_exports__,{ArcanaJSServer:()=>G,Container:()=>B,Express:()=>s.Express,FormRequest:()=>Y,JsonResource:()=>Z,NextFunction:()=>s.NextFunction,Request:()=>s.Request,Response:()=>s.Response,Route:()=>ie,ServiceProvider:()=>ae,ValidationException:()=>Q,Validator:()=>X,createArcanaServer:()=>oe});const e=require("compression");var t=__webpack_require__.n(e);const r=require("cookie-parser");var n=__webpack_require__.n(r);const s=require("express");var i=__webpack_require__.n(s);const a=require("fs");var o=__webpack_require__.n(a);const c=require("helmet");var u=__webpack_require__.n(c);const l=require("path");var h=__webpack_require__.n(l);const d=require("react");var p=__webpack_require__.n(d);const f=({children:e})=>p().createElement(p().Fragment,null,e);function m(e,t){const r=global,n=Symbol.for(`ARCANAJS_CONTEXT_${e}`);return r[n]||(r[n]=(0,d.createContext)(t)),r[n]}const y=m("HeadContext",null),w=({children:e})=>{const t=(0,d.useContext)(y);return"undefined"==typeof window&&t&&p().Children.forEach(e,e=>{p().isValidElement(e)&&t.push(p().cloneElement(e,{"data-arcanajs-head":"true"}))}),(0,d.useEffect)(()=>{const t=[];return p().Children.forEach(e,e=>{if(p().isValidElement(e)){const r=e;if("title"===r.type)document.title=r.props.children;else if("meta"===r.type){const e=r.props;let n="meta";if(e.name&&(n+=`[name="${e.name}"]`),e.property&&(n+=`[property="${e.property}"]`),e.name||e.property){let r=document.querySelector(n+'[data-arcanajs-head="true"]')||document.querySelector(n);if(r)r.setAttribute("content",e.content),r.setAttribute("data-arcanajs-head","true"),t.push(r);else{const r=document.createElement("meta");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}else if("link"===r.type){const e=r.props;let n="link";e.rel&&(n+=`[rel="${e.rel}"]`),e.href&&(n+=`[href="${e.href}"]`);let s=document.querySelector(n+'[data-arcanajs-head="true"]')||document.querySelector(n);if(s)s.setAttribute("data-arcanajs-head","true"),t.push(s);else{const r=document.createElement("link");Object.keys(e).forEach(t=>{r.setAttribute(t,e[t])}),r.setAttribute("data-arcanajs-head","true"),document.head.appendChild(r),t.push(r)}}}}),()=>{t.forEach(e=>{e.remove()})}},[e]),null},g=m("RouterContext",null),_=({value:e,children:t})=>p().createElement(g.Provider,{value:e},t);function b(){return b=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)({}).hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e},b.apply(null,arguments)}const v=({href:e,children:t,prefetch:r=!1,...n})=>{const{navigateTo:s,navigateToAsync:i}=(()=>{const e=(0,d.useContext)(g);if(!e)throw new Error("useRouter must be used within an ArcanaJSApp");return e})(),a=/^https?:\/\//.test(e);return p().createElement("a",b({href:e,onClick:async t=>{t.preventDefault(),a?window.open(e,"_blank","noopener,noreferrer"):i?await i(e):s(e)},onMouseEnter:()=>{r&&!a&&fetch(e,{method:"HEAD"}).catch(()=>{})},target:a?"_blank":void 0,rel:a?"noopener noreferrer":void 0},n),t)},E=m("PageContext",null),x=({data:e,title:t,children:r})=>p().createElement(E.Provider,{value:e},t&&p().createElement(w,null,p().createElement("title",null,t)),r);function k({message:e="Something went wrong",statusCode:t=500,stack:r}){const n="development"===process.env.NODE_ENV;return React.createElement(x,null,React.createElement(w,null,React.createElement("title",null,t," - Server Error"),React.createElement("meta",{name:"description",content:"An error occurred on the server"})),React.createElement(f,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 right-1/4 w-96 h-96 bg-red-600 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 left-1/4 w-96 h-96 bg-orange-600 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-2xl w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("div",{className:"text-6xl mb-6 animate-float"},React.createElement("span",{className:"text-red-500 drop-shadow-lg filter"},"⚠️")),React.createElement("h1",{className:"text-8xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-red-500 to-orange-500 mb-4"},t),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Server Error"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e)),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center mb-8"},React.createElement(v,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto bg-gradient-to-r from-red-600 to-orange-600 hover:from-red-500 hover:to-orange-500 border-none shadow-red-900/20"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.location.reload(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15"})),"Try Again")),n&&r&&React.createElement("div",{className:"mt-8 text-left animate-slide-up"},React.createElement("details",{className:"bg-black/40 border border-white/10 rounded-xl overflow-hidden group"},React.createElement("summary",{className:"cursor-pointer font-medium text-gray-300 p-4 hover:bg-white/5 transition-colors flex items-center justify-between select-none"},React.createElement("span",null,"Stack Trace (Development Only)"),React.createElement("svg",{className:"w-5 h-5 text-gray-500 group-open:rotate-180 transition-transform",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M19 9l-7 7-7-7"}))),React.createElement("pre",{className:"text-xs text-red-300/80 p-4 overflow-x-auto whitespace-pre-wrap font-mono border-t border-white/5 bg-black/20"},r)))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If this problem persists, please"," ",React.createElement(v,{href:"/contact",className:"text-red-400 hover:text-red-300 underline transition-colors"},"contact support"),".")))))}function R({url:e}){return React.createElement(x,null,React.createElement(w,null,React.createElement("title",null,"404 - Page Not Found"),React.createElement("meta",{name:"description",content:"The page you're looking for doesn't exist"})),React.createElement(f,null,React.createElement("div",{className:"relative min-h-screen overflow-hidden bg-black text-white flex flex-col justify-center items-center px-4 font-sans"},React.createElement("div",{className:"fixed inset-0 z-0 overflow-hidden pointer-events-none"},React.createElement("div",{className:"absolute inset-0 grid-pattern opacity-30"}),React.createElement("div",{className:"absolute top-1/4 left-1/4 w-96 h-96 bg-orange-500 rounded-full opacity-20 blur-3xl animate-glow"}),React.createElement("div",{className:"absolute bottom-1/4 right-1/4 w-96 h-96 bg-purple-500 rounded-full opacity-10 blur-3xl animate-glow",style:{animationDelay:"2s"}}),React.createElement("div",{className:"absolute inset-0 hero-gradient"})),React.createElement("div",{className:"relative z-10 max-w-lg w-full text-center animate-scale-in"},React.createElement("div",{className:"glass-card rounded-3xl p-12 border border-white/10 shadow-2xl"},React.createElement("div",{className:"mb-8"},React.createElement("h1",{className:"text-9xl font-bold text-transparent bg-clip-text bg-gradient-to-br from-white to-gray-500 mb-4 animate-float"},"404"),React.createElement("h2",{className:"text-3xl font-bold text-white mb-4"},"Page Not Found"),React.createElement("p",{className:"text-gray-400 text-lg leading-relaxed"},e?React.createElement(React.Fragment,null,"The page ",React.createElement("span",{className:"text-orange-400"},'"',e,'"')," ","you're looking for doesn't exist."):"The page you're looking for doesn't exist.")),React.createElement("div",{className:"flex flex-col sm:flex-row gap-4 justify-center"},React.createElement(v,{href:"/",className:"btn-primary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6"})),"Go Home"),React.createElement("button",{onClick:()=>window.history.back(),className:"btn-secondary px-8 py-3.5 text-white font-semibold rounded-xl inline-flex items-center justify-center gap-2 w-full sm:w-auto"},React.createElement("svg",{className:"w-5 h-5",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24"},React.createElement("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 19l-7-7m0 0l7-7m-7 7h18"})),"Go Back"))),React.createElement("div",{className:"mt-8 text-gray-500 text-sm"},"If you believe this is an error, please"," ",React.createElement(v,{href:"/contact",className:"text-orange-400 hover:text-orange-300 underline transition-colors"},"contact support"),".")))))}const A=require("react-dom/server"),N=e=>{const{initialPage:t,initialData:r,initialParams:n={},initialUrl:s,csrfToken:i,views:a,layout:o,onNavigate:c,cacheLimit:u=50}=e,[l,h]=(0,d.useState)(t),[f,m]=(0,d.useState)(r),[y,w]=(0,d.useState)(n),[g,b]=(0,d.useState)(s||("undefined"!=typeof window?window.location.pathname:"/")),[v,E]=(0,d.useState)(!1),k=p().useRef(new Map),R=p().useRef(null);(0,d.useEffect)(()=>{"undefined"==typeof window||window.history.state||window.history.replaceState({page:t,data:r,params:n},"",window.location.href);const e=e=>{if(e.state)h(e.state.page),m(e.state.data),w(e.state.params||{}),b(window.location.pathname);else{const e=window.location.pathname;A(e).catch(()=>{window.location.reload()})}};return window.addEventListener("popstate",e),()=>{var t;window.removeEventListener("popstate",e),null===(t=R.current)||void 0===t||t.abort()}},[]);const A=async e=>{var t;const r=k.current;if(r.has(e)){const t=r.get(e);if(h(t.page),m(t.data),w(t.params||{}),b(e),window.history.pushState(t,"",e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}return void(c&&c(e))}E(!0),null===(t=R.current)||void 0===t||t.abort();const n=new AbortController;R.current=n;try{const t=await fetch(e,{headers:{"X-ArcanaJS-Request":"true"},cache:"no-store",signal:n.signal});if(!t.ok){if(404===t.status)return h("NotFoundPage"),b(e),void window.history.pushState({page:"NotFoundPage",data:{}},"",e);throw new Error(`Navigation failed: ${t.status} ${t.statusText}`)}if(!(t.headers.get("content-type")||"").includes("application/json"))return void(window.location.href=e);const r=await t.json(),s={page:r.page,data:r.data,params:r.params||{}};if(((e,t)=>{const r=k.current;if(r.has(e)&&r.delete(e),r.set(e,t),r.size>u){const e=r.keys().next().value;void 0!==e&&r.delete(e)}})(e,s),window.history.pushState({page:s.page,data:s.data,params:s.params},"",e),h(s.page),m(s.data),w(s.params||{}),b(e),"undefined"!=typeof window)try{window.scrollTo({top:0,behavior:"smooth"})}catch{}c&&c(e)}catch(e){if("AbortError"===(null==e?void 0:e.name))return;throw console.error("Navigation failed",e),e}finally{R.current===n&&(R.current=null),E(!1)}},N=(()=>{const e=a[l]||a.NotFoundPage||(()=>p().createElement("div",null,"404 Not Found"));return p().createElement(x,{data:f},p().createElement(e,{data:f,navigateTo:A,params:y}))})();return p().createElement(_,{value:{navigateTo:(...e)=>{A(e[0])},navigateToAsync:A,currentPage:l,currentUrl:g,params:y,csrfToken:i,onNavigate:c,isNavigating:v}},o?p().createElement(o,null,N):p().createElement(p().Fragment,null,N))},C='<!DOCTYPE html>\n<html lang="en">\n <head>\n <meta charset="UTF-8" />\n <meta name="viewport" content="width=device-width, initial-scale=1.0" />\n \x3c!--HEAD_CONTENT--\x3e\n </head>\n <body>\n <div id="root">\x3c!--APP_CONTENT--\x3e</div>\n \x3c!--ARCANAJS_DATA_SCRIPT--\x3e\n </body>\n</html>',O=require("crypto");var T=__webpack_require__.n(O);const S="_csrf",j=(e,t,r)=>{t.success=(e={},r="Success",n=200)=>t.status(n).json({success:!0,message:r,data:e,error:null}),t.error=(e="Error",r=500,n=null,s=null)=>{const i=n?"object"==typeof n&&null!==n?n instanceof Error?n.toString():n:n.toString():null;return t.status(r).json({success:!1,message:e,data:s,error:i})},r()};var P=__webpack_require__(14);class q{static macros={};static macro(e,t){this.macros[e]=t,this.prototype[e]=t}static mixin(e){Object.keys(e).forEach(t=>{this.macro(t,e[t])})}static hasMacro(e){return!!this.macros[e]}}class D extends q{selectColumns=["*"];whereClauses=[];orderByClauses=[];joinClauses=[];constructor(e,t){super(),this.tableName=e,this.adapter=t}select(...e){return this.selectColumns=e,this}where(e,t,r){return void 0===r&&(r=t,t="="),this.whereClauses.push({column:e,operator:t,value:r,boolean:"AND"}),this}orWhere(e,t,r){return void 0===r&&(r=t,t="="),this.whereClauses.push({column:e,operator:t,value:r,boolean:"OR"}),this}whereIn(e,t){return this.whereClauses.push({column:e,operator:"IN",value:t,boolean:"AND"}),this}whereNotIn(e,t){return this.whereClauses.push({column:e,operator:"NOT IN",value:t,boolean:"AND"}),this}whereBetween(e,t){return this.whereClauses.push({column:e,operator:"BETWEEN",value:t,boolean:"AND"}),this}whereNull(e){return this.whereClauses.push({column:e,operator:"IS NULL",value:null,boolean:"AND"}),this}whereNotNull(e){return this.whereClauses.push({column:e,operator:"IS NOT NULL",value:null,boolean:"AND"}),this}orderBy(e,t="ASC"){return this.orderByClauses.push({column:e,direction:t.toUpperCase()}),this}limit(e){return this.limitValue=e,this}offset(e){return this.offsetValue=e,this}join(e,t,r,n,s="INNER"){return this.joinClauses.push({type:s,table:e,first:t,operator:r,second:n}),this}leftJoin(e,t,r,n){return this.join(e,t,r,n,"LEFT")}rightJoin(e,t,r,n){return this.join(e,t,r,n,"RIGHT")}eagerLoads=[];setModel(e){return this.model=e,this}with(e){return Array.isArray(e)?this.eagerLoads.push(...e):this.eagerLoads.push(e),this}async get(){const e={columns:this.selectColumns,where:this.whereClauses,orderBy:this.orderByClauses,limit:this.limitValue,offset:this.offsetValue,joins:this.joinClauses},t=await this.adapter.select(this.tableName,e);return this.eagerLoads.length>0&&this.model?await this.eagerLoadRelations(t):t}async eagerLoadRelations(e){if(0===e.length)return e;const t=e.map(e=>this.model.hydrate(e));for(const e of this.eagerLoads){const r=new this.model;if("function"!=typeof r[e])throw new Error(`Relation ${e} does not exist on ${this.model.name}`);const n=r[e]();n.addEagerConstraints(t);const s=await n.get();n.match(t,s,e)}return t}async first(){return this.limit(1),(await this.get())[0]||null}async find(e){return this.where("id",e).first()}async count(){this.selectColumns=["COUNT(*) as count"];const e=await this.first();return e?e.count:0}async pluck(e){return this.select(e),(await this.get()).map(t=>t[e])}async sum(e){this.selectColumns=[`SUM(${e}) as sum`];const t=await this.first();return t&&t.sum||0}async avg(e){this.selectColumns=[`AVG(${e}) as avg`];const t=await this.first();return t&&t.avg||0}async min(e){this.selectColumns=[`MIN(${e}) as min`];const t=await this.first();return t?t.min:null}async max(e){this.selectColumns=[`MAX(${e}) as max`];const t=await this.first();return t?t.max:null}async exists(){return await this.count()>0}async paginate(e=1,t=15){const r=await this.count(),n=(e-1)*t;return this.limit(t).offset(n),{data:await this.get(),total:r,perPage:t,currentPage:e,lastPage:Math.ceil(r/t)}}clone(){const e=new D(this.tableName,this.adapter);return e.selectColumns=[...this.selectColumns],e.whereClauses=[...this.whereClauses],e.orderByClauses=[...this.orderByClauses],e.joinClauses=[...this.joinClauses],e.limitValue=this.limitValue,e.offsetValue=this.offsetValue,e}}class ${constructor(e,t){this.query=e,this.parent=t,this.related=e.model,this.addConstraints()}getQuery(){return this.query}async get(){return this.query.get()}async first(){return this.query.first()}}class M extends ${constructor(e,t,r,n){super(e,t),this.foreignKey=r,this.ownerKey=n}addConstraints(){const e=this.parent.getAttribute(this.foreignKey);this.query.where(this.ownerKey,"=",e)}addEagerConstraints(e){const t=e.map(e=>e.getAttribute(this.foreignKey)).filter(e=>null!==e);this.query.whereIn(this.ownerKey,t)}match(e,t,r){const n={};return t.forEach(e=>{const t=e.getAttribute(this.ownerKey);n[t]=e}),e.forEach(e=>{const t=e.getAttribute(this.foreignKey);n[t]&&e.setRelation(r,n[t])}),e}}class K extends ${constructor(e,t,r,n,s,i,a){super(e,t),this.table=r,this.foreignPivotKey=n,this.relatedPivotKey=s,this.parentKey=i,this.relatedKey=a}addConstraints(){this.performJoin(),this.query.where(`${this.table}.${this.foreignPivotKey}`,"=",this.parent.getAttribute(this.parentKey))}performJoin(e){const t=e||this.query,r=this.related.prototype.getTable();return t.join(this.table,`${r}.${this.relatedKey}`,"=",`${this.table}.${this.relatedPivotKey}`),this}addEagerConstraints(e){this.performJoin();const t=e.map(e=>e.getAttribute(this.parentKey)).filter(e=>null!==e);this.query.whereIn(`${this.table}.${this.foreignPivotKey}`,t)}match(e,t,r){return e}}class I extends ${constructor(e,t,r,n){super(e,t),this.foreignKey=r,this.localKey=n}addConstraints(){const e=this.parent.getAttribute(this.localKey);this.query.where(this.foreignKey,"=",e)}addEagerConstraints(e){const t=e.map(e=>e.getAttribute(this.localKey)).filter(e=>null!==e);this.query.whereIn(this.foreignKey,t)}match(e,t,r){const n={};return t.forEach(e=>{const t=e.getAttribute(this.foreignKey);n[t]||(n[t]=[]),n[t].push(e)}),e.forEach(e=>{const t=e.getAttribute(this.localKey);n[t]?e.setRelation(r,n[t]):e.setRelation(r,[])}),e}}class F extends ${constructor(e,t,r,n){super(e,t),this.foreignKey=r,this.localKey=n}addConstraints(){const e=this.parent.getAttribute(this.localKey);this.query.where(this.foreignKey,"=",e)}addEagerConstraints(e){const t=e.map(e=>e.getAttribute(this.localKey)).filter(e=>null!==e);this.query.whereIn(this.foreignKey,t)}match(e,t,r){const n={};return t.forEach(e=>{const t=e.getAttribute(this.foreignKey);n[t]=e}),e.forEach(e=>{const t=e.getAttribute(this.localKey);n[t]&&e.setRelation(r,n[t])}),e}}class L extends q{static primaryKey="id";static connection="default";attributes={};original={};relations={};exists=!1;fillable=[];guarded=["id"];hidden=[];visible=[];casts={};dates=[];timestamps=!0;createdAt="created_at";updatedAt="updated_at";softDeletes=!1;deletedAt="deleted_at";static setAdapter(e){this.adapter=e}static getTable(){if(this.tableName)return this.tableName;const e=this.name;return this.pluralize(this.snakeCase(e))}static query(){return new D(this.getTable(),this.adapter)}static async all(){return(await this.query().get()).map(e=>this.hydrate(e))}static async find(e){const t=await this.query().where(this.primaryKey,e).first();return t?this.hydrate(t):null}static async findOrFail(e){const t=await this.find(e);if(!t)throw new Error(`Model not found with ${this.primaryKey}: ${e}`);return t}static where(e,t,r){return this.query().where(e,t,r)}static async create(e){const t=new this;if(t.fill(e),t.timestamps){const e=new Date;t.attributes[t.createdAt]=e,t.attributes[t.updatedAt]=e}const r=await this.adapter.insert(this.getTable(),t.attributes),n=r[this.primaryKey]||r.id||r.insertId;return t.attributes[this.primaryKey]=n,"id"!==this.primaryKey&&(t.attributes.id=n),t.exists=!0,t.syncOriginal(),t}static async update(e,t){const r=await this.findOrFail(e);return await r.update(t),r}static async destroy(e){const t=await this.find(e);return!!t&&await t.delete()}static async firstOrCreate(e,t={}){const r=this.query();for(const[t,n]of Object.entries(e))r.where(t,n);const n=await r.first();return n?this.hydrate(n):await this.create({...e,...t})}static async updateOrCreate(e,t={}){const r=this.query();for(const[t,n]of Object.entries(e))r.where(t,n);const n=await r.first();if(n){const e=this.hydrate(n);return await e.update(t),e}return await this.create({...e,...t})}static hydrate(e){const t=new this;return t.attributes={...e},t.original={...e},t.exists=!0,t}fill(e){for(const[t,r]of Object.entries(e))this.isFillable(t)&&this.setAttribute(t,r);return this}isFillable(e){return this.fillable.length>0?this.fillable.includes(e):!this.guarded.includes(e)}setAttribute(e,t){const r=`set${this.studly(e)}Attribute`;"function"==typeof this[r]&&(t=this[r](t)),this.attributes[e]=this.castAttribute(e,t)}getAttribute(e){const t=`get${this.studly(e)}Attribute`;if("function"==typeof this[t])return this[t]();const r=this.attributes[e];return this.castAttribute(e,r,!0)}castAttribute(e,t,r=!1){if(null==t)return t;const n=this.casts[e];if(!n)return t;if(r)switch(n){case"int":case"integer":return parseInt(t);case"float":case"double":return parseFloat(t);case"string":return String(t);case"bool":case"boolean":return Boolean(t);case"array":case"json":return"string"==typeof t?JSON.parse(t):t;case"date":case"datetime":return t instanceof Date?t:new Date(t);default:return t}else switch(n){case"array":case"json":return"object"==typeof t?JSON.stringify(t):t;case"date":case"datetime":return t instanceof Date?t:new Date(t);default:return t}}async save(){const e=this.constructor;if(this.timestamps){const e=new Date;this.exists||(this.attributes[this.createdAt]=e),this.attributes[this.updatedAt]=e}if(this.exists){const t=this.attributes[e.primaryKey];await e.adapter.update(e.getTable(),t,this.attributes)}else{const t=await e.adapter.insert(e.getTable(),this.attributes),r=t[e.primaryKey]||t.id||t.insertId;this.attributes[e.primaryKey]=r,"id"!==e.primaryKey&&(this.attributes.id=r),this.exists=!0}return this.syncOriginal(),this}async update(e){return this.fill(e),await this.save()}async delete(){const e=this.constructor;if(this.softDeletes)return this.attributes[this.deletedAt]=new Date,await this.save(),!0;const t=this.attributes[e.primaryKey];return await e.adapter.delete(e.getTable(),t)}async forceDelete(){const e=this.constructor,t=this.attributes[e.primaryKey];return await e.adapter.delete(e.getTable(),t)}async restore(){return this.softDeletes&&(this.attributes[this.deletedAt]=null,await this.save()),this}syncOriginal(){this.original={...this.attributes}}getDirty(){const e={};for(const[t,r]of Object.entries(this.attributes))this.original[t]!==r&&(e[t]=r);return e}isDirty(){return Object.keys(this.getDirty()).length>0}constructor(e={}){super(),this.fill(e)}toJSON(){const e={};for(const[t,r]of Object.entries(this.attributes))this.hidden.includes(t)||this.visible.length>0&&!this.visible.includes(t)||(e[t]=this.getAttribute(t));for(const[t,r]of Object.entries(this.relations))e[t]=r;return e}hasOne(e,t,r){const n=new e,s=t||`${this.constructor.name.toLowerCase()}_id`,i=r||"id";return new F(n.newQuery(),this,s,i)}hasMany(e,t,r){const n=new e,s=t||`${this.constructor.name.toLowerCase()}_id`,i=r||"id";return new I(n.newQuery(),this,s,i)}belongsTo(e,t,r){const n=new e,s=t||`${n.constructor.name.toLowerCase()}_id`,i=r||"id";return new M(n.newQuery(),this,s,i)}belongsToMany(e,t,r,n,s,i){const a=new e,o=t||this.guessPivotTable(a),c=r||`${this.constructor.name.toLowerCase()}_id`,u=n||`${a.constructor.name.toLowerCase()}_id`,l=s||"id",h=i||"id";return new K(a.newQuery(),this,o,c,u,l,h)}guessPivotTable(e){const t=[this.constructor.name.toLowerCase(),e.constructor.name.toLowerCase()];return t.sort(),t.join("_")}static with(e){return this.query().with(e)}setRelation(e,t){return this.relations[e]=t,this}getRelation(e){return this.relations[e]}relationLoaded(e){return void 0!==this.relations[e]}newQuery(){return this.constructor.query()}static snakeCase(e){return e.replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}static pluralize(e){return e.endsWith("y")?e.slice(0,-1)+"ies":e.endsWith("s")?e+"es":e+"s"}studly(e){return e.replace(/(^|_)(\w)/g,(e,t,r)=>r.toUpperCase())}}class V{constructor(e,t,r){this.definition={name:e,type:t,length:r,nullable:!1}}nullable(){return this.definition.nullable=!0,this}default(e){return this.definition.default=e,this}unique(){return this.definition.unique=!0,this}primary(){return this.definition.primary=!0,this}autoIncrement(){return this.definition.autoIncrement=!0,this}unsigned(){return this.definition.unsigned=!0,this}getDefinition(){return this.definition}}class H{constructor(e){this.column=e}references(e){return this.referencedColumn=e,this}on(e){return this.referencedTable=e,this}onDelete(e){return this.onDeleteAction=e,this}onUpdate(e){return this.onUpdateAction=e,this}toSQL(){if(!this.referencedTable||!this.referencedColumn)throw new Error("Foreign key must reference a table and column");let e=`FOREIGN KEY (${this.column}) REFERENCES ${this.referencedTable}(${this.referencedColumn})`;return this.onDeleteAction&&(e+=` ON DELETE ${this.onDeleteAction}`),this.onUpdateAction&&(e+=` ON UPDATE ${this.onUpdateAction}`),e}}class J{columns=[];indexes=[];foreignKeys=[];primaryKeys=[];constructor(e){this.tableName=e}id(e="id"){const t=new V(e,"bigInteger");return t.primary().autoIncrement().unsigned(),this.columns.push(t.getDefinition()),t}uuid(e="id"){const t=new V(e,"uuid");return this.columns.push(t.getDefinition()),t}string(e,t=255){const r=new V(e,"string",t);return this.columns.push(r.getDefinition()),r}text(e){const t=new V(e,"text");return this.columns.push(t.getDefinition()),t}integer(e){const t=new V(e,"integer");return this.columns.push(t.getDefinition()),t}bigInteger(e){const t=new V(e,"bigInteger");return this.columns.push(t.getDefinition()),t}decimal(e,t=10,r=2){const n=new V(e,"decimal");return this.columns.push(n.getDefinition()),n}float(e){const t=new V(e,"float");return this.columns.push(t.getDefinition()),t}double(e){const t=new V(e,"double");return this.columns.push(t.getDefinition()),t}boolean(e){const t=new V(e,"boolean");return this.columns.push(t.getDefinition()),t}date(e){const t=new V(e,"date");return this.columns.push(t.getDefinition()),t}datetime(e){const t=new V(e,"datetime");return this.columns.push(t.getDefinition()),t}timestamp(e){const t=new V(e,"timestamp");return this.columns.push(t.getDefinition()),t}timestamps(){this.timestamp("created_at").nullable(),this.timestamp("updated_at").nullable()}softDeletes(e="deleted_at"){return this.timestamp(e).nullable()}json(e){const t=new V(e,"json");return this.columns.push(t.getDefinition()),t}enum(e,t){const r=new V(e,"enum");return this.columns.push(r.getDefinition()),r}foreign(e){const t=new H(e);return this.foreignKeys.push(t),t}index(e,t){const r=Array.isArray(e)?e:[e];this.indexes.push({columns:r,unique:!1,name:t})}unique(e,t){const r=Array.isArray(e)?e:[e];this.indexes.push({columns:r,unique:!0,name:t})}primary(e){this.primaryKeys=Array.isArray(e)?e:[e]}getColumns(){return this.columns}getTableName(){return this.tableName}getIndexes(){return this.indexes}getForeignKeys(){return this.foreignKeys}}class W{static setAdapter(e){this.adapter=e}static async create(e,t){const r=new J(e);t(r),await this.adapter.createTable(e,r.getColumns())}static async table(e,t){t(new J(e)),console.warn("Schema.table() is not fully implemented yet. Use migrations for complex alterations.")}static async drop(e){await this.adapter.dropTable(e)}static async dropIfExists(e){await this.hasTable(e)&&await this.drop(e)}static async rename(e,t){throw new Error("Schema.rename() not yet implemented")}static async hasTable(e){return await this.adapter.hasTable(e)}static async hasColumn(e,t){return await this.adapter.hasColumn(e,t)}static async getTables(){throw new Error("Schema.getTables() not yet implemented")}static async getColumns(e){throw new Error("Schema.getColumns() not yet implemented")}}class U{static async register(e){let t;try{const e=`${process.cwd()}/database/config`;t=(0,P.dynamicRequire)(e).default||(0,P.dynamicRequire)(e)}catch(e){return void console.warn("No database config found. Skipping database setup.")}const r=(()=>{switch(t.type){case"mysql":return new(__webpack_require__(707).default);case"mongodb":return new(__webpack_require__(697).default);case"postgres":return new(__webpack_require__(590).default);default:throw new Error(`Unsupported DB type ${t.type}`)}})();e.singleton("DatabaseAdapter",()=>r),e.singleton("DBConnection",async()=>{const e=await r.connect(t);return L.setAdapter(r),W.setAdapter(r),console.log(`Connected to ${t.type} database: ${t.database}`),e})}static async close(e){try{const t=await e.make("DatabaseAdapter");await t.disconnect(),console.log("Database connection closed.")}catch(e){}}}__webpack_require__(630);class B{bindings=new Map;singletons=new Map;constructor(){B.instance||(B.instance=this)}static getInstance(){return B.instance||(B.instance=new B),B.instance}bind(e,t){this.isConstructor(t)?this.bindings.set(e,()=>this.build(t)):this.bindings.set(e,t)}singleton(e,t){const r=this.isConstructor(t)?()=>this.build(t):t;this.bindings.set(e,()=>(this.singletons.has(e)||this.singletons.set(e,r(this)),this.singletons.get(e)))}make(e){if(this.bindings.has(e))return this.bindings.get(e)(this);if(this.isConstructor(e))return this.build(e);throw new Error(`Service not found: ${e.toString()}`)}build(e){return new e(...(Reflect.getMetadata("design:paramtypes",e)||[]).map(e=>this.make(e)))}isConstructor(e){return!!e.prototype&&!!e.prototype.constructor.name}}const z=B.getInstance(),G=class{providers=[];constructor(e){this.config=e,this.app=i()(),this.container=B.getInstance(),U.register(this.container).catch(e=>{console.error("Failed to register DatabaseProvider:",e)}),this.initialize(),this.registerProviders(),this.bootProviders()}registerProviders(){this.config.providers&&this.config.providers.forEach(e=>{const t=new e(this);t.register(),this.providers.push(t)})}bootProviders(){this.providers.forEach(e=>{e.boot()})}initialize(){const{staticDir:e="public",distDir:r="dist/public",indexFile:s="dist/public/index.html",views:a,viewsContext:c,routes:l,layout:d,apiRoutes:f,apiBase:m="/api"}=this.config,w=process.cwd();let g=a;!g&&c&&(g=this.loadViewsFromContext(c)),g||(g=this.loadViewsFromAlias()),g||(g=this.discoverViews()),g&&0!==Object.keys(g).length||(console.warn("No views found. Please check your views directory."),g={}),g.NotFoundPage=g.NotFoundPage||R,g.ErrorPage=g.ErrorPage||k,this.app.use(u()({contentSecurityPolicy:!1})),this.app.use(n()()),this.app.use((e,t,r)=>{let n=e.cookies[S];n||(n=T().randomBytes(32).toString("hex"),t.cookie(S,n,{httpOnly:!0,secure:"production"===process.env.NODE_ENV,sameSite:"strict"})),t.locals.csrfToken=n;const s=e.method.toUpperCase();if(["POST","PUT","DELETE","PATCH"].includes(s)){const r=e.headers["x-csrf-token"];if(!r||r!==n)return t.status(403).json({error:"Invalid CSRF Token"})}r()}),this.app.use(j);const _={index:!1,maxAge:"production"===process.env.NODE_ENV?"1y":"0"},b=[h().resolve(w,r),h().resolve(w,e)].filter((e,t,r)=>r.indexOf(e)===t);for(const e of b)this.app.use(i().static(e,_));this.app.use(t()()),this.app.use((e=>{const{views:t,indexFile:r,layout:n}=e;let s=null;return(e,i,a)=>{i.renderPage=(a,c={},u={})=>{const l=i.locals.csrfToken;if(e.get("X-ArcanaJS-Request")||"json"===e.query.format)return i.json({page:a,data:c,params:u,csrfToken:l});try{const h=[],d={tags:h,push:e=>h.push(e)},f=(0,A.renderToString)(p().createElement(y.Provider,{value:d},p().createElement(N,{initialPage:a,initialData:c,initialParams:u,initialUrl:e.path,csrfToken:l,views:t,layout:n}))),m=(0,A.renderToString)(p().createElement(p().Fragment,null,...h));(e=>{if("production"===process.env.NODE_ENV&&s)return e(null,s);r&&o().existsSync(r)?o().readFile(r,"utf8",(t,r)=>{t||"production"!==process.env.NODE_ENV||(s=r),e(t,r)}):("production"===process.env.NODE_ENV&&(s=C),e(null,C))})((e,t)=>{if(e)return console.error("Error reading index.html",e),i.status(500).send("Server Error");var r;const n=`<script id="__ARCANAJS_DATA__" type="application/json">${r={page:a,data:c,params:u,csrfToken:l},JSON.stringify(r).replace(/</g,"\\u003c")}<\/script>`,s=process.env.ARCANA_HMR_PORT?`\n <script>\n (function() {\n const socket = new WebSocket("ws://localhost:${process.env.ARCANA_HMR_PORT}");\n socket.onmessage = function(event) {\n const data = JSON.parse(event.data);\n if (data.type === "reload") {\n window.location.reload();\n }\n };\n })();\n <\/script>`:"",o=t.replace("\x3c!--HEAD_CONTENT--\x3e",m).replace("\x3c!--APP_CONTENT--\x3e",f).replace("\x3c!--ARCANAJS_DATA_SCRIPT--\x3e",n+s);i.send(o)})}catch(e){return console.error("SSR Error:",e),i.status(500).send("Internal Server Error")}return i},a()}})({views:g,indexFile:h().resolve(w,s),layout:d}));const v=(e,t)=>{if(!e)return;const r=Array.isArray(e)?e:[e];for(const e of r)e&&("function"==typeof e.getRouter?this.app.use(t||"/",e.getRouter()):this.app.use(t||"/",e))};try{v(f,m),f&&console.log(`API routes mounted at ${m}`)}catch(e){console.error("Error mounting apiRoutes:",e)}try{v(l)}catch(e){console.error("Error mounting routes:",e)}this.app.use((e=>(t,r,n)=>{let s=t.path.substring(1);if(""===s&&(s="index"),e[s])return r.renderPage(s,{});for(const t of Object.keys(e)){if(!t.includes("["))continue;const e=t.split("/"),n=s.split("/");if(e.length!==n.length)continue;let i=!0;const a={};for(let t=0;t<e.length;t++){const r=e[t],s=n[t];if(r.startsWith("[")&&r.endsWith("]"))a[r.slice(1,-1)]=s;else if(r!==s){i=!1;break}}if(i)return r.renderPage(t,{},a)}n()})(g)),this.app.use((e,t)=>{e.get("X-ArcanaJS-Request")||"json"===e.query.format?t.status(404).json({page:"NotFoundPage",data:{},params:{},csrfToken:t.locals.csrfToken}):t.status(404).renderPage("NotFoundPage")}),this.app.use((e,t,r,n)=>{console.error(e);const s="production"===process.env.NODE_ENV?"Internal Server Error":e.message;t.get("X-ArcanaJS-Request")||"json"===t.query.format?r.status(500).json({page:"ErrorPage",data:{message:s},params:{},csrfToken:r.locals.csrfToken}):r.status(500).renderPage("ErrorPage",{message:s})})}loadViewsFromContext(e){const t={};return e.keys().forEach(r=>{const n=r.replace(/^\.\/(.*)\.tsx$/,"$1");t[n]=e(r).default}),t}loadViewsFromAlias(){try{const e=__webpack_require__(369);if(e)return this.loadViewsFromContext(e)}catch(e){}}discoverViews(){const e={},t=this.config.viewsDir?h().resolve(process.cwd(),this.config.viewsDir):h().resolve(process.cwd(),"src/views");if(!o().existsSync(t))return e;const r=n=>{o().readdirSync(n).forEach(s=>{const i=h().join(n,s);if(o().statSync(i).isDirectory())r(i);else if(s.endsWith(".tsx")||s.endsWith(".jsx")){const r=h().relative(t,i).replace(/\.(tsx|jsx)$/,"");try{if(s.endsWith(".tsx")||s.endsWith(".ts"))try{(0,P.dynamicRequire)("ts-node/register")}catch(e){}const t=(0,P.dynamicRequire)(i);e[r]=t.default||t}catch(e){console.error(`Failed to load view ${r}:`,e)}}})};return r(t),e}start(){const e=this.config.port||process.env.PORT||3e3;if(this.serverInstance=this.app.listen(e,()=>{console.log(`Server is running on http://localhost:${e}`)}),!1!==this.config.autoHandleSignals){const e=async()=>{try{await this.stop(),process.exit(0)}catch(e){console.error("Error during shutdown:",e),process.exit(1)}};this._sigintHandler=e,this._sigtermHandler=e,process.on("SIGINT",this._sigintHandler),process.on("SIGTERM",this._sigtermHandler)}}async stop(){this.serverInstance&&(await new Promise((e,t)=>{this.serverInstance.close(r=>{if(r)return t(r);e()})}),this.serverInstance=void 0,console.log("HTTP server stopped"));try{await U.close(this.container)}catch(e){console.error("Error closing database connection:",e)}try{this._sigintHandler&&(process.removeListener("SIGINT",this._sigintHandler),this._sigintHandler=void 0),this._sigtermHandler&&(process.removeListener("SIGTERM",this._sigtermHandler),this._sigtermHandler=void 0)}catch(e){}}};class Q extends Error{constructor(e){super("The given data was invalid."),this.name="ValidationException",this.errors=e,this.status=422}}class X{errors={};constructor(e,t){this.data=e,this.rules=t}static make(e,t){return new X(e,t)}fails(){return this.validate(),Object.keys(this.errors).length>0}passes(){return!this.fails()}errors_(){return this.errors}validate(){this.errors={};const e={};for(const[t,r]of Object.entries(this.rules)){const n=r.split("|"),s=this.data[t];for(const e of n)if("required"===e)null!=s&&""!==s||this.addError(t,`${t} is required.`);else if("string"===e)void 0!==s&&"string"!=typeof s&&this.addError(t,`${t} must be a string.`);else if("numeric"===e)void 0!==s&&isNaN(Number(s))&&this.addError(t,`${t} must be a number.`);else if("email"===e)void 0===s||/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(String(s))||this.addError(t,`${t} must be a valid email address.`);else if(e.startsWith("min:")){const r=parseInt(e.split(":")[1]);"string"==typeof s&&s.length<r?this.addError(t,`${t} must be at least ${r} characters.`):"number"==typeof s&&s<r&&this.addError(t,`${t} must be at least ${r}.`)}else if(e.startsWith("max:")){const r=parseInt(e.split(":")[1]);"string"==typeof s&&s.length>r?this.addError(t,`${t} must not be greater than ${r} characters.`):"number"==typeof s&&s>r&&this.addError(t,`${t} must not be greater than ${r}.`)}void 0!==s&&(e[t]=s)}if(Object.keys(this.errors).length>0)throw new Q(this.errors);return e}addError(e,t){this.errors[e]||(this.errors[e]=[]),this.errors[e].push(t)}}class Y{constructor(e){this.req=e}authorize(){return!0}async validate(){if(!this.authorize())throw new Error("This action is unauthorized.");return X.make(this.req.body,this.rules()).validate()}input(e,t=null){return this.req.body[e]||t}all(){return this.req.body}}class Z{constructor(e){this.resource=e}static make(e){return new this(e)}static collection(e){return new ee(e,this)}resolve(e){return null===this.resource?null:Array.isArray(this.resource)?this.resource.map(t=>new this.constructor(t).toArray(e)):this.toArray(e)}toArray(e){return this.resource&&"function"==typeof this.resource.toJSON?this.resource.toJSON():this.resource}}class ee extends Z{constructor(e,t){super(e),this.collects=t}resolve(e){return this.resource.map(t=>new this.collects(t).resolve(e))}}class te{static handle(e,t){let r;try{r=z.make(e)}catch(t){console.warn(`Failed to instantiate controller ${e.name}`,t),r=e}return async(n,s,i)=>{try{if("function"!=typeof r[t])throw new Error(`Method ${t} not found on controller ${e.name}`);await r[t](n,s,i)}catch(e){i(e)}}}}class re{static handle(e,t="handle"){let r;try{r=z.make(e)}catch(t){r=e}return async(n,s,i)=>{try{if("function"!=typeof r[t])throw new Error(`Method ${t} not found on middleware ${e.name}`);await r[t](n,s,i)}catch(e){i(e)}}}}class ne{constructor(){this.router=i().Router(),this.middlewareStack=[],this.prefixStack=[]}static create(){return new ne}middleware(...e){const t=this._clone(),r=e.map(e=>this._resolveMiddleware(e));return t.middlewareStack=[...this.middlewareStack,...r],t}prefix(e){const t=this._clone();return t.prefixStack=[...this.prefixStack,e.replace(/^\/|\/$/g,"")],t}group(e){return e(this),this}get(e,...t){const r=t.pop(),n=t;return this._addRoute("get",e,r,n)}post(e,...t){const r=t.pop(),n=t;return this._addRoute("post",e,r,n)}put(e,...t){const r=t.pop(),n=t;return this._addRoute("put",e,r,n)}delete(e,...t){const r=t.pop(),n=t;return this._addRoute("delete",e,r,n)}patch(e,...t){const r=t.pop(),n=t;return this._addRoute("patch",e,r,n)}options(e,...t){const r=t.pop(),n=t;return this._addRoute("options",e,r,n)}resource(e,t){return this.get(e,t,"index"),this.get(`${e}/create`,t,"create"),this.post(e,t,"store"),this.get(`${e}/:id`,t,"show"),this.get(`${e}/:id/edit`,t,"edit"),this.put(`${e}/:id`,t,"update"),this.patch(`${e}/:id`,t,"update"),this.delete(`${e}/:id`,t,"destroy"),this}getRouter(){return this.router}mount(e,t="/"){e.use(t,this.router)}_clone(){const e=new ne;return e.router=this.router,e.middlewareStack=[...this.middlewareStack],e.prefixStack=[...this.prefixStack],e}_addRoute(e,t,r,n=[]){const s=this._buildPath(t),i=this._buildHandler(r),a=n.flat(1/0).map(e=>this._resolveMiddleware(e)),o=[...this.middlewareStack,...a,i];return this.router[e](s,...o),this}_resolveMiddleware(e){var t;if("function"==typeof e&&(null===(t=e.prototype)||void 0===t||!t.handle))return e;if(Array.isArray(e)&&2===e.length){const[t,r]=e;return re.handle(t,r)}if("function"==typeof e||"object"==typeof e&&null!==e)return re.handle(e,"handle");throw new Error("Invalid middleware. Must be a function, [Class, 'method'], or Class.")}_buildPath(e){const t=e.replace(/^\//,""),r=this.prefixStack.filter(e=>""!==e);return 0===r.length?`/${t}`:`/${r.join("/")}/${t}`.replace(/\/+/g,"/")}_buildHandler(e){if("function"==typeof e)return e;if(Array.isArray(e)&&2===e.length){const[t,r]=e;return te.handle(t,r)}throw new Error('Action must be a function or array [Controller, "method"]')}}class se{static _router=new ne;static create(){return ne.create()}static middleware(...e){return this._router.middleware(...e)}static prefix(e){return this._router.prefix(e)}static group(e){return this._router.group(e)}static get(e,...t){return this._router.get(e,...t)}static post(e,...t){return this._router.post(e,...t)}static put(e,...t){return this._router.put(e,...t)}static delete(e,...t){return this._router.delete(e,...t)}static patch(e,...t){return this._router.patch(e,...t)}static options(e,...t){return this._router.options(e,...t)}static getRouter(){return this._router.getRouter()}static mount(e,t="/"){return this._router.mount(e,t)}static reset(){this._router=new ne}}const ie=se;class ae{constructor(e){this.app=e}register(){}boot(){}}function oe(e,t){return new G({...t})}})();var __webpack_export_target__=exports;for(var __webpack_i__ in __webpack_exports__)__webpack_export_target__[__webpack_i__]=__webpack_exports__[__webpack_i__];__webpack_exports__.__esModule&&Object.defineProperty(__webpack_export_target__,"__esModule",{value:!0})})();
2
3
  //# sourceMappingURL=arcanajs.js.map
@@ -0,0 +1,14 @@
1
+ /*! *****************************************************************************
2
+ Copyright (C) Microsoft. All rights reserved.
3
+ Licensed under the Apache License, Version 2.0 (the "License"); you may not use
4
+ this file except in compliance with the License. You may obtain a copy of the
5
+ License at http://www.apache.org/licenses/LICENSE-2.0
6
+
7
+ THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
8
+ KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
9
+ WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
10
+ MERCHANTABLITY OR NON-INFRINGEMENT.
11
+
12
+ See the Apache Version 2.0 License for specific language governing permissions
13
+ and limitations under the License.
14
+ ***************************************************************************** */