@bobtail.software/b-ssr 1.0.46 → 1.0.48

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,4 +1,4 @@
1
- "use strict";var de=Object.create;var K=Object.defineProperty;var me=Object.getOwnPropertyDescriptor;var fe=Object.getOwnPropertyNames;var ye=Object.getPrototypeOf,he=Object.prototype.hasOwnProperty;var be=(o,l)=>{for(var x in l)K(o,x,{get:l[x],enumerable:!0})},te=(o,l,x,C)=>{if(l&&typeof l=="object"||typeof l=="function")for(let w of fe(l))!he.call(o,w)&&w!==x&&K(o,w,{get:()=>l[w],enumerable:!(C=me(l,w))||C.enumerable});return o};var re=(o,l,x)=>(x=o!=null?de(ye(o)):{},te(l||!o||!o.__esModule?K(x,"default",{value:o,enumerable:!0}):x,o)),xe=o=>te(K({},"__esModule",{value:!0}),o);var Pe={};be(Pe,{rpcGeneratorPlugin:()=>we});module.exports=xe(Pe);var ne=re(require("fast-glob"),1),M=require("fs/promises"),u=re(require("path"),1),U=require("prettier"),s=require("ts-morph"),k="virtual:b-ssr-rpc-universal:";function Te(o){let l=o.replace(/[^a-zA-Z0-9]+(.)?/g,(x,C)=>C?C.toUpperCase():"");return l.charAt(0).toLowerCase()+l.slice(1)}function Z(o,l,x){let C=u.default.basename(x,u.default.extname(x))||"Index",w=l.replace(/:[a-zA-Z0-9_]+/g,"").replace(/\//g," "),q=`${o} ${w} ${C}`;return Te(q)}function we(o={}){let{routerPattern:l="src-ts/routers/**/*.mts",tsConfigFilePath:x="tsconfig.json",routerBaseDir:C="src-ts/routers"}=o,w=new Map,q=new Set,B=new s.Project({tsConfigFilePath:x,skipAddingFilesFromTsConfig:!1}),se=u.default.resolve(process.cwd(),C||".");async function I(t){try{let D=function(e){return e.replace(/import\(['"](.*?)['"]\)/g,(c,a)=>{if(!u.default.isAbsolute(a))return c;let i=a;if(!u.default.extname(i)){let b=B.getSourceFile(y=>y.getFilePath().replace(/\.(mts|ts|tsx)$/,"")===a);b&&(i=b.getFilePath())}let p=u.default.relative(u.default.dirname(v),i).replace(/\\/g,"/");return p.startsWith(".")||(p="./"+p),`import("${p}")`})},O=function(e,c){if(e.getSymbol()?.getName()==="Promise"){let g=e.getAwaitedType();if(g)return`Promise<${O(g,c)}>`}let a=e.getAliasSymbol()??e.getSymbol();if(a?.getName()==="__object")return D(e.getText(c,s.ts.TypeFormatFlags.NoTruncation|s.ts.TypeFormatFlags.UseFullyQualifiedType));if(e.isObject()&&!a){let g=(f,h=0)=>{if(!(h>5)){if(f.isArray()){let T=f.getArrayElementType();T&&g(T,h);return}if(f.isObject()&&!f.getSymbol()&&!f.getAliasSymbol()){for(let T of f.getApparentProperties()){let A=T.getValueDeclaration();A&&g(T.getTypeAtLocation(A),h+1)}return}O(f,c)}};return g(e),D(e.getText(c,s.ts.TypeFormatFlags.NoTruncation|s.ts.TypeFormatFlags.UseFullyQualifiedType))}if(!a)return D(e.getText(c,s.ts.TypeFormatFlags.NoTruncation));let i=a.getDeclarations()[0];if(!i)return a.getName();if(s.Node.isImportSpecifier(i)||s.Node.isImportClause(i)){let g=i.getFirstAncestorByKind(s.SyntaxKind.ImportDeclaration);if(g){let f=g.getModuleSpecifierValue(),h=a.getName();return F.has(f)||F.set(f,new Set),F.get(f)?.add(h),h}}let p=i.getSourceFile();if(p.getFilePath()===m.getFilePath())return a.getName();if(p.isInNodeModules())return D(e.getText(c,s.ts.TypeFormatFlags.NoTruncation));let b=u.default.relative(u.default.dirname(v),p.getFilePath()).replace(/\\/g,"/"),R=b.startsWith(".")?b:`./${b}`,P=a.getName();return F.has(R)||F.set(R,new Set),F.get(R)?.add(P),P},Q=function(e){let c;if(s.Node.isFunctionLikeDeclaration(e)||s.Node.isArrowFunction(e)){let a=e.getDescendantsOfKind(s.SyntaxKind.ReturnStatement);for(let i of a){let p=i.getExpression();if(p?.isKind(s.SyntaxKind.SatisfiesExpression)){c=p.getTypeNode()?.getType();break}}}if(c)return O(c,e);{let a=e.getType().getCallSignatures();if(a.length>0){let i=a[0]?.getReturnType();return O(i,e)}}return"unknown"};var d=D,n=O,r=Q;let m=B.addSourceFileAtPath(t);await m.refreshFromFileSystem(),B.resolveSourceFileDependencies();let S=m.getDescendantsOfKind(s.SyntaxKind.CallExpression),E=S.filter(e=>e.getExpression().getText().endsWith(".addRpcRoute")),$=S.filter(e=>e.getExpression().getText().endsWith(".addRenderRoute")),j=S.filter(e=>e.getExpression().getText().endsWith(".addLoaderRoute")),L=u.default.extname(t),v=t.substring(0,t.length-L.length)+".universal.d.ts",V=u.default.resolve(t);if(E.length===0&&$.length===0&&j.length===0){w.delete(V),q.delete(V),v!==t&&await(0,M.unlink)(v).catch(()=>{});return}q.add(V);let _=[],F=new Map;F.has("fastify")||F.set("fastify",new Set),F.get("fastify")?.add("FastifyRequest"),F.get("fastify")?.add("FastifyReply");let ce=e=>{let c="unknown",a="unknown",i="unknown",p=!1;if(!e||!s.Node.isObjectLiteralExpression(e))return{paramsType:c,queryType:a,bodyType:i,isMultipart:p};let b=e.getProperty("schema");if(b?.isKind(s.SyntaxKind.PropertyAssignment)){let y=b.getInitializer();if(y?.isKind(s.SyntaxKind.Identifier)){let P=y.getSymbol()?.getValueDeclaration();if(P){let g=P.getFirstDescendantByKind(s.SyntaxKind.ObjectLiteralExpression);g&&(y=g)}}if(y&&s.Node.isObjectLiteralExpression(y)){let R=y.getProperty("consumes");if(R?.isKind(s.SyntaxKind.PropertyAssignment)){let g=R.getInitializer();s.Node.isArrayLiteralExpression(g)&&(p=g.getElements().some(f=>f.isKind(s.SyntaxKind.StringLiteral)&&f.getLiteralValue()==="multipart/form-data"))}let P=g=>{let f=y.getProperty(g);if(f?.isKind(s.SyntaxKind.PropertyAssignment)){let h=f.getInitializer();if(h){let T=h.getType(),A=T.getProperty("_output");return O(A?A.getTypeAtLocation(h).getApparentType():T,h)}}return"unknown"};if(c=P("params"),a=P("querystring"),i=P("body"),p){let g="{ file: File }";i=i!=="unknown"&&i.trim().startsWith("{")?`(${i} & ${g})`:g}}}return{paramsType:c,queryType:a,bodyType:i,isMultipart:p}},N=u.default.relative(se,u.default.dirname(t)).split(u.default.sep).join("/"),pe=N==="."||!N?"":N.startsWith("/")?N:"/"+N,z=(e,c)=>{let[a,i]=e.getArguments();if(!a?.isKind(s.SyntaxKind.StringLiteral))return;let p=a.getLiteralValue(),b="unknown",y=pe,{paramsType:R,queryType:P,bodyType:g,isMultipart:f}=ce(i);if(i?.isKind(s.SyntaxKind.ObjectLiteralExpression)){let A=i.getProperty("prefix");if(A?.isKind(s.SyntaxKind.PropertyAssignment)){let W=A.getInitializer();W?.isKind(s.SyntaxKind.StringLiteral)&&(y=W.getLiteralValue())}let ee=i.getProperty("handler");if(ee?.isKind(s.SyntaxKind.PropertyAssignment)){let W=ee.getInitializer();W&&(b=Q(W),b.startsWith("Promise<")||(b=`Promise<${b}>`))}}let h="",T="";c==="rpc"?(h=u.default.join(y,"rpc",p).replace(/\\/g,"/"),T=Z("action",y,p)):c==="loader"?(h=u.default.join(y,"loader",p).replace(/\\/g,"/"),T=Z("loader",y,p)):c==="api"&&(h=u.default.join(y,"api",p).replace(/\\/g,"/"),T=Z("get",y,p)),T&&_.push({type:c,name:T,returnType:b,url:p,rpcUrl:h,loaderUrl:h,paramsType:R,queryType:P,bodyType:g,isMultipart:f})};E.forEach(e=>z(e,"rpc")),$.forEach(e=>z(e,"loader")),j.forEach(e=>z(e,"api"));let H=[];for(let[e,c]of F.entries())H.push(`import type { ${[...c].sort().join(", ")} } from "${e}";`);let X=[];_.forEach(e=>{X.push(oe(e))});let G=`// AUTO-GENERATED by @bobtail.software/b-ssr. DO NOT EDIT.
1
+ "use strict";var de=Object.create;var K=Object.defineProperty;var me=Object.getOwnPropertyDescriptor;var fe=Object.getOwnPropertyNames;var ye=Object.getPrototypeOf,he=Object.prototype.hasOwnProperty;var be=(o,p)=>{for(var x in p)K(o,x,{get:p[x],enumerable:!0})},te=(o,p,x,v)=>{if(p&&typeof p=="object"||typeof p=="function")for(let P of fe(p))!he.call(o,P)&&P!==x&&K(o,P,{get:()=>p[P],enumerable:!(v=me(p,P))||v.enumerable});return o};var re=(o,p,x)=>(x=o!=null?de(ye(o)):{},te(p||!o||!o.__esModule?K(x,"default",{value:o,enumerable:!0}):x,o)),xe=o=>te(K({},"__esModule",{value:!0}),o);var Se={};be(Se,{rpcGeneratorPlugin:()=>Pe});module.exports=xe(Se);var ne=re(require("fast-glob"),1),O=require("fs/promises"),c=re(require("path"),1),U=require("prettier"),r=require("ts-morph"),k="virtual:b-ssr-rpc-universal:";function Te(o){let p=o.replace(/[^a-zA-Z0-9]+(.)?/g,(x,v)=>v?v.toUpperCase():"");return p.charAt(0).toLowerCase()+p.slice(1)}function Z(o,p,x){let v=c.default.basename(x,c.default.extname(x))||"Index",P=p.replace(/:[a-zA-Z0-9_]+/g,"").replace(/\//g," "),q=`${o} ${P} ${v}`;return Te(q)}function Pe(o={}){let{routerPattern:p="src-ts/routers/**/*.mts",tsConfigFilePath:x="tsconfig.json",routerBaseDir:v="src-ts/routers"}=o,P=new Map,q=new Set,B=new r.Project({tsConfigFilePath:x,skipAddingFilesFromTsConfig:!1}),se=c.default.resolve(process.cwd(),v||".");async function I(t){try{let D=function(e){return e.replace(/import\(['"](.*?)['"]\)/g,(u,a)=>{if(!c.default.isAbsolute(a))return u;let i=a;if(!c.default.extname(i)){let b=B.getSourceFile(y=>y.getFilePath().replace(/\.(mts|ts|tsx)$/,"")===a);b&&(i=b.getFilePath())}let g=c.default.relative(c.default.dirname($),i).replace(/\\/g,"/");return g.startsWith(".")||(g="./"+g),`import("${g}")`})},M=function(e,u){if(e.getSymbol()?.getName()==="Promise"){let d=e.getAwaitedType();if(d)return`Promise<${M(d,u)}>`}let a=e.getAliasSymbol()??e.getSymbol();if(a?.getName()==="__object")return D(e.getText(u,r.ts.TypeFormatFlags.NoTruncation|r.ts.TypeFormatFlags.UseFullyQualifiedType));if(e.isObject()&&!a){let d=(f,h=0)=>{if(!(h>5)){if(f.isArray()){let T=f.getArrayElementType();T&&d(T,h);return}if(f.isObject()&&!f.getSymbol()&&!f.getAliasSymbol()){for(let T of f.getApparentProperties()){let A=T.getValueDeclaration();A&&d(T.getTypeAtLocation(A),h+1)}return}M(f,u)}};return d(e),D(e.getText(u,r.ts.TypeFormatFlags.NoTruncation|r.ts.TypeFormatFlags.UseFullyQualifiedType))}if(!a)return D(e.getText(u,r.ts.TypeFormatFlags.NoTruncation));let i=a.getDeclarations()[0];if(!i)return a.getName();if(r.Node.isImportSpecifier(i)||r.Node.isImportClause(i)){let d=i.getFirstAncestorByKind(r.SyntaxKind.ImportDeclaration);if(d){let f=d.getModuleSpecifierValue(),h=a.getName();return R.has(f)||R.set(f,new Set),R.get(f)?.add(h),h}}let g=i.getSourceFile();if(g.getFilePath()===s.getFilePath())return a.getName();if(g.isInNodeModules())return D(e.getText(u,r.ts.TypeFormatFlags.NoTruncation));let b=c.default.relative(c.default.dirname($),g.getFilePath()).replace(/\\/g,"/"),E=b.startsWith(".")?b:`./${b}`,F=a.getName();return R.has(E)||R.set(E,new Set),R.get(E)?.add(F),F},Q=function(e){let u;if(r.Node.isFunctionLikeDeclaration(e)||r.Node.isArrowFunction(e)){let a=e.getDescendantsOfKind(r.SyntaxKind.ReturnStatement);for(let i of a){let g=i.getExpression();if(g?.isKind(r.SyntaxKind.SatisfiesExpression)){u=g.getTypeNode()?.getType();break}}}if(u)return M(u,e);{let a=e.getType().getCallSignatures();if(a.length>0){let i=a[0]?.getReturnType();return M(i,e)}}return"unknown"};var m=D,n=M,l=Q;let s=B.addSourceFileAtPath(t);await s.refreshFromFileSystem(),B.resolveSourceFileDependencies();let w=s.getDescendantsOfKind(r.SyntaxKind.CallExpression),C=w.filter(e=>e.getExpression().getText().endsWith(".addRpcRoute")),S=w.filter(e=>e.getExpression().getText().endsWith(".addRenderRoute")),j=w.filter(e=>e.getExpression().getText().endsWith(".addLoaderRoute")),L=c.default.extname(t),$=t.substring(0,t.length-L.length)+".universal.d.ts",V=c.default.resolve(t);if(C.length===0&&S.length===0&&j.length===0){P.delete(V),q.delete(V),$!==t&&await(0,O.unlink)($).catch(()=>{});return}q.add(V);let _=[],R=new Map;R.has("fastify")||R.set("fastify",new Set),R.get("fastify")?.add("FastifyRequest"),R.get("fastify")?.add("FastifyReply");let ce=e=>{let u="unknown",a="unknown",i="unknown",g=!1;if(!e||!r.Node.isObjectLiteralExpression(e))return{paramsType:u,queryType:a,bodyType:i,isMultipart:g};let b=e.getProperty("schema");if(b?.isKind(r.SyntaxKind.PropertyAssignment)){let y=b.getInitializer();if(y?.isKind(r.SyntaxKind.Identifier)){let F=y.getSymbol()?.getValueDeclaration();if(F){let d=F.getFirstDescendantByKind(r.SyntaxKind.ObjectLiteralExpression);d&&(y=d)}}if(y&&r.Node.isObjectLiteralExpression(y)){let E=y.getProperty("consumes");if(E?.isKind(r.SyntaxKind.PropertyAssignment)){let d=E.getInitializer();r.Node.isArrayLiteralExpression(d)&&(g=d.getElements().some(f=>f.isKind(r.SyntaxKind.StringLiteral)&&f.getLiteralValue()==="multipart/form-data"))}let F=d=>{let f=y.getProperty(d);if(f?.isKind(r.SyntaxKind.PropertyAssignment)){let h=f.getInitializer();if(h){let T=h.getType(),A=T.getProperty("_output");return M(A?A.getTypeAtLocation(h).getApparentType():T,h)}}return"unknown"};if(u=F("params"),a=F("querystring"),i=F("body"),g){let d="{ file: File }";i=i!=="unknown"&&i.trim().startsWith("{")?`(${i} & ${d})`:d}}}return{paramsType:u,queryType:a,bodyType:i,isMultipart:g}},N=c.default.relative(se,c.default.dirname(t)).split(c.default.sep).join("/"),pe=N==="."||!N?"":N.startsWith("/")?N:"/"+N,z=(e,u)=>{let[a,i]=e.getArguments();if(!a?.isKind(r.SyntaxKind.StringLiteral))return;let g=a.getLiteralValue(),b="unknown",y=pe,{paramsType:E,queryType:F,bodyType:d,isMultipart:f}=ce(i);if(i?.isKind(r.SyntaxKind.ObjectLiteralExpression)){let A=i.getProperty("prefix");if(A?.isKind(r.SyntaxKind.PropertyAssignment)){let W=A.getInitializer();W?.isKind(r.SyntaxKind.StringLiteral)&&(y=W.getLiteralValue())}let ee=i.getProperty("handler");if(ee?.isKind(r.SyntaxKind.PropertyAssignment)){let W=ee.getInitializer();W&&(b=Q(W),b.startsWith("Promise<")||(b=`Promise<${b}>`))}}let h="",T="";u==="rpc"?(h=c.default.join(y,"rpc",g).replace(/\\/g,"/"),T=Z("action",y,g)):u==="loader"?(h=c.default.join(y,"loader",g).replace(/\\/g,"/"),T=Z("loader",y,g)):u==="api"&&(h=c.default.join(y,"api",g).replace(/\\/g,"/"),T=Z("get",y,g)),T&&_.push({type:u,name:T,returnType:b,url:g,rpcUrl:h,loaderUrl:h,paramsType:E,queryType:F,bodyType:d,isMultipart:f})};C.forEach(e=>z(e,"rpc")),S.forEach(e=>z(e,"loader")),j.forEach(e=>z(e,"api"));let H=[];for(let[e,u]of R.entries())H.push(`import type { ${[...u].sort().join(", ")} } from "${e}";`);let X=[];_.forEach(e=>{X.push(oe(e))});let G=`// AUTO-GENERATED by @bobtail.software/b-ssr. DO NOT EDIT.
2
2
  /* eslint-disable */
3
3
 
4
4
  `+(H.length>0?H.join(`
@@ -6,11 +6,11 @@
6
6
 
7
7
  `:"")+X.join(`
8
8
 
9
- `);try{let e=await(0,U.resolveConfig)(v)||{};G=await(0,U.format)(G,{...e,parser:"typescript",filepath:v})}catch{}await(0,M.writeFile)(v,G);let Y=[],J=[];_.forEach(e=>{let a=e.type==="rpc"?"POST":"GET",i=e.type==="loader"?e.loaderUrl:e.rpcUrl;J.push({name:e.name,rpcUrl:i,method:a,isMultipart:!!e.isMultipart}),Y.push({name:e.name,url:e.url,type:e.type,requiresArgs:!0})});let ue=`
9
+ `);try{let e=await(0,U.resolveConfig)($)||{};G=await(0,U.format)(G,{...e,parser:"typescript",filepath:$})}catch{}await(0,O.writeFile)($,G);let Y=[],J=[];_.forEach(e=>{let a=e.type==="rpc"?"POST":"GET",i=e.type==="loader"?e.loaderUrl:e.rpcUrl;J.push({name:e.name,rpcUrl:i,method:a,isMultipart:!!e.isMultipart}),Y.push({name:e.name,url:e.url,type:e.type,requiresArgs:!0})});let ue=`
10
10
  import { createClientRpc } from '@bobtail.software/b-ssr/client';
11
11
 
12
12
  if (import.meta.env.DEV) {
13
- console.debug('\u{1F6E1}\uFE0F [B-SSR Security] Loaded SAFE Client-Stub for: ${u.default.basename(t)}');
13
+ console.debug('\u{1F6E1}\uFE0F [B-SSR Security] Loaded SAFE Client-Stub for: ${c.default.basename(t)}');
14
14
  }
15
15
 
16
16
  ${J.map(e=>`
@@ -21,16 +21,15 @@
21
21
  });
22
22
  `).join(`
23
23
  `)}
24
- `,ge=ae(Y,t);w.set(u.default.resolve(t),{client:ue,server:ge})}catch(m){console.error(`[rpc-generator] Error al procesar ${t}:`,{error:m})}}let ie=(t,d,n)=>{if(d.includes("node_modules")||d.startsWith(k))return null;if(n?.ssr===!0&&/\.[cm]?[jt]sx?$/.test(d)){let r=/\brequire\s*\(/.test(t),m=/\bmodule\.exports\b/.test(t),S=/\bexports\./.test(t);if(r||m||S)return"import { createRequire } from 'module';"+`
24
+ `,ge=ae(Y,t);P.set(c.default.resolve(t),{client:ue,server:ge})}catch(s){console.error(`[rpc-generator] Error al procesar ${t}:`,{error:s})}}let ie=(t,m,n)=>{if(m.includes("node_modules")||m.startsWith(k))return null;if(n?.ssr===!0&&/\.[cm]?[jt]sx?$/.test(m)){let l=/\brequire\s*\(/.test(t),s=/\bmodule\.exports\b/.test(t),w=/\bexports\./.test(t);if(l||s||w)return"import { createRequire } from 'module';"+`
25
25
  const require = createRequire(import.meta.url);
26
26
  const module = { exports: {} };
27
27
  const exports = module.exports;
28
28
  `+t+`
29
- export default module.exports;`}return null};function oe(t){let d=Se(t),n="";return d.length>0&&(n=`args: { ${d.join("; ")} }`),n||(n="args: { signal?: AbortSignal }"),`export declare const ${t.name}: (${n}, ssrContext?: { req?: FastifyRequest, reply?: FastifyReply }) => ${t.returnType};`}function ae(t,d){if(t.length===0)return"";let n=d.replace(/\\/g,"/");return`
30
- import * as routeModule from '${n}';
31
-
29
+ export default module.exports;`}return null};function oe(t){let m=we(t),n="";return m.length>0&&(n=`args: { ${m.join("; ")} }`),n||(n="args: { signal?: AbortSignal }"),`export declare const ${t.name}: (${n}, ssrContext?: { req?: FastifyRequest, reply?: FastifyReply }) => ${t.returnType};`}function ae(t,m){if(t.length===0)return"";let l=`/${c.default.relative(process.cwd(),m).replace(/\\/g,"/")}`;return`
30
+
32
31
  if (typeof window !== 'undefined' && typeof document !== 'undefined') {
33
- throw new Error('\u{1F6A8} [B-SSR SECURITY ALERT] Server-side code leaked to browser: ${n}');
32
+ throw new Error('\u{1F6A8} [B-SSR SECURITY ALERT] Server-side code leaked to browser: ${l}');
34
33
  }
35
34
 
36
35
  let initPromise;
@@ -43,6 +42,17 @@ export default module.exports;`}return null};function oe(t){let d=Se(t),n="";ret
43
42
  rpcOptionsMap = new Map();
44
43
  renderOptionsMap = new Map();
45
44
  loaderApiOptionsMap = new Map();
45
+ const serverModulePath = '${l}';
46
+
47
+ if (typeof globalThis.require === 'undefined') {
48
+ try {
49
+ const { createRequire } = await import('module');
50
+ globalThis.require = createRequire(serverModulePath);
51
+ } catch (e) {}
52
+ }
53
+
54
+ const routeModule = await import(/* @vite-ignore */ serverModulePath);
55
+
46
56
  const mockMethods = {
47
57
  addRpcRoute: (url, options) => rpcOptionsMap.set(url, options),
48
58
  addRenderRoute: (url, options) => renderOptionsMap.set(url, options),
@@ -71,7 +81,7 @@ export default module.exports;`}return null};function oe(t){let d=Se(t),n="";ret
71
81
  try {
72
82
  await entryPoint(mockFastify);
73
83
  } catch (err) {
74
- console.error('\u274C [B-SSR CRITICAL] Error inicializando rutas backend:', '${n}', err);
84
+ console.error('\u274C [B-SSR CRITICAL] Error inicializando rutas backend:', serverModulePath, err);
75
85
  }
76
86
  }
77
87
  })();
