@bobtail.software/b-ssr 1.0.39 → 1.0.40

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.
@@ -1 +1 @@
1
- "use strict";var D=Object.create;var F=Object.defineProperty;var O=Object.getOwnPropertyDescriptor;var I=Object.getOwnPropertyNames;var k=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty;var G=(e,t)=>{for(var u in t)F(e,u,{get:t[u],enumerable:!0})},g=(e,t,u,h)=>{if(t&&typeof t=="object"||typeof t=="function")for(let c of I(t))!C.call(e,c)&&c!==u&&F(e,c,{get:()=>t[c],enumerable:!(h=O(t,c))||h.enumerable});return e};var y=(e,t,u)=>(u=e!=null?D(k(e)):{},g(t||!e||!e.__esModule?F(u,"default",{value:e,enumerable:!0}):u,e)),P=e=>g(F({},"__esModule",{value:!0}),e);var A={};G(A,{default:()=>$});module.exports=P(A);var H=require("@fastify/multipart"),E=y(require("fastify-plugin"),1),w=require("fs/promises"),R=y(require("path"),1),T=async(e,t)=>{if(!e.isMultipart())return t.status(415).send({statusCode:415,error:"Unsupported Media Type",message:"Multipart/form-data expected"});let u=e.parts(),h={};for await(let c of u)if(c.type==="field")h[c.fieldname]=c.value;else{let S=Symbol.for("file-stream");e[S]=c}e.body=h},b=async(e,t)=>{let u=r=>{if(t.errorHandler){let a=t.errorHandler(r);if(a)return a}return{message:"Internal Server Error",statusCode:500}};if(e.hasDecorator("viteInitDone")&&e.viteInitDone)return;if(!e.hasDecorator("multipartErrors"))try{let r=await import("@fastify/multipart");await e.register(r.default)}catch(r){if(r.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw r}let h=process.env.NODE_ENV==="production",c;if(h){if(t.clientDistDir){let r=R.default.resolve(t.root,t.clientDistDir);if(t.serveStaticAssets!==!1)try{let l=await import("@fastify/static");await e.register(l.default,{root:r,wildcard:!1}),console.log(`\u{1F4C2} [Fastify-SSR] Plugin is serving static assets from: ${r}`)}catch(l){console.error("\u274C [Fastify-SSR] Error registering @fastify/static. Did you install it?",l)}let a=R.default.resolve(r,".vite/manifest.json");try{c=JSON.parse(await(0,w.readFile)(a,"utf-8"))}catch{let s=R.default.resolve(r,"manifest.json");try{c=JSON.parse(await(0,w.readFile)(s,"utf-8"))}catch{console.error(`\u274C [Fastify-SSR] Failed to load manifest.json from ${a} or ${s}. Client assets will not load.`)}}}}else{if(!e.hasDecorator("use"))try{let s=await import("@fastify/middie");await e.register(s.default,{hook:"onRequest"})}catch(s){if(s.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw s}let r=await import("vite"),a=t.viteConfig||{},l=await r.createServer({root:t.root,appType:"custom",...a,server:{hmr:{port:24678},...a.server,middlewareMode:!0}});e.use(l.middlewares),e.hasDecorator("viteServer")||e.decorate("viteServer",l),console.log("\u{1F680} [Fastify-SSR] Vite Dev Server Ready")}e.decorate("viteInitDone",!0);let S=async(r,a,l)=>{try{let s=r.raw.url;if(R.default.extname(s)!==""){a.status(404).send(`File not found: ${s}`);return}let f="",m="";if(!h&&e.viteServer){let n=await e.viteServer.transformIndexHtml(s,"<html><head></head><body></body></html>");f=n.substring(n.indexOf("<head>")+6,n.indexOf("</head>"))}else if(h&&c){let n=t.devClientEntryFile.startsWith("/")?t.devClientEntryFile.substring(1):t.devClientEntryFile,o=c[n];o?(f+=`<link rel="modulepreload" as="script" crossorigin href="/${o.file}">`,o.css&&o.css.forEach(p=>{f+=`<link rel="stylesheet" href="/${p}">`}),m+=`<script type="module" src="/${o.file}"></script>`):console.error(`\u274C [Fastify-SSR] Entry file "${n}" not found in manifest.json. Keys available: ${Object.keys(c).join(", ")}`)}let d=h?await import(R.default.resolve(t.root,t.prodEntryFile)):await e.viteServer.ssrLoadModule(t.devEntryFile),i=d.render||d.default;if(typeof i!="function")throw new Error(`Entry file ${t.devEntryFile} must export a 'render' function.`);await i({req:r,reply:a,head:f,scripts:m,data:l})}catch(s){e.viteServer?.ssrFixStacktrace(s),console.error("[SSR Error]:",s),a.sent||a.status(500).send("Internal Server Error")}};e.decorate("addRpcRoute",function(r,a){let{handler:l,schema:s,...f}=a,m=`/rpc${r}`,d={...f,schema:s};if(s?.consumes?.includes("multipart/form-data")){let n=d.preValidation;d.preValidation=n?Array.isArray(n)?[T,...n]:[T,n]:T}this.route({method:"POST",url:m,...d,handler:async(n,o)=>{try{let p=await l.call(this,n,o);return o.sent?void 0:p}catch(p){if(console.error(`[RPC Error] ${m}:`,p),!o.sent){let{statusCode:v,message:x}=u(p);o.status(v).send({error:{message:x}})}}}})}),e.decorate("addRenderRoute",function(r,a){let{handler:l,schema:s,...f}=a||{},m=async(d,i,n)=>{try{let o=await l?.call(this,d,i);return n?o:S(d,i,o)}catch(o){if(console.error(`[Render Error] ${r}:`,o),!i.sent){let{statusCode:p,message:v}=u(o);if(n)i.status(p).send({error:{message:v}});else return S(d,i,{ssrError:{statusCode:500,message:"Internal Error"}})}}};if(this.route({method:"GET",url:r,schema:s,...f,handler:(d,i)=>m(d,i,!1)}),r!=="*"&&r!=="/*"){this.route({method:"GET",url:`/loader${r}`,schema:s,...f,handler:(n,o)=>m(n,o,!0)});let d=r.endsWith("/")?"*":"/*",i=`${r}${d}`;this.route({method:"GET",url:i,schema:s,...f,handler:(n,o)=>m(n,o,!1)})}}),e.decorate("addLoaderRoute",function(r,a){let{handler:l,schema:s,...f}=a,m=`/api${r}`;this.route({method:"GET",url:m,schema:s,...f,handler:async(d,i)=>{try{let n=await l.call(this,d,i);return i.sent?void 0:n}catch(n){if(console.error(`[Loader API Error] ${m}:`,n),!i.sent){let{statusCode:o,message:p}=u(n);i.status(o).send({error:{message:p}})}}}})})},$=(0,E.default)(b,{name:"fastify-b-ssr"});
1
+ "use strict";var O=Object.create;var v=Object.defineProperty;var D=Object.getOwnPropertyDescriptor;var I=Object.getOwnPropertyNames;var k=Object.getPrototypeOf,C=Object.prototype.hasOwnProperty;var G=(e,t)=>{for(var l in t)v(e,l,{get:t[l],enumerable:!0})},w=(e,t,l,p)=>{if(t&&typeof t=="object"||typeof t=="function")for(let d of I(t))!C.call(e,d)&&d!==l&&v(e,d,{get:()=>t[d],enumerable:!(p=D(t,d))||p.enumerable});return e};var y=(e,t,l)=>(l=e!=null?O(k(e)):{},w(t||!e||!e.__esModule?v(l,"default",{value:e,enumerable:!0}):l,e)),P=e=>w(v({},"__esModule",{value:!0}),e);var b={};G(b,{default:()=>$});module.exports=P(b);var M=require("@fastify/multipart"),E=y(require("fastify-plugin"),1),T=require("fs/promises"),R=y(require("path"),1),g=async(e,t)=>{if(!e.isMultipart())return t.status(415).send({statusCode:415,error:"Unsupported Media Type",message:"Multipart/form-data expected"});let l=e.parts(),p={};for await(let d of l)if(d.type==="field")p[d.fieldname]=d.value;else{let F=Symbol.for("file-stream");e[F]=d}e.body=p},A=async(e,t)=>{let l=r=>{if(t.errorHandler){let a=t.errorHandler(r);if(a)return a}return{message:"Internal Server Error",statusCode:500}};if(e.hasDecorator("viteInitDone")&&e.viteInitDone)return;if(!e.hasDecorator("multipartErrors"))try{let r=await import("@fastify/multipart");await e.register(r.default)}catch(r){if(r.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw r}let p=process.env.NODE_ENV==="production",d;if(p){if(t.clientDistDir){let r=R.default.resolve(t.root,t.clientDistDir);if(t.serveStaticAssets!==!1)try{let u=await import("@fastify/static");await e.register(u.default,{root:r,wildcard:!1}),console.log(`\u{1F4C2} [Fastify-SSR] Plugin is serving static assets from: ${r}`)}catch(u){console.error("\u274C [Fastify-SSR] Error registering @fastify/static. Did you install it?",u)}let a=R.default.resolve(r,".vite/manifest.json");try{d=JSON.parse(await(0,T.readFile)(a,"utf-8"))}catch{let s=R.default.resolve(r,"manifest.json");try{d=JSON.parse(await(0,T.readFile)(s,"utf-8"))}catch{console.error(`\u274C [Fastify-SSR] Failed to load manifest.json from ${a} or ${s}. Client assets will not load.`)}}}}else{if(!e.hasDecorator("use"))try{let s=await import("@fastify/middie");await e.register(s.default,{hook:"onRequest"})}catch(s){if(s.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw s}let r=await import("vite"),a=t.viteConfig||{},u=await r.createServer({root:t.root,appType:"custom",...a,server:{hmr:{port:24678},...a.server,middlewareMode:!0}});e.use(u.middlewares),e.hasDecorator("viteServer")||e.decorate("viteServer",u),console.log("\u{1F680} [Fastify-SSR] Vite Dev Server Ready")}e.decorate("viteInitDone",!0);let F=async(r,a,u)=>{try{let s=r.raw.url;if(R.default.extname(s)!==""){a.status(404).send(`File not found: ${s}`);return}let m=[],h=[],c="";if(!p&&e.viteServer){let n=await e.viteServer.transformIndexHtml(s,"<html><head></head><body></body></html>");c=n.substring(n.indexOf("<head>")+6,n.indexOf("</head>"))}else if(p&&d){let n=t.devClientEntryFile.startsWith("/")?t.devClientEntryFile.substring(1):t.devClientEntryFile,f=d[n];f?(m.push({rel:"modulepreload",as:"script",crossOrigin:"",href:`/${f.file}`}),f.css&&f.css.forEach(S=>{m.push({rel:"stylesheet",href:`/${S}`})}),h.push({type:"module",src:`/${f.file}`})):console.error(`\u274C [Fastify-SSR] Entry "${n}" not found in manifest.`)}let i=p?await import(R.default.resolve(t.root,t.prodEntryFile)):await e.viteServer.ssrLoadModule(t.devEntryFile),o=i.render||i.default;if(typeof o!="function")throw new Error(`Entry file ${t.devEntryFile} must export a 'render' function.`);await o({req:r,reply:a,head:c,manifestLinks:m,manifestScripts:h,data:u})}catch(s){e.viteServer?.ssrFixStacktrace(s),console.error("[SSR Error]:",s),a.sent||a.status(500).send("Internal Server Error")}};e.decorate("addRpcRoute",function(r,a){let{handler:u,schema:s,...m}=a,h=`/rpc${r}`,c={...m,schema:s};if(s?.consumes?.includes("multipart/form-data")){let o=c.preValidation;c.preValidation=o?Array.isArray(o)?[g,...o]:[g,o]:g}this.route({method:"POST",url:h,...c,handler:async(o,n)=>{try{let f=await u.call(this,o,n);return n.sent?void 0:f}catch(f){if(console.error(`[RPC Error] ${h}:`,f),!n.sent){let{statusCode:S,message:x}=l(f);n.status(S).send({error:{message:x}})}}}})}),e.decorate("addRenderRoute",function(r,a){let{handler:u,schema:s,...m}=a||{},h=async(c,i,o)=>{try{let n=await u?.call(this,c,i);return o?n:F(c,i,n)}catch(n){if(console.error(`[Render Error] ${r}:`,n),!i.sent){let{statusCode:f,message:S}=l(n);if(o)i.status(f).send({error:{message:S}});else return F(c,i,{ssrError:{statusCode:500,message:"Internal Error"}})}}};if(this.route({method:"GET",url:r,schema:s,...m,handler:(c,i)=>h(c,i,!1)}),r!=="*"&&r!=="/*"){this.route({method:"GET",url:`/loader${r}`,schema:s,...m,handler:(o,n)=>h(o,n,!0)});let c=r.endsWith("/")?"*":"/*",i=`${r}${c}`;this.route({method:"GET",url:i,schema:s,...m,handler:(o,n)=>h(o,n,!1)})}}),e.decorate("addLoaderRoute",function(r,a){let{handler:u,schema:s,...m}=a,h=`/api${r}`;this.route({method:"GET",url:h,schema:s,...m,handler:async(c,i)=>{try{let o=await u.call(this,c,i);return i.sent?void 0:o}catch(o){if(console.error(`[Loader API Error] ${h}:`,o),!i.sent){let{statusCode:n,message:f}=l(o);i.status(n).send({error:{message:f}})}}}})})},$=(0,E.default)(A,{name:"fastify-b-ssr"});
@@ -1 +1 @@
1
- import"@fastify/multipart";import w from"fastify-plugin";import{readFile as v}from"fs/promises";import y from"path";var F=async(r,i)=>{if(!r.isMultipart())return i.status(415).send({statusCode:415,error:"Unsupported Media Type",message:"Multipart/form-data expected"});let p=r.parts(),h={};for await(let f of p)if(f.type==="field")h[f.fieldname]=f.value;else{let R=Symbol.for("file-stream");r[R]=f}r.body=h},g=async(r,i)=>{let p=e=>{if(i.errorHandler){let o=i.errorHandler(e);if(o)return o}return{message:"Internal Server Error",statusCode:500}};if(r.hasDecorator("viteInitDone")&&r.viteInitDone)return;if(!r.hasDecorator("multipartErrors"))try{let e=await import("@fastify/multipart");await r.register(e.default)}catch(e){if(e.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw e}let h=process.env.NODE_ENV==="production",f;if(h){if(i.clientDistDir){let e=y.resolve(i.root,i.clientDistDir);if(i.serveStaticAssets!==!1)try{let d=await import("@fastify/static");await r.register(d.default,{root:e,wildcard:!1}),console.log(`\u{1F4C2} [Fastify-SSR] Plugin is serving static assets from: ${e}`)}catch(d){console.error("\u274C [Fastify-SSR] Error registering @fastify/static. Did you install it?",d)}let o=y.resolve(e,".vite/manifest.json");try{f=JSON.parse(await v(o,"utf-8"))}catch{let n=y.resolve(e,"manifest.json");try{f=JSON.parse(await v(n,"utf-8"))}catch{console.error(`\u274C [Fastify-SSR] Failed to load manifest.json from ${o} or ${n}. Client assets will not load.`)}}}}else{if(!r.hasDecorator("use"))try{let n=await import("@fastify/middie");await r.register(n.default,{hook:"onRequest"})}catch(n){if(n.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw n}let e=await import("vite"),o=i.viteConfig||{},d=await e.createServer({root:i.root,appType:"custom",...o,server:{hmr:{port:24678},...o.server,middlewareMode:!0}});r.use(d.middlewares),r.hasDecorator("viteServer")||r.decorate("viteServer",d),console.log("\u{1F680} [Fastify-SSR] Vite Dev Server Ready")}r.decorate("viteInitDone",!0);let R=async(e,o,d)=>{try{let n=e.raw.url;if(y.extname(n)!==""){o.status(404).send(`File not found: ${n}`);return}let l="",u="";if(!h&&r.viteServer){let t=await r.viteServer.transformIndexHtml(n,"<html><head></head><body></body></html>");l=t.substring(t.indexOf("<head>")+6,t.indexOf("</head>"))}else if(h&&f){let t=i.devClientEntryFile.startsWith("/")?i.devClientEntryFile.substring(1):i.devClientEntryFile,s=f[t];s?(l+=`<link rel="modulepreload" as="script" crossorigin href="/${s.file}">`,s.css&&s.css.forEach(m=>{l+=`<link rel="stylesheet" href="/${m}">`}),u+=`<script type="module" src="/${s.file}"></script>`):console.error(`\u274C [Fastify-SSR] Entry file "${t}" not found in manifest.json. Keys available: ${Object.keys(f).join(", ")}`)}let c=h?await import(y.resolve(i.root,i.prodEntryFile)):await r.viteServer.ssrLoadModule(i.devEntryFile),a=c.render||c.default;if(typeof a!="function")throw new Error(`Entry file ${i.devEntryFile} must export a 'render' function.`);await a({req:e,reply:o,head:l,scripts:u,data:d})}catch(n){r.viteServer?.ssrFixStacktrace(n),console.error("[SSR Error]:",n),o.sent||o.status(500).send("Internal Server Error")}};r.decorate("addRpcRoute",function(e,o){let{handler:d,schema:n,...l}=o,u=`/rpc${e}`,c={...l,schema:n};if(n?.consumes?.includes("multipart/form-data")){let t=c.preValidation;c.preValidation=t?Array.isArray(t)?[F,...t]:[F,t]:F}this.route({method:"POST",url:u,...c,handler:async(t,s)=>{try{let m=await d.call(this,t,s);return s.sent?void 0:m}catch(m){if(console.error(`[RPC Error] ${u}:`,m),!s.sent){let{statusCode:S,message:T}=p(m);s.status(S).send({error:{message:T}})}}}})}),r.decorate("addRenderRoute",function(e,o){let{handler:d,schema:n,...l}=o||{},u=async(c,a,t)=>{try{let s=await d?.call(this,c,a);return t?s:R(c,a,s)}catch(s){if(console.error(`[Render Error] ${e}:`,s),!a.sent){let{statusCode:m,message:S}=p(s);if(t)a.status(m).send({error:{message:S}});else return R(c,a,{ssrError:{statusCode:500,message:"Internal Error"}})}}};if(this.route({method:"GET",url:e,schema:n,...l,handler:(c,a)=>u(c,a,!1)}),e!=="*"&&e!=="/*"){this.route({method:"GET",url:`/loader${e}`,schema:n,...l,handler:(t,s)=>u(t,s,!0)});let c=e.endsWith("/")?"*":"/*",a=`${e}${c}`;this.route({method:"GET",url:a,schema:n,...l,handler:(t,s)=>u(t,s,!1)})}}),r.decorate("addLoaderRoute",function(e,o){let{handler:d,schema:n,...l}=o,u=`/api${e}`;this.route({method:"GET",url:u,schema:n,...l,handler:async(c,a)=>{try{let t=await d.call(this,c,a);return a.sent?void 0:t}catch(t){if(console.error(`[Loader API Error] ${u}:`,t),!a.sent){let{statusCode:s,message:m}=p(t);a.status(s).send({error:{message:m}})}}}})})},I=w(g,{name:"fastify-b-ssr"});export{I as default};
1
+ import"@fastify/multipart";import T from"fastify-plugin";import{readFile as v}from"fs/promises";import R from"path";var F=async(t,i)=>{if(!t.isMultipart())return i.status(415).send({statusCode:415,error:"Unsupported Media Type",message:"Multipart/form-data expected"});let p=t.parts(),h={};for await(let m of p)if(m.type==="field")h[m.fieldname]=m.value;else{let S=Symbol.for("file-stream");t[S]=m}t.body=h},w=async(t,i)=>{let p=e=>{if(i.errorHandler){let o=i.errorHandler(e);if(o)return o}return{message:"Internal Server Error",statusCode:500}};if(t.hasDecorator("viteInitDone")&&t.viteInitDone)return;if(!t.hasDecorator("multipartErrors"))try{let e=await import("@fastify/multipart");await t.register(e.default)}catch(e){if(e.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw e}let h=process.env.NODE_ENV==="production",m;if(h){if(i.clientDistDir){let e=R.resolve(i.root,i.clientDistDir);if(i.serveStaticAssets!==!1)try{let d=await import("@fastify/static");await t.register(d.default,{root:e,wildcard:!1}),console.log(`\u{1F4C2} [Fastify-SSR] Plugin is serving static assets from: ${e}`)}catch(d){console.error("\u274C [Fastify-SSR] Error registering @fastify/static. Did you install it?",d)}let o=R.resolve(e,".vite/manifest.json");try{m=JSON.parse(await v(o,"utf-8"))}catch{let r=R.resolve(e,"manifest.json");try{m=JSON.parse(await v(r,"utf-8"))}catch{console.error(`\u274C [Fastify-SSR] Failed to load manifest.json from ${o} or ${r}. Client assets will not load.`)}}}}else{if(!t.hasDecorator("use"))try{let r=await import("@fastify/middie");await t.register(r.default,{hook:"onRequest"})}catch(r){if(r.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw r}let e=await import("vite"),o=i.viteConfig||{},d=await e.createServer({root:i.root,appType:"custom",...o,server:{hmr:{port:24678},...o.server,middlewareMode:!0}});t.use(d.middlewares),t.hasDecorator("viteServer")||t.decorate("viteServer",d),console.log("\u{1F680} [Fastify-SSR] Vite Dev Server Ready")}t.decorate("viteInitDone",!0);let S=async(e,o,d)=>{try{let r=e.raw.url;if(R.extname(r)!==""){o.status(404).send(`File not found: ${r}`);return}let l=[],f=[],c="";if(!h&&t.viteServer){let s=await t.viteServer.transformIndexHtml(r,"<html><head></head><body></body></html>");c=s.substring(s.indexOf("<head>")+6,s.indexOf("</head>"))}else if(h&&m){let s=i.devClientEntryFile.startsWith("/")?i.devClientEntryFile.substring(1):i.devClientEntryFile,u=m[s];u?(l.push({rel:"modulepreload",as:"script",crossOrigin:"",href:`/${u.file}`}),u.css&&u.css.forEach(y=>{l.push({rel:"stylesheet",href:`/${y}`})}),f.push({type:"module",src:`/${u.file}`})):console.error(`\u274C [Fastify-SSR] Entry "${s}" not found in manifest.`)}let a=h?await import(R.resolve(i.root,i.prodEntryFile)):await t.viteServer.ssrLoadModule(i.devEntryFile),n=a.render||a.default;if(typeof n!="function")throw new Error(`Entry file ${i.devEntryFile} must export a 'render' function.`);await n({req:e,reply:o,head:c,manifestLinks:l,manifestScripts:f,data:d})}catch(r){t.viteServer?.ssrFixStacktrace(r),console.error("[SSR Error]:",r),o.sent||o.status(500).send("Internal Server Error")}};t.decorate("addRpcRoute",function(e,o){let{handler:d,schema:r,...l}=o,f=`/rpc${e}`,c={...l,schema:r};if(r?.consumes?.includes("multipart/form-data")){let n=c.preValidation;c.preValidation=n?Array.isArray(n)?[F,...n]:[F,n]:F}this.route({method:"POST",url:f,...c,handler:async(n,s)=>{try{let u=await d.call(this,n,s);return s.sent?void 0:u}catch(u){if(console.error(`[RPC Error] ${f}:`,u),!s.sent){let{statusCode:y,message:g}=p(u);s.status(y).send({error:{message:g}})}}}})}),t.decorate("addRenderRoute",function(e,o){let{handler:d,schema:r,...l}=o||{},f=async(c,a,n)=>{try{let s=await d?.call(this,c,a);return n?s:S(c,a,s)}catch(s){if(console.error(`[Render Error] ${e}:`,s),!a.sent){let{statusCode:u,message:y}=p(s);if(n)a.status(u).send({error:{message:y}});else return S(c,a,{ssrError:{statusCode:500,message:"Internal Error"}})}}};if(this.route({method:"GET",url:e,schema:r,...l,handler:(c,a)=>f(c,a,!1)}),e!=="*"&&e!=="/*"){this.route({method:"GET",url:`/loader${e}`,schema:r,...l,handler:(n,s)=>f(n,s,!0)});let c=e.endsWith("/")?"*":"/*",a=`${e}${c}`;this.route({method:"GET",url:a,schema:r,...l,handler:(n,s)=>f(n,s,!1)})}}),t.decorate("addLoaderRoute",function(e,o){let{handler:d,schema:r,...l}=o,f=`/api${e}`;this.route({method:"GET",url:f,schema:r,...l,handler:async(c,a)=>{try{let n=await d.call(this,c,a);return a.sent?void 0:n}catch(n){if(console.error(`[Loader API Error] ${f}:`,n),!a.sent){let{statusCode:s,message:u}=p(n);a.status(s).send({error:{message:u}})}}}})})},I=T(w,{name:"fastify-b-ssr"});export{I as default};
@@ -1 +1 @@
1
- "use strict";var h=Object.defineProperty;var y=Object.getOwnPropertyDescriptor;var l=Object.getOwnPropertyNames;var m=Object.prototype.hasOwnProperty;var q=(e,t)=>{for(var r in t)h(e,r,{get:t[r],enumerable:!0})},F=(e,t,r,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of l(t))!m.call(e,n)&&n!==r&&h(e,n,{get:()=>t[n],enumerable:!(s=y(t,n))||s.enumerable});return e};var g=e=>F(h({},"__esModule",{value:!0}),e);var v={};q(v,{createServerHandler:()=>x});module.exports=g(v);var i=require("@tanstack/react-router/ssr/server"),p=require("react/jsx-runtime");function w(e){let t=e.protocol,r=e.hostname,s=`${t}://${r}`,n=new URL(e.url,s||"http://localhost:3000").href,u=new Headers;for(let[d,a]of Object.entries(e.headers))a&&u.set(d,Array.isArray(a)?a.join(", "):a);return new Request(n,{method:e.method,headers:u})}function x(e){return async function({req:r,reply:s,head:n,data:u,scripts:d}){let a=w(r),f=await(0,i.createRequestHandler)({request:a,createRouter:()=>{let o=e(),c=o.options.context||{};return o.update({context:{...c,head:n,scripts:d,req:r,reply:s,loaderData:u}}),o}})(({request:o,responseHeaders:c,router:R})=>(0,i.renderRouterToStream)({request:o,responseHeaders:c,router:R,children:(0,p.jsx)(i.RouterServer,{router:R})}));return s.status(f.status),f.headers.forEach((o,c)=>{s.header(c,o)}),s.send(f.body)}}0&&(module.exports={createServerHandler});
1
+ "use strict";var p=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var m=Object.getOwnPropertyNames;var y=Object.prototype.hasOwnProperty;var H=(e,t)=>{for(var r in t)p(e,r,{get:t[r],enumerable:!0})},T=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of m(t))!y.call(e,s)&&s!==r&&p(e,s,{get:()=>t[s],enumerable:!(n=R(t,s))||n.enumerable});return e};var M=e=>T(p({},"__esModule",{value:!0}),e);var q={};H(q,{createServerHandler:()=>k});module.exports=M(q);var a=require("@tanstack/react-router/ssr/server"),h=require("react/jsx-runtime");function S(e){let t=e.protocol,r=e.hostname,n=`${t}://${r}`,s=new URL(e.url,n||"http://localhost:3000").href,c=new Headers;for(let[d,i]of Object.entries(e.headers))i&&c.set(d,Array.isArray(i)?i.join(", "):i);return new Request(s,{method:e.method,headers:c})}function k(e){return async function({req:r,reply:n,manifestLinks:s=[],manifestScripts:c=[],head:d,data:i}){let L=S(r),f=await(0,a.createRequestHandler)({request:L,createRouter:()=>{let o=e(),u=o.options.context||{};return o.update({context:{...u,head:d,manifestLinks:s,manifestScripts:c,req:r,reply:n,loaderData:i}}),o}})(({request:o,responseHeaders:u,router:l})=>(0,a.renderRouterToStream)({request:o,responseHeaders:u,router:l,children:(0,h.jsx)(a.RouterServer,{router:l})}));return n.status(f.status),f.headers.forEach((o,u)=>{n.header(u,o)}),n.send(f.body)}}0&&(module.exports={createServerHandler});
@@ -1,10 +1,12 @@
1
1
  import { FastifyRequest, FastifyReply } from 'fastify';
2
+ import { DetailedHTMLProps, LinkHTMLAttributes, ScriptHTMLAttributes } from 'react';
2
3
 
3
4
  interface RenderOptions {
4
5
  req: FastifyRequest;
5
6
  reply: FastifyReply;
6
- head: string;
7
- scripts?: string;
7
+ head?: string;
8
+ manifestLinks?: (DetailedHTMLProps<LinkHTMLAttributes<HTMLLinkElement>, HTMLLinkElement> | undefined)[];
9
+ manifestScripts?: (DetailedHTMLProps<ScriptHTMLAttributes<HTMLScriptElement>, HTMLScriptElement> | undefined)[];
8
10
  data?: unknown;
9
11
  }
10
12
  /**
@@ -13,6 +15,6 @@ interface RenderOptions {
13
15
  * @param createRouterFn Función que devuelve una instancia del Router
14
16
  * @returns Una función `render` lista para ser exportada en entry-server.tsx
15
17
  */
16
- declare function createServerHandler(createRouterFn: () => any): ({ req, reply, head, data, scripts }: RenderOptions) => Promise<never>;
18
+ declare function createServerHandler(createRouterFn: () => any): ({ req, reply, manifestLinks, manifestScripts, head, data, }: RenderOptions) => Promise<never>;
17
19
 
18
20
  export { type RenderOptions, createServerHandler };
@@ -1,10 +1,12 @@
1
1
  import { FastifyRequest, FastifyReply } from 'fastify';
2
+ import { DetailedHTMLProps, LinkHTMLAttributes, ScriptHTMLAttributes } from 'react';
2
3
 
3
4
  interface RenderOptions {
4
5
  req: FastifyRequest;
5
6
  reply: FastifyReply;
6
- head: string;
7
- scripts?: string;
7
+ head?: string;
8
+ manifestLinks?: (DetailedHTMLProps<LinkHTMLAttributes<HTMLLinkElement>, HTMLLinkElement> | undefined)[];
9
+ manifestScripts?: (DetailedHTMLProps<ScriptHTMLAttributes<HTMLScriptElement>, HTMLScriptElement> | undefined)[];
8
10
  data?: unknown;
9
11
  }
10
12
  /**
@@ -13,6 +15,6 @@ interface RenderOptions {
13
15
  * @param createRouterFn Función que devuelve una instancia del Router
14
16
  * @returns Una función `render` lista para ser exportada en entry-server.tsx
15
17
  */
16
- declare function createServerHandler(createRouterFn: () => any): ({ req, reply, head, data, scripts }: RenderOptions) => Promise<never>;
18
+ declare function createServerHandler(createRouterFn: () => any): ({ req, reply, manifestLinks, manifestScripts, head, data, }: RenderOptions) => Promise<never>;
17
19
 
18
20
  export { type RenderOptions, createServerHandler };
@@ -1 +1 @@
1
- import{createRequestHandler as h,renderRouterToStream as R,RouterServer as p}from"@tanstack/react-router/ssr/server";import{jsx as l}from"react/jsx-runtime";function y(e){let d=e.protocol,o=e.hostname,r=`${d}://${o}`,i=new URL(e.url,r||"http://localhost:3000").href,a=new Headers;for(let[c,s]of Object.entries(e.headers))s&&a.set(c,Array.isArray(s)?s.join(", "):s);return new Request(i,{method:e.method,headers:a})}function F(e){return async function({req:o,reply:r,head:i,data:a,scripts:c}){let s=y(o),u=await h({request:s,createRouter:()=>{let t=e(),n=t.options.context||{};return t.update({context:{...n,head:i,scripts:c,req:o,reply:r,loaderData:a}}),t}})(({request:t,responseHeaders:n,router:f})=>R({request:t,responseHeaders:n,router:f,children:l(p,{router:f})}));return r.status(u.status),u.headers.forEach((t,n)=>{r.header(n,t)}),r.send(u.body)}}export{F as createServerHandler};
1
+ import{createRequestHandler as l,renderRouterToStream as h,RouterServer as L}from"@tanstack/react-router/ssr/server";import{jsx as m}from"react/jsx-runtime";function R(e){let d=e.protocol,o=e.hostname,r=`${d}://${o}`,a=new URL(e.url,r||"http://localhost:3000").href,i=new Headers;for(let[u,n]of Object.entries(e.headers))n&&i.set(u,Array.isArray(n)?n.join(", "):n);return new Request(a,{method:e.method,headers:i})}function T(e){return async function({req:o,reply:r,manifestLinks:a=[],manifestScripts:i=[],head:u,data:n}){let p=R(o),c=await l({request:p,createRouter:()=>{let t=e(),s=t.options.context||{};return t.update({context:{...s,head:u,manifestLinks:a,manifestScripts:i,req:o,reply:r,loaderData:n}}),t}})(({request:t,responseHeaders:s,router:f})=>h({request:t,responseHeaders:s,router:f,children:m(L,{router:f})}));return r.status(c.status),c.headers.forEach((t,s)=>{r.header(s,t)}),r.send(c.body)}}export{T as createServerHandler};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bobtail.software/b-ssr",
3
- "version": "1.0.39",
3
+ "version": "1.0.40",
4
4
  "description": "Fastify + Vite SSR Plugin wrapper with RPC",
5
5
  "author": "Victor Moreno <info@bobtail.software> (https://bobtail.software)",
6
6
  "license": "GPL-3.0",