@bobtail.software/b-ssr 1.0.36 → 1.0.38
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
|
|
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 p=(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 $={};G($,{default:()=>A});module.exports=P($);var H=require("@fastify/multipart"),E=p(require("fastify-plugin"),1),w=require("fs/promises"),R=p(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 o=t.errorHandler(r);if(o)return o}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 o=R.default.resolve(r,".vite/manifest.json");try{c=JSON.parse(await(0,w.readFile)(o,"utf-8"))}catch{let n=R.default.resolve(r,"manifest.json");try{c=JSON.parse(await(0,w.readFile)(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(!e.hasDecorator("use"))try{let n=await import("@fastify/middie");await e.register(n.default,{hook:"onRequest"})}catch(n){if(n.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw n}let r=await import("vite"),o=t.viteConfig||{},l=await r.createServer({root:t.root,appType:"custom",...o,server:{hmr:{port:24678},...o.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,o,l)=>{try{let n=r.raw.url;if(R.default.extname(n)!==""){o.status(404).send(`File not found: ${n}`);return}let f="";if(!h&&e.viteServer){let a=await e.viteServer.transformIndexHtml(n,"<html><head></head><body></body></html>");f=a.substring(a.indexOf("<head>")+6,a.indexOf("</head>"))}else if(h&&c){let a=t.devClientEntryFile.startsWith("/")?t.devClientEntryFile.substring(1):t.devClientEntryFile,s=c[a];s?(f+=`<script type="module" crossorigin src="/${s.file}"></script>`,s.css&&s.css.forEach(i=>{f+=`<link rel="stylesheet" href="/${i}">`})):console.error(`\u274C [Fastify-SSR] Entry file "${a}" not found in manifest.json. Keys available: ${Object.keys(c).join(", ")}`)}let m=h?await import(R.default.resolve(t.root,t.prodEntryFile)):await e.viteServer.ssrLoadModule(t.devEntryFile),d=m.render||m.default;if(typeof d!="function")throw new Error(`Entry file ${t.devEntryFile} must export a 'render' function.`);await d({req:r,reply:o,head:f,data:l})}catch(n){e.viteServer?.ssrFixStacktrace(n),console.error("[SSR Error]:",n),o.sent||o.status(500).send("Internal Server Error")}};e.decorate("addRpcRoute",function(r,o){let{handler:l,schema:n,...f}=o,m=`/rpc${r}`,d={...f,schema:n};if(n?.consumes?.includes("multipart/form-data")){let s=d.preValidation;d.preValidation=s?Array.isArray(s)?[T,...s]:[T,s]:T}this.route({method:"POST",url:m,...d,handler:async(s,i)=>{try{let y=await l.call(this,s,i);return i.sent?void 0:y}catch(y){if(console.error(`[RPC Error] ${m}:`,y),!i.sent){let{statusCode:v,message:x}=u(y);i.status(v).send({error:{message:x}})}}}})}),e.decorate("addRenderRoute",function(r,o){let{handler:l,schema:n,...f}=o||{},m=async(d,a,s)=>{try{let i=await l?.call(this,d,a);return s?i:S(d,a,i)}catch(i){if(console.error(`[Render Error] ${r}:`,i),!a.sent){let{statusCode:y,message:v}=u(i);if(s)a.status(y).send({error:{message:v}});else return S(d,a,{ssrError:{statusCode:500,message:"Internal Error"}})}}};if(this.route({method:"GET",url:r,schema:n,...f,handler:(d,a)=>m(d,a,!1)}),r!=="*"&&r!=="/*"){this.route({method:"GET",url:`/loader${r}`,schema:n,...f,handler:(s,i)=>m(s,i,!0)});let d=r.endsWith("/")?"*":"/*",a=`${r}${d}`;this.route({method:"GET",url:a,schema:n,...f,handler:(s,i)=>m(s,i,!1)})}}),e.decorate("addLoaderRoute",function(r,o){let{handler:l,schema:n,...f}=o,m=`/api${r}`;this.route({method:"GET",url:m,schema:n,...f,handler:async(d,a)=>{try{let s=await l.call(this,d,a);return a.sent?void 0:s}catch(s){if(console.error(`[Loader API Error] ${m}:`,s),!a.sent){let{statusCode:i,message:y}=u(s);a.status(i).send({error:{message:y}})}}}})})},A=(0,E.default)(b,{name:"fastify-b-ssr"});
|
|
@@ -30,8 +30,20 @@ interface FastifyReactSsrOptions {
|
|
|
30
30
|
root: string;
|
|
31
31
|
/** Ruta al archivo de entrada SSR en desarrollo (ej: '/src/entry-ssr-server.tsx') */
|
|
32
32
|
devEntryFile: string;
|
|
33
|
-
/** Ruta
|
|
33
|
+
/** Ruta al archivo de entrada del CLIENTE en desarrollo (ej: '/src-ts/entry-client.tsx') */
|
|
34
|
+
devClientEntryFile: string;
|
|
35
|
+
/** Ruta relativa al archivo compilado del servidor SSR en producción (ej: './dist-react/server/entry-server.mjs') */
|
|
34
36
|
prodEntryFile: string;
|
|
37
|
+
/**
|
|
38
|
+
* Ruta relativa a la carpeta de salida del cliente en producción (ej: './dist-react/client').
|
|
39
|
+
* Requerido para servir assets (CSS, JS) en producción.
|
|
40
|
+
*/
|
|
41
|
+
clientDistDir?: string;
|
|
42
|
+
/**
|
|
43
|
+
* Si es `true` (por defecto), el plugin registrará @fastify/static para servir los assets del cliente.
|
|
44
|
+
* Ponlo en `false` si ya estás sirviendo la carpeta de assets manualmente.
|
|
45
|
+
*/
|
|
46
|
+
serveStaticAssets?: boolean;
|
|
35
47
|
/** Configuración extra para Vite (opcional) */
|
|
36
48
|
viteConfig?: InlineConfig;
|
|
37
49
|
/** Manejador de errores personalizado */
|
|
@@ -30,8 +30,20 @@ interface FastifyReactSsrOptions {
|
|
|
30
30
|
root: string;
|
|
31
31
|
/** Ruta al archivo de entrada SSR en desarrollo (ej: '/src/entry-ssr-server.tsx') */
|
|
32
32
|
devEntryFile: string;
|
|
33
|
-
/** Ruta
|
|
33
|
+
/** Ruta al archivo de entrada del CLIENTE en desarrollo (ej: '/src-ts/entry-client.tsx') */
|
|
34
|
+
devClientEntryFile: string;
|
|
35
|
+
/** Ruta relativa al archivo compilado del servidor SSR en producción (ej: './dist-react/server/entry-server.mjs') */
|
|
34
36
|
prodEntryFile: string;
|
|
37
|
+
/**
|
|
38
|
+
* Ruta relativa a la carpeta de salida del cliente en producción (ej: './dist-react/client').
|
|
39
|
+
* Requerido para servir assets (CSS, JS) en producción.
|
|
40
|
+
*/
|
|
41
|
+
clientDistDir?: string;
|
|
42
|
+
/**
|
|
43
|
+
* Si es `true` (por defecto), el plugin registrará @fastify/static para servir los assets del cliente.
|
|
44
|
+
* Ponlo en `false` si ya estás sirviendo la carpeta de assets manualmente.
|
|
45
|
+
*/
|
|
46
|
+
serveStaticAssets?: boolean;
|
|
35
47
|
/** Configuración extra para Vite (opcional) */
|
|
36
48
|
viteConfig?: InlineConfig;
|
|
37
49
|
/** Manejador de errores personalizado */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import"@fastify/multipart";import
|
|
1
|
+
import"@fastify/multipart";import w from"fastify-plugin";import{readFile as v}from"fs/promises";import p 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 y=t.parts(),h={};for await(let f of y)if(f.type==="field")h[f.fieldname]=f.value;else{let R=Symbol.for("file-stream");t[R]=f}t.body=h},g=async(t,i)=>{let y=e=>{if(i.errorHandler){let a=i.errorHandler(e);if(a)return a}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",f;if(h){if(i.clientDistDir){let e=p.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 a=p.resolve(e,".vite/manifest.json");try{f=JSON.parse(await v(a,"utf-8"))}catch{let r=p.resolve(e,"manifest.json");try{f=JSON.parse(await v(r,"utf-8"))}catch{console.error(`\u274C [Fastify-SSR] Failed to load manifest.json from ${a} 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"),a=i.viteConfig||{},d=await e.createServer({root:i.root,appType:"custom",...a,server:{hmr:{port:24678},...a.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 R=async(e,a,d)=>{try{let r=e.raw.url;if(p.extname(r)!==""){a.status(404).send(`File not found: ${r}`);return}let l="";if(!h&&t.viteServer){let s=await t.viteServer.transformIndexHtml(r,"<html><head></head><body></body></html>");l=s.substring(s.indexOf("<head>")+6,s.indexOf("</head>"))}else if(h&&f){let s=i.devClientEntryFile.startsWith("/")?i.devClientEntryFile.substring(1):i.devClientEntryFile,n=f[s];n?(l+=`<script type="module" crossorigin src="/${n.file}"></script>`,n.css&&n.css.forEach(o=>{l+=`<link rel="stylesheet" href="/${o}">`})):console.error(`\u274C [Fastify-SSR] Entry file "${s}" not found in manifest.json. Keys available: ${Object.keys(f).join(", ")}`)}let u=h?await import(p.resolve(i.root,i.prodEntryFile)):await t.viteServer.ssrLoadModule(i.devEntryFile),c=u.render||u.default;if(typeof c!="function")throw new Error(`Entry file ${i.devEntryFile} must export a 'render' function.`);await c({req:e,reply:a,head:l,data:d})}catch(r){t.viteServer?.ssrFixStacktrace(r),console.error("[SSR Error]:",r),a.sent||a.status(500).send("Internal Server Error")}};t.decorate("addRpcRoute",function(e,a){let{handler:d,schema:r,...l}=a,u=`/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:u,...c,handler:async(n,o)=>{try{let m=await d.call(this,n,o);return o.sent?void 0:m}catch(m){if(console.error(`[RPC Error] ${u}:`,m),!o.sent){let{statusCode:S,message:T}=y(m);o.status(S).send({error:{message:T}})}}}})}),t.decorate("addRenderRoute",function(e,a){let{handler:d,schema:r,...l}=a||{},u=async(c,s,n)=>{try{let o=await d?.call(this,c,s);return n?o:R(c,s,o)}catch(o){if(console.error(`[Render Error] ${e}:`,o),!s.sent){let{statusCode:m,message:S}=y(o);if(n)s.status(m).send({error:{message:S}});else return R(c,s,{ssrError:{statusCode:500,message:"Internal Error"}})}}};if(this.route({method:"GET",url:e,schema:r,...l,handler:(c,s)=>u(c,s,!1)}),e!=="*"&&e!=="/*"){this.route({method:"GET",url:`/loader${e}`,schema:r,...l,handler:(n,o)=>u(n,o,!0)});let c=e.endsWith("/")?"*":"/*",s=`${e}${c}`;this.route({method:"GET",url:s,schema:r,...l,handler:(n,o)=>u(n,o,!1)})}}),t.decorate("addLoaderRoute",function(e,a){let{handler:d,schema:r,...l}=a,u=`/api${e}`;this.route({method:"GET",url:u,schema:r,...l,handler:async(c,s)=>{try{let n=await d.call(this,c,s);return s.sent?void 0:n}catch(n){if(console.error(`[Loader API Error] ${u}:`,n),!s.sent){let{statusCode:o,message:m}=y(n);s.status(o).send({error:{message:m}})}}}})})},I=w(g,{name:"fastify-b-ssr"});export{I as default};
|
package/package.json
CHANGED