@@ -79,46 +89,46 @@ export default module.exports;`}return null};function oe(t){let d=Se(t),n="";ret
79
89
  return initPromise;
80
90
  }
81
91
 
82
- ${t.map(r=>{let m=[];r.requiresArgs&&m.push("args"),m.push("ssrContext");let S=r.requiresArgs?"args":"{}",E="";return r.type==="rpc"?E=`
92
+ ${t.map(s=>{let w=[];s.requiresArgs&&w.push("args"),w.push("ssrContext");let C=s.requiresArgs?"args":"{}",S="";return s.type==="rpc"?S=`
83
93
  if (fn.isMultipart) throw new Error('RPC multipart no soportado en SSR.');
84
94
  await getOptionsMaps();
85
- const options = rpcOptionsMap.get('${r.url}');
86
- if (!options?.handler) throw new Error('Handler no encontrado para RPC: ${r.name}');
87
- const augmentedReq = Object.assign(Object.create(ssrContext.req), ${S});
95
+ const options = rpcOptionsMap.get('${s.url}');
96
+ if (!options?.handler) throw new Error('Handler no encontrado para RPC: ${s.name}');
97
+ const augmentedReq = Object.assign(Object.create(ssrContext.req), ${C});
88
98
  return await options.handler.call(ssrContext.req.server, augmentedReq, ssrContext.reply);
89
- `:r.type==="api"?E=`
99
+ `:s.type==="api"?S=`
90
100
  await getOptionsMaps();
91
- const options = loaderApiOptionsMap.get('${r.url}');
101
+ const options = loaderApiOptionsMap.get('${s.url}');
92
102
  if (!options?.handler) {
93
- console.error('\u26A0\uFE0F [B-SSR Warning] Handler API no encontrado:', '${r.name}', 'URL:', '${r.url}');
103
+ console.error('\u26A0\uFE0F [B-SSR Warning] Handler API no encontrado:', '${s.name}', 'URL:', '${s.url}');
94
104
  return null;
95
105
  }
96
- const augmentedReq = Object.assign(Object.create(ssrContext.req), ${S});
106
+ const augmentedReq = Object.assign(Object.create(ssrContext.req), ${C});
97
107
  return await options.handler.call(ssrContext.req.server, augmentedReq, ssrContext.reply);
98
- `:E=`
108
+ `:S=`
99
109
  await getOptionsMaps();
100
- const options = renderOptionsMap.get('${r.url}');
110
+ const options = renderOptionsMap.get('${s.url}');
101
111
  if (!options) return {};
102
- const augmentedReq = Object.assign(Object.create(ssrContext.req), ${S});
112
+ const augmentedReq = Object.assign(Object.create(ssrContext.req), ${C});
103
113
  let customData = {};
104
114
  try {
105
115
  if (options.handler) {
106
116
  customData = (await options.handler.call(ssrContext.req.server, augmentedReq, ssrContext.reply)) || {};
107
117
  }
108
118
  } catch (handlerErr) {
109
- console.error('\u274C [B-SSR Handler Error] ${r.name}:', handlerErr);
119
+ console.error('\u274C [B-SSR Handler Error] ${s.name}:', handlerErr);
110
120
  return {};
111
121
  }
112
122
  if (ssrContext.reply.sent) return;
113
123
  return { ...customData };
114
- `,`export const ${r.name} = async (${m.join(", ")}) => {
124
+ `,`export const ${s.name} = async (${w.join(", ")}) => {
115
125
  try {
116
- if (!ssrContext?.req) throw new Error('ssrContext requerido en ${r.name} (SSR)');
117
- ${E}
126
+ if (!ssrContext?.req) throw new Error('ssrContext requerido en ${s.name} (SSR)');
127
+ ${S}
118
128
  } catch (error) {
119
- console.error('\u274C [B-SSR Error] ${r.name}:', error);
129
+ console.error('\u274C [B-SSR Error] ${s.name}:', error);
120
130
  throw error;
121
131
  }
122
132
  };`}).join(`
123
133
  `)}
124
- `}async function le(){let t=await(0,ne.default)(l,{absolute:!0});await Promise.all(t.map(d=>I(d)))}return{name:"b-ssr-vite-plugin-rpc-universal-generator",enforce:"pre",async buildStart(){await le()},configureServer(t){let d=n=>n.endsWith(".mts")||n.endsWith(".ts");t.watcher.on("add",n=>d(n)&&I(n)),t.watcher.on("change",n=>d(n)&&I(n)),t.watcher.on("unlink",n=>{if(d(n)){let r=u.default.resolve(n);w.delete(r),q.delete(r);let m=u.default.extname(n),S=n.substring(0,n.length-m.length)+".universal.d.ts";(0,M.unlink)(S).catch(()=>{})}})},async resolveId(t,d,n){if(t.startsWith(k))return null;if(t.includes(".universal")){let r=t.split("?")[0],m=r;if(r.endsWith(".universal"))m=r;else if(r.endsWith(".universal.ts"))m=r.slice(0,-3);else if(r.endsWith(".universal.mts"))m=r.slice(0,-4);else if(r.endsWith(".universal.js"))m=r.slice(0,-3);else return null;let S=[".mts",".ts"];for(let E of S){let $=m.slice(0,-10)+E,j=await this.resolve($,d,{skipSelf:!0});if(j){let L=n?.ssr?"?mode=ssr":"?mode=client";return k+j.id+L}try{await(0,M.access)($);let L=n?.ssr?"?mode=ssr":"?mode=client";return k+$+L}catch{}}}return null},async load(t,d){if(t.startsWith(k)){let n=t.slice(k.length).split("?")[0],r=w.get(n);return r||(await I(n),r=w.get(n)),r?d?.ssr===!0?r.server:r.client:null}if(d?.ssr!==!0){let n=u.default.resolve(t);if(q.has(n))return`throw new Error("\u{1F6A8} [B-SSR FIREWALL] BLOCKED: Backend File imported in Client: ${u.default.basename(t)}");`}return null},transform:ie}}function Se(o){let l=[];return o.paramsType!=="unknown"&&l.push(`params: ${o.paramsType}`),o.queryType!=="unknown"&&l.push(`query: ${o.queryType}`),o.bodyType!=="unknown"&&l.push(`body: ${o.bodyType}`),l.push("signal?: AbortSignal"),l}0&&(module.exports={rpcGeneratorPlugin});
134
+ `}async function le(){let t=await(0,ne.default)(p,{absolute:!0});await Promise.all(t.map(m=>I(m)))}return{name:"b-ssr-vite-plugin-rpc-universal-generator",enforce:"pre",async buildStart(){await le()},configureServer(t){let m=n=>n.endsWith(".mts")||n.endsWith(".ts");t.watcher.on("add",n=>m(n)&&I(n)),t.watcher.on("change",n=>m(n)&&I(n)),t.watcher.on("unlink",n=>{if(m(n)){let l=c.default.resolve(n);P.delete(l),q.delete(l);let s=c.default.extname(n),w=n.substring(0,n.length-s.length)+".universal.d.ts";(0,O.unlink)(w).catch(()=>{})}})},async resolveId(t,m,n){if(t.startsWith(k))return null;if(t.includes(".universal")){let l=t.split("?")[0],s=l;if(l.endsWith(".universal"))s=l;else if(l.endsWith(".universal.ts"))s=l.slice(0,-3);else if(l.endsWith(".universal.mts"))s=l.slice(0,-4);else if(l.endsWith(".universal.js"))s=l.slice(0,-3);else return null;let w=[".mts",".ts"];for(let C of w){let S=s.slice(0,-10)+C,j=await this.resolve(S,m,{skipSelf:!0});if(j){let L=n?.ssr?"?mode=ssr":"?mode=client";return k+j.id+L}try{await(0,O.access)(S);let L=n?.ssr?"?mode=ssr":"?mode=client";return k+S+L}catch{}}}return null},async load(t,m){if(t.startsWith(k)){let n=t.slice(k.length).split("?")[0],l=P.get(n);return l||(await I(n),l=P.get(n)),l?m?.ssr===!0?l.server:l.client:null}if(m?.ssr!==!0){let n=c.default.resolve(t);if(q.has(n))return`throw new Error("\u{1F6A8} [B-SSR FIREWALL] BLOCKED: Backend File imported in Client: ${c.default.basename(t)}");`}return null},transform:ie}}function we(o){let p=[];return o.paramsType!=="unknown"&&p.push(`params: ${o.paramsType}`),o.queryType!=="unknown"&&p.push(`query: ${o.queryType}`),o.bodyType!=="unknown"&&p.push(`body: ${o.bodyType}`),p.push("signal?: AbortSignal"),p}0&&(module.exports={rpcGeneratorPlugin});
@@ -1,4 +1,4 @@
1
- import pe from"fast-glob";import{access as ue,unlink as ee,writeFile as ge}from"fs/promises";import l from"path";import{format as de,resolveConfig as me}from"prettier";import{Node as v,Project as fe,SyntaxKind as y,ts as j}from"ts-morph";var k="virtual:b-ssr-rpc-universal:";function ye(x){let T=x.replace(/[^a-zA-Z0-9]+(.)?/g,(L,O)=>O?O.toUpperCase():"");return T.charAt(0).toLowerCase()+T.slice(1)}function G(x,T,L){let O=l.basename(L,l.extname(L))||"Index",R=T.replace(/:[a-zA-Z0-9_]+/g,"").replace(/\//g," "),M=`${x} ${R} ${O}`;return ye(M)}function Ee(x={}){let{routerPattern:T="src-ts/routers/**/*.mts",tsConfigFilePath:L="tsconfig.json",routerBaseDir:O="src-ts/routers"}=x,R=new Map,M=new Set,U=new fe({tsConfigFilePath:L,skipAddingFilesFromTsConfig:!1}),te=l.resolve(process.cwd(),O||".");async function K(t){try{let N=function(e){return e.replace(/import\(['"](.*?)['"]\)/g,(o,i)=>{if(!l.isAbsolute(i))return o;let s=i;if(!l.extname(s)){let f=U.getSourceFile(d=>d.getFilePath().replace(/\.(mts|ts|tsx)$/,"")===i);f&&(s=f.getFilePath())}let a=l.relative(l.dirname(A),s).replace(/\\/g,"/");return a.startsWith(".")||(a="./"+a),`import("${a}")`})},$=function(e,o){if(e.getSymbol()?.getName()==="Promise"){let c=e.getAwaitedType();if(c)return`Promise<${$(c,o)}>`}let i=e.getAliasSymbol()??e.getSymbol();if(i?.getName()==="__object")return N(e.getText(o,j.TypeFormatFlags.NoTruncation|j.TypeFormatFlags.UseFullyQualifiedType));if(e.isObject()&&!i){let c=(g,m=0)=>{if(!(m>5)){if(g.isArray()){let h=g.getArrayElementType();h&&c(h,m);return}if(g.isObject()&&!g.getSymbol()&&!g.getAliasSymbol()){for(let h of g.getApparentProperties()){let E=h.getValueDeclaration();E&&c(h.getTypeAtLocation(E),m+1)}return}$(g,o)}};return c(e),N(e.getText(o,j.TypeFormatFlags.NoTruncation|j.TypeFormatFlags.UseFullyQualifiedType))}if(!i)return N(e.getText(o,j.TypeFormatFlags.NoTruncation));let s=i.getDeclarations()[0];if(!s)return i.getName();if(v.isImportSpecifier(s)||v.isImportClause(s)){let c=s.getFirstAncestorByKind(y.ImportDeclaration);if(c){let g=c.getModuleSpecifierValue(),m=i.getName();return S.has(g)||S.set(g,new Set),S.get(g)?.add(m),m}}let a=s.getSourceFile();if(a.getFilePath()===u.getFilePath())return i.getName();if(a.isInNodeModules())return N(e.getText(o,j.TypeFormatFlags.NoTruncation));let f=l.relative(l.dirname(A),a.getFilePath()).replace(/\\/g,"/"),F=f.startsWith(".")?f:`./${f}`,w=i.getName();return S.has(F)||S.set(F,new Set),S.get(F)?.add(w),w},Z=function(e){let o;if(v.isFunctionLikeDeclaration(e)||v.isArrowFunction(e)){let i=e.getDescendantsOfKind(y.ReturnStatement);for(let s of i){let a=s.getExpression();if(a?.isKind(y.SatisfiesExpression)){o=a.getTypeNode()?.getType();break}}}if(o)return $(o,e);{let i=e.getType().getCallSignatures();if(i.length>0){let s=i[0]?.getReturnType();return $(s,e)}}return"unknown"};var p=N,n=$,r=Z;let u=U.addSourceFileAtPath(t);await u.refreshFromFileSystem(),U.resolveSourceFileDependencies();let b=u.getDescendantsOfKind(y.CallExpression),P=b.filter(e=>e.getExpression().getText().endsWith(".addRpcRoute")),C=b.filter(e=>e.getExpression().getText().endsWith(".addRenderRoute")),q=b.filter(e=>e.getExpression().getText().endsWith(".addLoaderRoute")),D=l.extname(t),A=t.substring(0,t.length-D.length)+".universal.d.ts",B=l.resolve(t);if(P.length===0&&C.length===0&&q.length===0){R.delete(B),M.delete(B),A!==t&&await ee(A).catch(()=>{});return}M.add(B);let V=[],S=new Map;S.has("fastify")||S.set("fastify",new Set),S.get("fastify")?.add("FastifyRequest"),S.get("fastify")?.add("FastifyReply");let oe=e=>{let o="unknown",i="unknown",s="unknown",a=!1;if(!e||!v.isObjectLiteralExpression(e))return{paramsType:o,queryType:i,bodyType:s,isMultipart:a};let f=e.getProperty("schema");if(f?.isKind(y.PropertyAssignment)){let d=f.getInitializer();if(d?.isKind(y.Identifier)){let w=d.getSymbol()?.getValueDeclaration();if(w){let c=w.getFirstDescendantByKind(y.ObjectLiteralExpression);c&&(d=c)}}if(d&&v.isObjectLiteralExpression(d)){let F=d.getProperty("consumes");if(F?.isKind(y.PropertyAssignment)){let c=F.getInitializer();v.isArrayLiteralExpression(c)&&(a=c.getElements().some(g=>g.isKind(y.StringLiteral)&&g.getLiteralValue()==="multipart/form-data"))}let w=c=>{let g=d.getProperty(c);if(g?.isKind(y.PropertyAssignment)){let m=g.getInitializer();if(m){let h=m.getType(),E=h.getProperty("_output");return $(E?E.getTypeAtLocation(m).getApparentType():h,m)}}return"unknown"};if(o=w("params"),i=w("querystring"),s=w("body"),a){let c="{ file: File }";s=s!=="unknown"&&s.trim().startsWith("{")?`(${s} & ${c})`:c}}}return{paramsType:o,queryType:i,bodyType:s,isMultipart:a}},W=l.relative(te,l.dirname(t)).split(l.sep).join("/"),ae=W==="."||!W?"":W.startsWith("/")?W:"/"+W,_=(e,o)=>{let[i,s]=e.getArguments();if(!i?.isKind(y.StringLiteral))return;let a=i.getLiteralValue(),f="unknown",d=ae,{paramsType:F,queryType:w,bodyType:c,isMultipart:g}=oe(s);if(s?.isKind(y.ObjectLiteralExpression)){let E=s.getProperty("prefix");if(E?.isKind(y.PropertyAssignment)){let I=E.getInitializer();I?.isKind(y.StringLiteral)&&(d=I.getLiteralValue())}let J=s.getProperty("handler");if(J?.isKind(y.PropertyAssignment)){let I=J.getInitializer();I&&(f=Z(I),f.startsWith("Promise<")||(f=`Promise<${f}>`))}}let m="",h="";o==="rpc"?(m=l.join(d,"rpc",a).replace(/\\/g,"/"),h=G("action",d,a)):o==="loader"?(m=l.join(d,"loader",a).replace(/\\/g,"/"),h=G("loader",d,a)):o==="api"&&(m=l.join(d,"api",a).replace(/\\/g,"/"),h=G("get",d,a)),h&&V.push({type:o,name:h,returnType:f,url:a,rpcUrl:m,loaderUrl:m,paramsType:F,queryType:w,bodyType:c,isMultipart:g})};P.forEach(e=>_(e,"rpc")),C.forEach(e=>_(e,"loader")),q.forEach(e=>_(e,"api"));let z=[];for(let[e,o]of S.entries())z.push(`import type { ${[...o].sort().join(", ")} } from "${e}";`);let Q=[];V.forEach(e=>{Q.push(ne(e))});let H=`// AUTO-GENERATED by @bobtail.software/b-ssr. DO NOT EDIT.
1
+ import pe from"fast-glob";import{access as ue,unlink as ee,writeFile as ge}from"fs/promises";import c from"path";import{format as de,resolveConfig as me}from"prettier";import{Node as $,Project as fe,SyntaxKind as y,ts as j}from"ts-morph";var k="virtual:b-ssr-rpc-universal:";function ye(x){let T=x.replace(/[^a-zA-Z0-9]+(.)?/g,(L,M)=>M?M.toUpperCase():"");return T.charAt(0).toLowerCase()+T.slice(1)}function G(x,T,L){let M=c.basename(L,c.extname(L))||"Index",v=T.replace(/:[a-zA-Z0-9_]+/g,"").replace(/\//g," "),O=`${x} ${v} ${M}`;return ye(O)}function Re(x={}){let{routerPattern:T="src-ts/routers/**/*.mts",tsConfigFilePath:L="tsconfig.json",routerBaseDir:M="src-ts/routers"}=x,v=new Map,O=new Set,U=new fe({tsConfigFilePath:L,skipAddingFilesFromTsConfig:!1}),te=c.resolve(process.cwd(),M||".");async function K(t){try{let N=function(e){return e.replace(/import\(['"](.*?)['"]\)/g,(a,i)=>{if(!c.isAbsolute(i))return a;let s=i;if(!c.extname(s)){let f=U.getSourceFile(d=>d.getFilePath().replace(/\.(mts|ts|tsx)$/,"")===i);f&&(s=f.getFilePath())}let l=c.relative(c.dirname(C),s).replace(/\\/g,"/");return l.startsWith(".")||(l="./"+l),`import("${l}")`})},A=function(e,a){if(e.getSymbol()?.getName()==="Promise"){let p=e.getAwaitedType();if(p)return`Promise<${A(p,a)}>`}let i=e.getAliasSymbol()??e.getSymbol();if(i?.getName()==="__object")return N(e.getText(a,j.TypeFormatFlags.NoTruncation|j.TypeFormatFlags.UseFullyQualifiedType));if(e.isObject()&&!i){let p=(g,m=0)=>{if(!(m>5)){if(g.isArray()){let h=g.getArrayElementType();h&&p(h,m);return}if(g.isObject()&&!g.getSymbol()&&!g.getAliasSymbol()){for(let h of g.getApparentProperties()){let E=h.getValueDeclaration();E&&p(h.getTypeAtLocation(E),m+1)}return}A(g,a)}};return p(e),N(e.getText(a,j.TypeFormatFlags.NoTruncation|j.TypeFormatFlags.UseFullyQualifiedType))}if(!i)return N(e.getText(a,j.TypeFormatFlags.NoTruncation));let s=i.getDeclarations()[0];if(!s)return i.getName();if($.isImportSpecifier(s)||$.isImportClause(s)){let p=s.getFirstAncestorByKind(y.ImportDeclaration);if(p){let g=p.getModuleSpecifierValue(),m=i.getName();return S.has(g)||S.set(g,new Set),S.get(g)?.add(m),m}}let l=s.getSourceFile();if(l.getFilePath()===n.getFilePath())return i.getName();if(l.isInNodeModules())return N(e.getText(a,j.TypeFormatFlags.NoTruncation));let f=c.relative(c.dirname(C),l.getFilePath()).replace(/\\/g,"/"),F=f.startsWith(".")?f:`./${f}`,w=i.getName();return S.has(F)||S.set(F,new Set),S.get(F)?.add(w),w},Z=function(e){let a;if($.isFunctionLikeDeclaration(e)||$.isArrowFunction(e)){let i=e.getDescendantsOfKind(y.ReturnStatement);for(let s of i){let l=s.getExpression();if(l?.isKind(y.SatisfiesExpression)){a=l.getTypeNode()?.getType();break}}}if(a)return A(a,e);{let i=e.getType().getCallSignatures();if(i.length>0){let s=i[0]?.getReturnType();return A(s,e)}}return"unknown"};var u=N,r=A,o=Z;let n=U.addSourceFileAtPath(t);await n.refreshFromFileSystem(),U.resolveSourceFileDependencies();let b=n.getDescendantsOfKind(y.CallExpression),R=b.filter(e=>e.getExpression().getText().endsWith(".addRpcRoute")),P=b.filter(e=>e.getExpression().getText().endsWith(".addRenderRoute")),q=b.filter(e=>e.getExpression().getText().endsWith(".addLoaderRoute")),D=c.extname(t),C=t.substring(0,t.length-D.length)+".universal.d.ts",B=c.resolve(t);if(R.length===0&&P.length===0&&q.length===0){v.delete(B),O.delete(B),C!==t&&await ee(C).catch(()=>{});return}O.add(B);let V=[],S=new Map;S.has("fastify")||S.set("fastify",new Set),S.get("fastify")?.add("FastifyRequest"),S.get("fastify")?.add("FastifyReply");let oe=e=>{let a="unknown",i="unknown",s="unknown",l=!1;if(!e||!$.isObjectLiteralExpression(e))return{paramsType:a,queryType:i,bodyType:s,isMultipart:l};let f=e.getProperty("schema");if(f?.isKind(y.PropertyAssignment)){let d=f.getInitializer();if(d?.isKind(y.Identifier)){let w=d.getSymbol()?.getValueDeclaration();if(w){let p=w.getFirstDescendantByKind(y.ObjectLiteralExpression);p&&(d=p)}}if(d&&$.isObjectLiteralExpression(d)){let F=d.getProperty("consumes");if(F?.isKind(y.PropertyAssignment)){let p=F.getInitializer();$.isArrayLiteralExpression(p)&&(l=p.getElements().some(g=>g.isKind(y.StringLiteral)&&g.getLiteralValue()==="multipart/form-data"))}let w=p=>{let g=d.getProperty(p);if(g?.isKind(y.PropertyAssignment)){let m=g.getInitializer();if(m){let h=m.getType(),E=h.getProperty("_output");return A(E?E.getTypeAtLocation(m).getApparentType():h,m)}}return"unknown"};if(a=w("params"),i=w("querystring"),s=w("body"),l){let p="{ file: File }";s=s!=="unknown"&&s.trim().startsWith("{")?`(${s} & ${p})`:p}}}return{paramsType:a,queryType:i,bodyType:s,isMultipart:l}},W=c.relative(te,c.dirname(t)).split(c.sep).join("/"),ae=W==="."||!W?"":W.startsWith("/")?W:"/"+W,_=(e,a)=>{let[i,s]=e.getArguments();if(!i?.isKind(y.StringLiteral))return;let l=i.getLiteralValue(),f="unknown",d=ae,{paramsType:F,queryType:w,bodyType:p,isMultipart:g}=oe(s);if(s?.isKind(y.ObjectLiteralExpression)){let E=s.getProperty("prefix");if(E?.isKind(y.PropertyAssignment)){let I=E.getInitializer();I?.isKind(y.StringLiteral)&&(d=I.getLiteralValue())}let J=s.getProperty("handler");if(J?.isKind(y.PropertyAssignment)){let I=J.getInitializer();I&&(f=Z(I),f.startsWith("Promise<")||(f=`Promise<${f}>`))}}let m="",h="";a==="rpc"?(m=c.join(d,"rpc",l).replace(/\\/g,"/"),h=G("action",d,l)):a==="loader"?(m=c.join(d,"loader",l).replace(/\\/g,"/"),h=G("loader",d,l)):a==="api"&&(m=c.join(d,"api",l).replace(/\\/g,"/"),h=G("get",d,l)),h&&V.push({type:a,name:h,returnType:f,url:l,rpcUrl:m,loaderUrl:m,paramsType:F,queryType:w,bodyType:p,isMultipart:g})};R.forEach(e=>_(e,"rpc")),P.forEach(e=>_(e,"loader")),q.forEach(e=>_(e,"api"));let z=[];for(let[e,a]of S.entries())z.push(`import type { ${[...a].sort().join(", ")} } from "${e}";`);let Q=[];V.forEach(e=>{Q.push(ne(e))});let H=`// AUTO-GENERATED by @bobtail.software/b-ssr. DO NOT EDIT.
2
2
  /* eslint-disable */
3
3
 
4
4
  `+(z.length>0?z.join(`
@@ -6,11 +6,11 @@ import pe from"fast-glob";import{access as ue,unlink as ee,writeFile as ge}from"
6
6
 
7
7
  `:"")+Q.join(`
8
8
 
9
- `);try{let e=await me(A)||{};H=await de(H,{...e,parser:"typescript",filepath:A})}catch{}await ge(A,H);let X=[],Y=[];V.forEach(e=>{let i=e.type==="rpc"?"POST":"GET",s=e.type==="loader"?e.loaderUrl:e.rpcUrl;Y.push({name:e.name,rpcUrl:s,method:i,isMultipart:!!e.isMultipart}),X.push({name:e.name,url:e.url,type:e.type,requiresArgs:!0})});let le=`
9
+ `);try{let e=await me(C)||{};H=await de(H,{...e,parser:"typescript",filepath:C})}catch{}await ge(C,H);let X=[],Y=[];V.forEach(e=>{let i=e.type==="rpc"?"POST":"GET",s=e.type==="loader"?e.loaderUrl:e.rpcUrl;Y.push({name:e.name,rpcUrl:s,method:i,isMultipart:!!e.isMultipart}),X.push({name:e.name,url:e.url,type:e.type,requiresArgs:!0})});let le=`
10
10
  import { createClientRpc } from '@bobtail.software/b-ssr/client';
11
11
 
12
12
  if (import.meta.env.DEV) {
13
- console.debug('\u{1F6E1}\uFE0F [B-SSR Security] Loaded SAFE Client-Stub for: ${l.basename(t)}');
13
+ console.debug('\u{1F6E1}\uFE0F [B-SSR Security] Loaded SAFE Client-Stub for: ${c.basename(t)}');
14
14
  }
15
15
 
16
16
  ${Y.map(e=>`
@@ -21,16 +21,15 @@ import pe from"fast-glob";import{access as ue,unlink as ee,writeFile as ge}from"
21
21
  });
22
22
  `).join(`
23
23
  `)}
24
- `,ce=se(X,t);R.set(l.resolve(t),{client:le,server:ce})}catch(u){console.error(`[rpc-generator] Error al procesar ${t}:`,{error:u})}}let re=(t,p,n)=>{if(p.includes("node_modules")||p.startsWith(k))return null;if(n?.ssr===!0&&/\.[cm]?[jt]sx?$/.test(p)){let r=/\brequire\s*\(/.test(t),u=/\bmodule\.exports\b/.test(t),b=/\bexports\./.test(t);if(r||u||b)return"import { createRequire } from 'module';"+`
24
+ `,ce=se(X,t);v.set(c.resolve(t),{client:le,server:ce})}catch(n){console.error(`[rpc-generator] Error al procesar ${t}:`,{error:n})}}let re=(t,u,r)=>{if(u.includes("node_modules")||u.startsWith(k))return null;if(r?.ssr===!0&&/\.[cm]?[jt]sx?$/.test(u)){let o=/\brequire\s*\(/.test(t),n=/\bmodule\.exports\b/.test(t),b=/\bexports\./.test(t);if(o||n||b)return"import { createRequire } from 'module';"+`
25
25
  const require = createRequire(import.meta.url);
26
26
  const module = { exports: {} };
27
27
  const exports = module.exports;
28
28
  `+t+`
29
- export default module.exports;`}return null};function ne(t){let p=he(t),n="";return p.length>0&&(n=`args: { ${p.join("; ")} }`),n||(n="args: { signal?: AbortSignal }"),`export declare const ${t.name}: (${n}, ssrContext?: { req?: FastifyRequest, reply?: FastifyReply }) => ${t.returnType};`}function se(t,p){if(t.length===0)return"";let n=p.replace(/\\/g,"/");return`
30
- import * as routeModule from '${n}';
31
-
29
+ export default module.exports;`}return null};function ne(t){let u=he(t),r="";return u.length>0&&(r=`args: { ${u.join("; ")} }`),r||(r="args: { signal?: AbortSignal }"),`export declare const ${t.name}: (${r}, ssrContext?: { req?: FastifyRequest, reply?: FastifyReply }) => ${t.returnType};`}function se(t,u){if(t.length===0)return"";let o=`/${c.relative(process.cwd(),u).replace(/\\/g,"/")}`;return`
30
+
32
31
  if (typeof window !== 'undefined' && typeof document !== 'undefined') {
33
- throw new Error('\u{1F6A8} [B-SSR SECURITY ALERT] Server-side code leaked to browser: ${n}');
32
+ throw new Error('\u{1F6A8} [B-SSR SECURITY ALERT] Server-side code leaked to browser: ${o}');
34
33
  }
35
34
 
36
35
  let initPromise;
@@ -43,6 +42,17 @@ export default module.exports;`}return null};function ne(t){let p=he(t),n="";ret
43
42
  rpcOptionsMap = new Map();
44
43
  renderOptionsMap = new Map();
45
44
  loaderApiOptionsMap = new Map();
45
+ const serverModulePath = '${o}';
46
+
47
+ if (typeof globalThis.require === 'undefined') {
48
+ try {
49
+ const { createRequire } = await import('module');
50
+ globalThis.require = createRequire(serverModulePath);
51
+ } catch (e) {}
52
+ }
53
+
54
+ const routeModule = await import(/* @vite-ignore */ serverModulePath);
55
+
46
56
  const mockMethods = {
47
57
  addRpcRoute: (url, options) => rpcOptionsMap.set(url, options),
48
58
  addRenderRoute: (url, options) => renderOptionsMap.set(url, options),
@@ -71,7 +81,7 @@ export default module.exports;`}return null};function ne(t){let p=he(t),n="";ret
71
81
  try {
72
82
  await entryPoint(mockFastify);
73
83
  } catch (err) {
74
- console.error('\u274C [B-SSR CRITICAL] Error inicializando rutas backend:', '${n}', err);
84
+ console.error('\u274C [B-SSR CRITICAL] Error inicializando rutas backend:', serverModulePath, err);
75
85
  }
76
86
  }
77
87
  })();
@@ -79,46 +89,46 @@ export default module.exports;`}return null};function ne(t){let p=he(t),n="";ret
79
89
  return initPromise;
80
90
  }
81
91
 
82
- ${t.map(r=>{let u=[];r.requiresArgs&&u.push("args"),u.push("ssrContext");let b=r.requiresArgs?"args":"{}",P="";return r.type==="rpc"?P=`
92
+ ${t.map(n=>{let b=[];n.requiresArgs&&b.push("args"),b.push("ssrContext");let R=n.requiresArgs?"args":"{}",P="";return n.type==="rpc"?P=`
83
93
  if (fn.isMultipart) throw new Error('RPC multipart no soportado en SSR.');
84
94
  await getOptionsMaps();
85
- const options = rpcOptionsMap.get('${r.url}');
86
- if (!options?.handler) throw new Error('Handler no encontrado para RPC: ${r.name}');
87
- const augmentedReq = Object.assign(Object.create(ssrContext.req), ${b});
95
+ const options = rpcOptionsMap.get('${n.url}');
96
+ if (!options?.handler) throw new Error('Handler no encontrado para RPC: ${n.name}');
97
+ const augmentedReq = Object.assign(Object.create(ssrContext.req), ${R});
88
98
  return await options.handler.call(ssrContext.req.server, augmentedReq, ssrContext.reply);
89
- `:r.type==="api"?P=`
99
+ `:n.type==="api"?P=`
90
100
  await getOptionsMaps();
91
- const options = loaderApiOptionsMap.get('${r.url}');
101
+ const options = loaderApiOptionsMap.get('${n.url}');
92
102
  if (!options?.handler) {
93
- console.error('\u26A0\uFE0F [B-SSR Warning] Handler API no encontrado:', '${r.name}', 'URL:', '${r.url}');
103
+ console.error('\u26A0\uFE0F [B-SSR Warning] Handler API no encontrado:', '${n.name}', 'URL:', '${n.url}');
94
104
  return null;
95
105
  }
96
- const augmentedReq = Object.assign(Object.create(ssrContext.req), ${b});
106
+ const augmentedReq = Object.assign(Object.create(ssrContext.req), ${R});
97
107
  return await options.handler.call(ssrContext.req.server, augmentedReq, ssrContext.reply);
98
108
  `:P=`
99
109
  await getOptionsMaps();
100
- const options = renderOptionsMap.get('${r.url}');
110
+ const options = renderOptionsMap.get('${n.url}');
101
111
  if (!options) return {};
102
- const augmentedReq = Object.assign(Object.create(ssrContext.req), ${b});
112
+ const augmentedReq = Object.assign(Object.create(ssrContext.req), ${R});
103
113
  let customData = {};
104
114
  try {
105
115
  if (options.handler) {
106
116
  customData = (await options.handler.call(ssrContext.req.server, augmentedReq, ssrContext.reply)) || {};
107
117
  }
108
118
  } catch (handlerErr) {
109
- console.error('\u274C [B-SSR Handler Error] ${r.name}:', handlerErr);
119
+ console.error('\u274C [B-SSR Handler Error] ${n.name}:', handlerErr);
110
120
  return {};
111
121
  }
112
122
  if (ssrContext.reply.sent) return;
113
123
  return { ...customData };
114
- `,`export const ${r.name} = async (${u.join(", ")}) => {
124
+ `,`export const ${n.name} = async (${b.join(", ")}) => {
115
125
  try {
116
- if (!ssrContext?.req) throw new Error('ssrContext requerido en ${r.name} (SSR)');
126
+ if (!ssrContext?.req) throw new Error('ssrContext requerido en ${n.name} (SSR)');
117
127
  ${P}
118
128
  } catch (error) {
119
- console.error('\u274C [B-SSR Error] ${r.name}:', error);
129
+ console.error('\u274C [B-SSR Error] ${n.name}:', error);
120
130
  throw error;
121
131
  }
122
132
  };`}).join(`
123
133
  `)}
124
- `}async function ie(){let t=await pe(T,{absolute:!0});await Promise.all(t.map(p=>K(p)))}return{name:"b-ssr-vite-plugin-rpc-universal-generator",enforce:"pre",async buildStart(){await ie()},configureServer(t){let p=n=>n.endsWith(".mts")||n.endsWith(".ts");t.watcher.on("add",n=>p(n)&&K(n)),t.watcher.on("change",n=>p(n)&&K(n)),t.watcher.on("unlink",n=>{if(p(n)){let r=l.resolve(n);R.delete(r),M.delete(r);let u=l.extname(n),b=n.substring(0,n.length-u.length)+".universal.d.ts";ee(b).catch(()=>{})}})},async resolveId(t,p,n){if(t.startsWith(k))return null;if(t.includes(".universal")){let r=t.split("?")[0],u=r;if(r.endsWith(".universal"))u=r;else if(r.endsWith(".universal.ts"))u=r.slice(0,-3);else if(r.endsWith(".universal.mts"))u=r.slice(0,-4);else if(r.endsWith(".universal.js"))u=r.slice(0,-3);else return null;let b=[".mts",".ts"];for(let P of b){let C=u.slice(0,-10)+P,q=await this.resolve(C,p,{skipSelf:!0});if(q){let D=n?.ssr?"?mode=ssr":"?mode=client";return k+q.id+D}try{await ue(C);let D=n?.ssr?"?mode=ssr":"?mode=client";return k+C+D}catch{}}}return null},async load(t,p){if(t.startsWith(k)){let n=t.slice(k.length).split("?")[0],r=R.get(n);return r||(await K(n),r=R.get(n)),r?p?.ssr===!0?r.server:r.client:null}if(p?.ssr!==!0){let n=l.resolve(t);if(M.has(n))return`throw new Error("\u{1F6A8} [B-SSR FIREWALL] BLOCKED: Backend File imported in Client: ${l.basename(t)}");`}return null},transform:re}}function he(x){let T=[];return x.paramsType!=="unknown"&&T.push(`params: ${x.paramsType}`),x.queryType!=="unknown"&&T.push(`query: ${x.queryType}`),x.bodyType!=="unknown"&&T.push(`body: ${x.bodyType}`),T.push("signal?: AbortSignal"),T}export{Ee as rpcGeneratorPlugin};
134
+ `}async function ie(){let t=await pe(T,{absolute:!0});await Promise.all(t.map(u=>K(u)))}return{name:"b-ssr-vite-plugin-rpc-universal-generator",enforce:"pre",async buildStart(){await ie()},configureServer(t){let u=r=>r.endsWith(".mts")||r.endsWith(".ts");t.watcher.on("add",r=>u(r)&&K(r)),t.watcher.on("change",r=>u(r)&&K(r)),t.watcher.on("unlink",r=>{if(u(r)){let o=c.resolve(r);v.delete(o),O.delete(o);let n=c.extname(r),b=r.substring(0,r.length-n.length)+".universal.d.ts";ee(b).catch(()=>{})}})},async resolveId(t,u,r){if(t.startsWith(k))return null;if(t.includes(".universal")){let o=t.split("?")[0],n=o;if(o.endsWith(".universal"))n=o;else if(o.endsWith(".universal.ts"))n=o.slice(0,-3);else if(o.endsWith(".universal.mts"))n=o.slice(0,-4);else if(o.endsWith(".universal.js"))n=o.slice(0,-3);else return null;let b=[".mts",".ts"];for(let R of b){let P=n.slice(0,-10)+R,q=await this.resolve(P,u,{skipSelf:!0});if(q){let D=r?.ssr?"?mode=ssr":"?mode=client";return k+q.id+D}try{await ue(P);let D=r?.ssr?"?mode=ssr":"?mode=client";return k+P+D}catch{}}}return null},async load(t,u){if(t.startsWith(k)){let r=t.slice(k.length).split("?")[0],o=v.get(r);return o||(await K(r),o=v.get(r)),o?u?.ssr===!0?o.server:o.client:null}if(u?.ssr!==!0){let r=c.resolve(t);if(O.has(r))return`throw new Error("\u{1F6A8} [B-SSR FIREWALL] BLOCKED: Backend File imported in Client: ${c.basename(t)}");`}return null},transform:re}}function he(x){let T=[];return x.paramsType!=="unknown"&&T.push(`params: ${x.paramsType}`),x.queryType!=="unknown"&&T.push(`query: ${x.queryType}`),x.bodyType!=="unknown"&&T.push(`body: ${x.bodyType}`),T.push("signal?: AbortSignal"),T}export{Re as rpcGeneratorPlugin};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bobtail.software/b-ssr",
3
- "version": "1.0.46",
3
+ "version": "1.0.48",
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",