@getcronit/pylon-dev 2.0.0-canary-20250206125311.f228add1e2e04c8af5d91db6063583bd317de463 → 2.0.0-canary-20250211153808.b2b63f4e67c55542413f7be6d62ce8139cfcbdbe
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.
- package/dist/index.js +115 -19
- package/dist/index.js.map +4 -4
- package/package.json +5 -4
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import
|
|
2
|
+
import*as ce from"@getcronit/pylon-telemetry";import{program as z}from"commander";import A from"consola";import we from"dotenv";import R from"pm2";var Y="2.0.0-canary-20250211153808.b2b63f4e67c55542413f7be6d62ce8139cfcbdbe";import he from"path";import{context as ye}from"esbuild";import de from"esbuild-plugin-tsc";import O from"path";import ne from"fs/promises";import E from"path";import ue from"fs/promises";import Z from"fs/promises";async function v(c,r){try{if(await Z.readFile(c,"utf8")===r)return!1}catch(t){if(t.code!=="ENOENT")throw t}return await Z.writeFile(c,r,"utf8"),!0}var X=({getBuildDefs:c,outputDir:r})=>({name:"inject-code",setup(t){t.onLoad({filter:/src[\/\\]index\.ts$/,namespace:"file"},async e=>{if(E.relative(process.cwd(),e.path)!==E.join("src","index.ts"))return;let{typeDefs:i,resolvers:o}=c(),n=ee(o),a=await ue.readFile(e.path,"utf-8"),l=E.join(process.cwd(),r,"schema.graphql");await v(l,i);let p=E.join(process.cwd(),r,"resolvers.js");return await v(p,`export const resolvers = ${n}`),{loader:"ts",contents:a+`
|
|
3
3
|
import {handler as __internalPylonHandler} from "@getcronit/pylon"
|
|
4
4
|
|
|
5
5
|
let __internalPylonConfig = undefined
|
|
@@ -11,47 +11,143 @@ import{fetchSchema as ce,generateClient as le}from"@gqty/cli";import{program as
|
|
|
11
11
|
}
|
|
12
12
|
|
|
13
13
|
app.use(__internalPylonHandler({
|
|
14
|
-
typeDefs: ${JSON.stringify(
|
|
14
|
+
typeDefs: ${JSON.stringify(i)},
|
|
15
15
|
graphql,
|
|
16
|
-
resolvers: ${
|
|
16
|
+
resolvers: ${n},
|
|
17
17
|
config: __internalPylonConfig
|
|
18
18
|
}))
|
|
19
|
-
`}})}});function
|
|
19
|
+
`}})}});function ee(c){return`{${Object.entries(c).map(([t,e])=>{if(e!==void 0)return typeof e=="string"?`${t}:${e}`:typeof e=="function"?`${t}:${e.toString()}`:typeof e=="object"&&!Array.isArray(e)?`${t}:${ee(e)}`:`${t}:${JSON.stringify(e)}`}).join(",")}}`}import me from"path";import te from"fs/promises";import k from"consola";var ie=({dir:c,onBuild:r})=>({name:"notify",async setup(t){let e=async()=>{let o=me.join(c,"schema.graphql");try{await te.access(o)}catch{return null}return await te.readFile(o,"utf-8")},s=await e(),i=Date.now();t.onStart(async()=>{i=Date.now(),k.start("[Pylon]: Building...")}),t.onEnd(async o=>{if(o.errors.length>0){for(let f of o.errors)k.error(`[Pylon]: ${f.text}
|
|
20
20
|
${f.location?`at ${f.location.file}:${f.location.line}:${f.location.column}`:""}
|
|
21
|
-
${f.detail?f.detail:""}`);throw new Error("Failed to build Pylon")}if(o.warnings.length>0)for(let f of o.warnings)C.warn(f);let i=Date.now()-n,l=Object.keys(o.metafile.inputs).length,p=Object.values(o.metafile.outputs).reduce((f,h)=>f+h.bytes,0),a=await e();C.success(`[Pylon]: Built in ${i}ms`),a!==s&&(C.info("[Pylon]: Schema updated"),s=a),r&&r({totalFiles:l,totalSize:p,schemaChanged:!0,duration:i})})}});var R=class{sfiFilePath;outputDir;constructor(r,t="./.pylon"){this.sfiFilePath=r,this.outputDir=t}async loadAndExexConfigPluginsBuild(){let r=O.join(process.cwd(),this.outputDir,"index.js"),t;try{t=(await import(r)).config}catch(s){console.error("Error loading config",s)}let e=t?.plugins||[];for(let s of e)s.build&&await s.build()}async build(r){let t=O.join(process.cwd(),this.sfiFilePath),e=O.join(process.cwd(),this.outputDir),s=await re({logLevel:"silent",metafile:!0,entryPoints:[t],outdir:e,bundle:!0,format:"esm",sourcemap:"inline",packages:"external",plugins:[H({dir:e,onBuild:r.onBuild}),K({getBuildDefs:r.getBuildDefs,outputDir:this.outputDir}),oe({tsconfigPath:O.join(process.cwd(),"tsconfig.json")})]});return await this.loadAndExexConfigPluginsBuild(),s}};import v from"typescript";import F from"typescript";import d from"typescript";var Y=c=>c.flags&d.TypeFlags.Object&&c.getProperties().length===0&&c.getCallSignatures().length===0,N=(c,r)=>{let t=c.typeToTypeNode(r,void 0,void 0),e=!!(t&&(t.kind===d.SyntaxKind.ArrayType||t.kind===d.SyntaxKind.TupleType));return!e&&r.getSymbol()?.getName()==="Array"?!0:e};var P=c=>c.flags&d.TypeFlags.String||c.flags&d.TypeFlags.Number||c.flags&d.TypeFlags.Boolean||c.flags&d.TypeFlags.StringLiteral||c.flags&d.TypeFlags.NumberLiteral||c.flags&d.TypeFlags.BooleanLiteral,E=c=>c.getCallSignatures().length>0,D=c=>P(c)?!1:!!(c.types?.length>1&&c.types.every(e=>e.flags&d.TypeFlags.StringLiteral||e.flags&d.TypeFlags.NumberLiteral||e.flags&d.TypeFlags.BooleanLiteral)),A=c=>c.getSymbol()?.getName()==="Promise",j=c=>{if(c.objectFlags&d.ObjectFlags.Reference){let e=c.typeArguments;if(e&&e.length>0)return e[0]}},X=c=>{if(!c.isUnion())return{type:c,wasOptional:!1};let t=c.types.filter(e=>!(e.flags&d.TypeFlags.Undefined||e.flags&d.TypeFlags.Null)).length!==c.types.length;return{type:c.getNonNullableType(),wasOptional:t}};function ee(c,r){let t=r;if(t.isUnion()){let n=t.types.filter(l=>!(l.flags&d.TypeFlags.Object&&l.objectFlags&d.ObjectFlags.Reference&&l.typeArguments?.length)),o=t.types.filter(l=>l.flags&d.TypeFlags.Object&&l.objectFlags&d.ObjectFlags.Reference&&l.typeArguments?.length).map(l=>l.typeArguments[0]),i=n.filter(l=>!o.some(p=>p===l));t=c.getUnionType(i)}let e=[];if(N(c,t)||P(t)||D(t))return e;let s=[];s=t.resolvedProperties||t.getProperties()||[];for(let n of s)(n.valueDeclaration&&!(d.getCombinedModifierFlags(n.valueDeclaration)&d.ModifierFlags.Private)&&!n.getName().startsWith("#"))!==!1&&e.push(n);return e}var x=c=>c.replace(/[^0-9a-zA-Z_]/g,"_"),L=c=>!!c.getSymbol()?.getDeclarations()?.some(r=>r.getSourceFile().fileName.includes("@repeaterjs"));import S from"typescript";var _=class{checker;schema;typesNameMap=new Map;inputsNameMap=new Map;unions=[];enums=[];constructor(r,t){this.checker=r,this.schema=t}getTypeDefinition=(r,t={isInputType:!1})=>{let{type:e,wasOptional:s}=X(r);if(e.flags&S.TypeFlags.Void||e.flags&S.TypeFlags.Undefined||e.flags&S.TypeFlags.Null)return{name:"Void",isList:!1,isRequired:!1};if(L(e)){let p=this.checker.getTypeArguments(e)[0];if(p)return this.getTypeDefinition(p,t)}if(A(e)){let p=j(e);if(p)return this.getTypeDefinition(p,t)}let n=t.isRequired!==void 0?t.isRequired:!s;if(Y(e))return{name:"Object",isList:!1,isRequired:n};let o=t.isInputType?this.inputsNameMap:this.typesNameMap;if(o.has(e))return{name:o.get(e),isList:!1,isRequired:n};let i=e.aliasSymbol?.escapedName?.toString()||e.symbol?.escapedName.toString();(i==="__type"||i==="__object")&&(t.propertyName?i=t.propertyName.charAt(0).toUpperCase()+t.propertyName.slice(1):i=void 0),i&&(i=x(i));let l=p=>Array.from(o.values()).includes(p);if(i&&!this.schema.scalars.includes(i)){t.isInputType&&(i=`${i}Input`);let p=1,a=i;for(;l(i);)i=`${a}_${p}`,p++}if(i&&this.schema.scalars.includes(i))return{name:i,isList:!1,isRequired:n};if(N(this.checker,e)){let p=this.checker.getIndexTypeOfType(e,S.IndexKind.Number);if(p){let a=this.getTypeDefinition(p,t);return{name:a.name,isList:!0,isRequired:a.isRequired,isListRequired:n}}}else if(D(e)){let p=this.checker.typeToTypeNode(e,void 0,void 0),m=e.types.map(f=>{if(f.isLiteral()){let h=f.value?.toString();if(!h)throw new Error("Enum member name is undefined");return x(h)}throw new Error("Invalid type for enum member")});m.length>0&&(i=i||p.typeName?.symbol?.escapedName,i||(i=m.join("_").toUpperCase(),i=t.isInputType?`${i}Input`:i),this.enums.push({name:i,values:m,rawType:e}))}else if(P(e)){let p=this.checker.typeToString(e);return e.flags&S.TypeFlags.StringLiteral?p="String":e.flags&S.TypeFlags.NumberLiteral?p="Number":e.flags&S.TypeFlags.BooleanLiteral?p="Boolean":e.flags&S.TypeFlags.String?p="String":e.flags&S.TypeFlags.Number?p="Number":e.flags&S.TypeFlags.Boolean&&(p="Boolean"),{name:x(p),isList:!1,isRequired:n}}else if(e.isIntersection()){let a=e.types.map(m=>this.getTypeDefinition(m,t).name);i=x(i||a.join("And"))}else if(e.isUnion()){let p=e.types,a=e.types.length===p.length,m=p.some(u=>{let g=N(this.checker,u)?this.checker.getIndexTypeOfType(u,S.IndexKind.Number):u;return g?P(g)||D(g):!0}),f=[...new Set(p.map(u=>this.getTypeDefinition(u,{...t,isRequired:a})))],h=f.filter(u=>u.isList);for(let u of h){let g=f.findIndex(b=>b.name===u.name&&!b.isList);g>-1&&f.splice(g,1)}let y=f.map(u=>u.name);if(i=x(i||y.join("Or")),i){let u=1,g=i;for(;l(i);)i=`${g}_${u}`,u++}if(f.length>1&&!t.isInputType&&!m)this.unions.push({name:i,types:y,rawType:e});else{let u=f[0];if(!u)throw new Error("Cannot get type definition");let g=f.some(b=>b.isList&&b.name===u.name);return{name:u.name,isList:g,isRequired:n}}}else if(E(e)){let a=e.getCallSignatures()[0]?.getReturnType();if(a&&A(a)){let m=j(a);m&&(a=m)}if(a)return this.getTypeDefinition(a,t)}return i||(i="Any"),o.set(e,i),{name:i,isList:!1,isRequired:n}};getUnions(){return this.unions}getEnums(){return this.enums}typeDefinitionToGraphQLType=r=>{let t=r.name,{isList:e,isRequired:s,isListRequired:n}=r;return s&&(t=`${t}!`),e&&(t=`[${t}]`,n&&(t=`${t}!`)),t}};import z from"consola";var B=class{schema;checker;program;sfiFile;typeDefinitionBuilder;constructor(r,t,e){this.schema={types:[],inputs:[],interfaces:[],unions:[],enums:[],scalars:["ID","Int","Float","Number","Any","Void","Object","File","Date","JSON","String","Boolean"]},this.checker=r,this.sfiFile=t,this.program=e,this.typeDefinitionBuilder=new _(r,this.schema)}parse(r){let t=this.makeReferenceSchema(r);for(let[e,s]of t.types){let n;r.Query===e?n="Query":r.Mutation===e?n="Mutation":r.Subscription===e&&(n="Subscription"),this.processSchemaReference(e,s,n,"types")}for(let[e,s]of t.inputs)this.processSchemaReference(e,s,void 0,"inputs");this.extractForbiddenFieldNamesFromSchema(),this.schema.unions=this.typeDefinitionBuilder.getUnions().map(e=>({...e,description:this.getTypeDocumentation(e.rawType)})),this.schema.enums=this.typeDefinitionBuilder.getEnums().map(e=>({...e,description:this.getTypeDocumentation(e.rawType)})),this.schema.types=this.schema.types.filter(e=>!this.schema.enums.find(s=>s.name===e.name)),this.schema.inputs=this.schema.inputs.filter(e=>!this.schema.enums.find(s=>s.name===e.name)),this.schema.unions.forEach(e=>{let s=this.checkIfInterfaceIsPossibleForUnion(e,this.schema.types);s&&(this.schema.interfaces.push(s),this.schema.unions=this.schema.unions.filter(n=>n.name!==e.name),this.schema.types.map(n=>{if(e.types.includes(n.name))return n.implements||(n.implements=[]),n.implements.push(s.name),n}))});for(let[e,s]of t.classImplementsMap){this.schema.types.map(n=>{let o=this.schema.types.find(i=>i.rawType===e);return o&&(o.implements=Array.from(new Set([...o.implements||[],...s.map(i=>this.checker.typeToString(i))]))),n});for(let n of s){let o=this.schema.types.find(i=>i.rawType===n);o&&(this.schema.interfaces.push({name:this.checker.typeToString(n),description:this.getTypeDocumentation(n),fields:o.fields}),this.schema.types=this.schema.types.filter(i=>i.rawType!==n))}}this.schema.types=this.schema.types.map(e=>((e.implements||this.schema.unions.find(s=>s.types.includes(e.name)))&&(e.fields=e.fields.filter(s=>s.type.name!=="Void")),e)),this.schema.unions=this.schema.unions.map(e=>({...e,__resolveType:this.getResolveTypeForUnionOrInterface(e,this.schema.types)})),this.schema.interfaces=this.schema.interfaces.map(e=>({...e,__resolveType:this.getResolveTypeForUnionOrInterface(e,this.schema.types)}))}checkIfInterfaceIsPossibleForUnion(r,t){let e=r.types.map(o=>{let i=t.find(l=>l.name===o);if(!i)throw new Error(`Type ${o} not found`);return i}),n=e[0].fields.filter(o=>e.every(i=>i.fields.some(l=>JSON.stringify(l)===JSON.stringify(o))));return n.length>0?{name:r.name,description:r.description,fields:n}:null}getResolveTypeForUnionOrInterface(r,t){let e="types"in r?t.filter(i=>r.types.includes(i.name)):t.filter(i=>i.implements?.includes(r.name));e.sort((i,l)=>l.fields.length-i.fields.length);let s=new Map;e.forEach(i=>{let l=i.fields.map(p=>p.name).sort().join(", ");if(s.has(l)){let p=s.get(l);z.warn(`Warning: Union types "${i.name}" and "${p?.name}" have the same fields: [${l}].
|
|
21
|
+
${f.detail?f.detail:""}`);throw new Error("Failed to build Pylon")}if(o.warnings.length>0)for(let f of o.warnings)k.warn(f);let n=Date.now()-i,a=Object.keys(o.metafile.inputs).length,l=Object.values(o.metafile.outputs).reduce((f,g)=>f+g.bytes,0),p=await e();k.success(`[Pylon]: Built in ${n}ms`);let u=p!==s;u&&(k.info("[Pylon]: Schema updated"),s=p),r&&await r({totalFiles:a,totalSize:l,schemaChanged:u,duration:n})})}});var $=class{sfiFilePath;outputDir;constructor(r,t="./.pylon"){this.sfiFilePath=r,this.outputDir=t}async initBuildPlugins(r){let t=O.join(process.cwd(),this.outputDir,"index.js"),e;try{e=(await import(t)).config}catch(o){console.error("Error loading config",o)}let s=[],i=e?.plugins||[];for(let o of i)if(o.build){let n=o.build({onBuild:r.onBuild});s.push(n)}return s}async build(r){let t=O.join(process.cwd(),this.sfiFilePath),e=O.join(process.cwd(),this.outputDir);await ne.mkdir(e,{recursive:!0});let s={name:"write-on-end",setup(n){n.onEnd(async a=>{a.outputFiles?.forEach(async l=>{await ne.mkdir(O.dirname(l.path),{recursive:!0}),await v(l.path,l.text)})})}},i=await ye({write:!1,logLevel:"silent",metafile:!0,entryPoints:[t],outdir:e,bundle:!0,format:"esm",sourcemap:"inline",packages:"external",plugins:[ie({dir:e,onBuild:async n=>{await r.onBuild?.(n)}}),X({getBuildDefs:r.getBuildDefs,outputDir:this.outputDir}),de({tsconfigPath:O.join(process.cwd(),"tsconfig.json")}),s]}),o=await this.initBuildPlugins({onBuild:()=>{r.onBuild?.({totalFiles:0,totalSize:0,schemaChanged:!1,duration:0})}});return{watch:async()=>{for(let n of o)await(await n).watch();return await i.watch()},rebuild:async()=>{for(let n of o)await(await n).rebuild();await i.rebuild()},dispose:async()=>{for(let n of o)await(await n).dispose();await i.dispose()},cancel:async()=>{for(let n of o)await(await n).cancel();await i.cancel()}}}};import S from"typescript";import F from"typescript";import y from"typescript";var se=c=>c.flags&y.TypeFlags.Object&&c.getProperties().length===0&&c.getCallSignatures().length===0,N=(c,r)=>{let t=c.typeToTypeNode(r,void 0,void 0),e=!!(t&&(t.kind===y.SyntaxKind.ArrayType||t.kind===y.SyntaxKind.TupleType));return!e&&r.getSymbol()?.getName()==="Array"?!0:e};var b=c=>c.flags&y.TypeFlags.String||c.flags&y.TypeFlags.Number||c.flags&y.TypeFlags.Boolean||c.flags&y.TypeFlags.StringLiteral||c.flags&y.TypeFlags.NumberLiteral||c.flags&y.TypeFlags.BooleanLiteral,_=c=>c.getCallSignatures().length>0,x=c=>b(c)?!1:!!(c.types?.length>1&&c.types.every(e=>e.flags&y.TypeFlags.StringLiteral||e.flags&y.TypeFlags.NumberLiteral||e.flags&y.TypeFlags.BooleanLiteral)),j=c=>c.getSymbol()?.getName()==="Promise",I=c=>{if(c.objectFlags&y.ObjectFlags.Reference){let e=c.typeArguments;if(e&&e.length>0)return e[0]}},re=c=>{if(!c.isUnion())return{type:c,wasOptional:!1};let t=c.types.filter(e=>!(e.flags&y.TypeFlags.Undefined||e.flags&y.TypeFlags.Null)).length!==c.types.length;return{type:c.getNonNullableType(),wasOptional:t}};function oe(c,r){let t=r;if(t.isUnion()){let i=t.types.filter(a=>!(a.flags&y.TypeFlags.Object&&a.objectFlags&y.ObjectFlags.Reference&&a.typeArguments?.length)),o=t.types.filter(a=>a.flags&y.TypeFlags.Object&&a.objectFlags&y.ObjectFlags.Reference&&a.typeArguments?.length).map(a=>a.typeArguments[0]),n=i.filter(a=>!o.some(l=>l===a));t=c.getUnionType(n)}let e=[];if(N(c,t)||b(t)||x(t))return e;let s=[];s=t.resolvedProperties||t.getProperties()||[];for(let i of s)(i.valueDeclaration&&!(y.getCombinedModifierFlags(i.valueDeclaration)&y.ModifierFlags.Private)&&!i.getName().startsWith("#"))!==!1&&e.push(i);return e}var D=c=>c.replace(/[^0-9a-zA-Z_]/g,"_"),L=c=>!!c.getSymbol()?.getDeclarations()?.some(r=>r.getSourceFile().fileName.includes("@repeaterjs"));import w from"typescript";var B=class{checker;schema;typesNameMap=new Map;inputsNameMap=new Map;unions=[];enums=[];constructor(r,t){this.checker=r,this.schema=t}getTypeDefinition=(r,t={isInputType:!1})=>{let{type:e,wasOptional:s}=re(r);if(e.flags&w.TypeFlags.Void||e.flags&w.TypeFlags.Undefined||e.flags&w.TypeFlags.Null)return{name:"Void",isList:!1,isRequired:!1};if(L(e)){let l=this.checker.getTypeArguments(e)[0];if(l)return this.getTypeDefinition(l,t)}if(j(e)){let l=I(e);if(l)return this.getTypeDefinition(l,t)}let i=t.isRequired!==void 0?t.isRequired:!s;if(se(e))return{name:"Object",isList:!1,isRequired:i};let o=t.isInputType?this.inputsNameMap:this.typesNameMap;if(o.has(e))return{name:o.get(e),isList:!1,isRequired:i};let n=e.aliasSymbol?.escapedName?.toString()||e.symbol?.escapedName.toString();(n==="__type"||n==="__object")&&(t.propertyName?n=t.propertyName.charAt(0).toUpperCase()+t.propertyName.slice(1):n=void 0),n&&(n=D(n));let a=l=>Array.from(o.values()).includes(l);if(n&&!this.schema.scalars.includes(n)){t.isInputType&&(n=`${n}Input`);let l=1,p=n;for(;a(n);)n=`${p}_${l}`,l++}if(n&&this.schema.scalars.includes(n))return{name:n,isList:!1,isRequired:i};if(N(this.checker,e)){let l=this.checker.getIndexTypeOfType(e,w.IndexKind.Number);if(l){let p=this.getTypeDefinition(l,t);return{name:p.name,isList:!0,isRequired:p.isRequired,isListRequired:i}}}else if(x(e)){let l=this.checker.typeToTypeNode(e,void 0,void 0),u=e.types.map(f=>{if(f.isLiteral()){let g=f.value?.toString();if(!g)throw new Error("Enum member name is undefined");return D(g)}throw new Error("Invalid type for enum member")});u.length>0&&(n=n||l.typeName?.symbol?.escapedName,n||(n=u.join("_").toUpperCase(),n=t.isInputType?`${n}Input`:n),this.enums.push({name:n,values:u,rawType:e}))}else if(b(e)){let l=this.checker.typeToString(e);return e.flags&w.TypeFlags.StringLiteral?l="String":e.flags&w.TypeFlags.NumberLiteral?l="Number":e.flags&w.TypeFlags.BooleanLiteral?l="Boolean":e.flags&w.TypeFlags.String?l="String":e.flags&w.TypeFlags.Number?l="Number":e.flags&w.TypeFlags.Boolean&&(l="Boolean"),{name:D(l),isList:!1,isRequired:i}}else if(e.isIntersection()){let p=e.types.map(u=>this.getTypeDefinition(u,t).name);n=D(n||p.join("And"))}else if(e.isUnion()){let l=e.types,p=e.types.length===l.length,u=l.some(m=>{let h=N(this.checker,m)?this.checker.getIndexTypeOfType(m,w.IndexKind.Number):m;return h?b(h)||x(h):!0}),f=[...new Set(l.map(m=>this.getTypeDefinition(m,{...t,isRequired:p})))],g=f.filter(m=>m.isList);for(let m of g){let h=f.findIndex(T=>T.name===m.name&&!T.isList);h>-1&&f.splice(h,1)}let d=f.map(m=>m.name);if(n=D(n||d.join("Or")),n){let m=1,h=n;for(;a(n);)n=`${h}_${m}`,m++}if(f.length>1&&!t.isInputType&&!u)this.unions.push({name:n,types:d,rawType:e});else{let m=f[0];if(!m)throw new Error("Cannot get type definition");let h=f.some(T=>T.isList&&T.name===m.name);return{name:m.name,isList:h,isRequired:i}}}else if(_(e)){let p=e.getCallSignatures()[0]?.getReturnType();if(p&&j(p)){let u=I(p);u&&(p=u)}if(p)return this.getTypeDefinition(p,t)}return n||(n="Any"),o.set(e,n),{name:n,isList:!1,isRequired:i}};getUnions(){return this.unions}getEnums(){return this.enums}typeDefinitionToGraphQLType=r=>{let t=r.name,{isList:e,isRequired:s,isListRequired:i}=r;return s&&(t=`${t}!`),e&&(t=`[${t}]`,i&&(t=`${t}!`)),t}};import H from"consola";var U=class{schema;checker;program;sfiFile;typeDefinitionBuilder;constructor(r,t,e){this.schema={types:[],inputs:[],interfaces:[],unions:[],enums:[],scalars:["ID","Int","Float","Number","Any","Void","Object","File","Date","JSON","String","Boolean"]},this.checker=r,this.sfiFile=t,this.program=e,this.typeDefinitionBuilder=new B(r,this.schema)}parse(r){let t=this.makeReferenceSchema(r);for(let[e,s]of t.types){let i;r.Query===e?i="Query":r.Mutation===e?i="Mutation":r.Subscription===e&&(i="Subscription"),this.processSchemaReference(e,s,i,"types")}for(let[e,s]of t.inputs)this.processSchemaReference(e,s,void 0,"inputs");this.extractForbiddenFieldNamesFromSchema(),this.schema.unions=this.typeDefinitionBuilder.getUnions().map(e=>({...e,description:this.getTypeDocumentation(e.rawType)})),this.schema.enums=this.typeDefinitionBuilder.getEnums().map(e=>({...e,description:this.getTypeDocumentation(e.rawType)})),this.schema.types=this.schema.types.filter(e=>!this.schema.enums.find(s=>s.name===e.name)),this.schema.inputs=this.schema.inputs.filter(e=>!this.schema.enums.find(s=>s.name===e.name)),this.schema.unions.forEach(e=>{let s=this.checkIfInterfaceIsPossibleForUnion(e,this.schema.types);s&&(this.schema.interfaces.push(s),this.schema.unions=this.schema.unions.filter(i=>i.name!==e.name),this.schema.types.map(i=>{if(e.types.includes(i.name))return i.implements||(i.implements=[]),i.implements.push(s.name),i}))});for(let[e,s]of t.classImplementsMap){this.schema.types.map(i=>{let o=this.schema.types.find(n=>n.rawType===e);return o&&(o.implements=Array.from(new Set([...o.implements||[],...s.map(n=>this.checker.typeToString(n))]))),i});for(let i of s){let o=this.schema.types.find(n=>n.rawType===i);o&&(this.schema.interfaces.push({name:this.checker.typeToString(i),description:this.getTypeDocumentation(i),fields:o.fields}),this.schema.types=this.schema.types.filter(n=>n.rawType!==i))}}this.schema.types=this.schema.types.map(e=>((e.implements||this.schema.unions.find(s=>s.types.includes(e.name)))&&(e.fields=e.fields.filter(s=>s.type.name!=="Void")),e)),this.schema.unions=this.schema.unions.map(e=>({...e,__resolveType:this.getResolveTypeForUnionOrInterface(e,this.schema.types)})),this.schema.interfaces=this.schema.interfaces.map(e=>({...e,__resolveType:this.getResolveTypeForUnionOrInterface(e,this.schema.types)}))}checkIfInterfaceIsPossibleForUnion(r,t){let e=r.types.map(o=>{let n=t.find(a=>a.name===o);if(!n)throw new Error(`Type ${o} not found`);return n}),i=e[0].fields.filter(o=>e.every(n=>n.fields.some(a=>JSON.stringify(a)===JSON.stringify(o))));return i.length>0?{name:r.name,description:r.description,fields:i}:null}getResolveTypeForUnionOrInterface(r,t){let e="types"in r?t.filter(n=>r.types.includes(n.name)):t.filter(n=>n.implements?.includes(r.name));e.sort((n,a)=>a.fields.length-n.fields.length);let s=new Map;e.forEach(n=>{let a=n.fields.map(l=>l.name).sort().join(", ");if(s.has(a)){let l=s.get(a);H.warn(`Warning: Union types "${n.name}" and "${l?.name}" have the same fields: [${a}].
|
|
22
22
|
Consider differentiating these types by adding unique fields or using different type names.
|
|
23
|
-
This may cause ambiguity in type resolution.`)}else s.set(
|
|
23
|
+
This may cause ambiguity in type resolution.`)}else s.set(a,n)});let o=`function resolveType(node) { if (node && typeof node === 'object') { ${e.map(n=>`if (${n.fields.map(p=>`"${p.name}" in node`).join(" && ")}) {return '${n.name}'};`).join(" ")} } }`;return new Function("return "+o)()}toString(){let{typeDefinitionToGraphQLType:r}=this.typeDefinitionBuilder,t=s=>s?`"""
|
|
24
24
|
${s}
|
|
25
25
|
"""
|
|
26
26
|
`:"",e="";for(let s of this.schema.inputs){e+=t(s.description),e+=`input ${s.name} {
|
|
27
27
|
`,s.fields.length===0&&(e+=` _ : String
|
|
28
|
-
`);for(let
|
|
28
|
+
`);for(let i of s.fields)e+=`${t(i.type.description)}`,e+=` ${i.name}: ${r(i.type)}
|
|
29
29
|
`;e+=`}
|
|
30
30
|
`}for(let s of this.schema.types)if(s.fields.length!==0){e+=t(s.description),e+=`type ${s.name}`,s.implements&&(e+=` implements ${s.implements.join(" & ")}`),e+=` {
|
|
31
|
-
`;for(let
|
|
31
|
+
`;for(let i of s.fields){let o="";i.args.length>0&&(o=`(${i.args.map(n=>`${t(n.type.description)}${n.name}: ${r(n.type)}`).join(", ")})`),e+=`${t(i.type.description)}`,e+=`${i.name}${o}: ${r(i.type)}
|
|
32
32
|
`}e+=`}
|
|
33
33
|
`}for(let s of this.schema.unions)e+=t(s.description),e+=`union ${s.name} = ${s.types.join(" | ")}
|
|
34
34
|
`;for(let s of this.schema.interfaces){e+=t(s.description),e+=`interface ${s.name} {
|
|
35
|
-
`;for(let
|
|
35
|
+
`;for(let i of s.fields)e+=`${t(i.type.description)}`,e+=`${i.name}: ${r(i.type)}
|
|
36
36
|
`;e+=`}
|
|
37
37
|
`}for(let s of this.schema.scalars)e+=`scalar ${s}
|
|
38
38
|
`;for(let s of this.schema.enums){e+=t(s.description),e+=`enum ${s.name} {
|
|
39
|
-
`;for(let
|
|
39
|
+
`;for(let i of s.values)e+=` ${i}
|
|
40
40
|
`;e+=`}
|
|
41
|
-
`}return e}getSchema(){return this.schema}getResolvers(){let r={};for(let t of this.schema.unions)r[t.name]={__resolveType:t.__resolveType};for(let t of this.schema.interfaces)r[t.name]={__resolveType:t.__resolveType};return r}processSchemaReference(r,t,e,s="types"){let{getTypeDefinition:
|
|
41
|
+
`}return e}getSchema(){return this.schema}getResolvers(){let r={};for(let t of this.schema.unions)r[t.name]={__resolveType:t.__resolveType};for(let t of this.schema.interfaces)r[t.name]={__resolveType:t.__resolveType};return r}processSchemaReference(r,t,e,s="types"){let{getTypeDefinition:i}=this.typeDefinitionBuilder,o=s==="inputs",n=i(r,{isInputType:o}),a=e||n.name,l=this.schema[s].find(p=>p.name===a);if(!l){if(this.schema.scalars.includes(a))return;this.schema[s].push({name:a,description:this.getTypeDocumentation(r),fields:[],rawType:N(this.checker,r)&&(r.getNumberIndexType()||r.getStringIndexType())||r}),l=this.schema[s][this.schema[s].length-1]}for(let[p,u]of Object.entries(t)){let f=u.returnType,g=i(f,{isInputType:o,propertyName:p});if(s==="types"){let d={name:p,type:{...g,description:this.getTypeDocumentation(f)},args:[]};if(u.args)for(let[m,h]of Object.entries(u.args)){let T=h,P=i(T.type,{isInputType:!0,propertyName:m,isRequired:h.isRequired});this.schema.scalars.includes(this.checker.typeToString(T.type))&&(P.name=this.checker.typeToString(T.type)),d.args.push({name:m,type:{...P,description:T.documentation}})}l.fields.push(d)}else if(s==="inputs"){let d={name:p,type:{...g,description:this.getTypeDocumentation(f)}};l.fields.find(m=>m.name===d.name)||l.fields.push(d)}}}getSymbolDocumentation(r){let t="";t+=F.displayPartsToString(r.getDocumentationComment(this.checker));let e=r.getJsDocTags(this.checker).map(s=>`@${s.name} ${F.displayPartsToString(s.text)}`).join(`
|
|
42
42
|
`);return e&&(t+=`
|
|
43
|
-
`+e),t}getTypeDocumentation=r=>{let t=r.getSymbol();return t?this.getSymbolDocumentation(t):""};extractForbiddenFieldNamesFromSchema(){let r=/^[_A-Za-z][_0-9A-Za-z]*$/,t=e=>r.test(e)?e.startsWith("__"):!0;for(let e of this.schema.types)e.fields=e.fields.filter(s=>!t(s.name));for(let e of this.schema.inputs)e.fields=e.fields.filter(s=>!t(s.name))}makeReferenceSchema(r){let t={types:new Map,inputs:new Map,classImplementsMap:new Map},e=(
|
|
43
|
+
`+e),t}getTypeDocumentation=r=>{let t=r.getSymbol();return t?this.getSymbolDocumentation(t):""};extractForbiddenFieldNamesFromSchema(){let r=/^[_A-Za-z][_0-9A-Za-z]*$/,t=e=>r.test(e)?e.startsWith("__"):!0;for(let e of this.schema.types)e.fields=e.fields.filter(s=>!t(s.name));for(let e of this.schema.inputs)e.fields=e.fields.filter(s=>!t(s.name))}makeReferenceSchema(r){let t={types:new Map,inputs:new Map,classImplementsMap:new Map},e=(i,o={},n="types",a=[])=>{if(t[n].has(i))return;if(L(i)){let p=this.checker.getTypeArguments(i)[0];e(p,o,n,[...a,"REPEATER_ITEM"]);return}if(this.checker.typeToString(i)!=="[]"&&!this.schema.scalars.includes(this.checker.typeToString(i))&&!b(i)){if(j(i)){if(n==="inputs")return;let p=I(i);p&&e(p,o,n,[...a,"PROMISE"]);return}if(i.isClass()){let p=i.getBaseTypes();p&&p.forEach(u=>{t.classImplementsMap.has(u)||t.classImplementsMap.set(u,[]),t.classImplementsMap.get(u).push(i)})}if(i.isUnion())if(x(i))t[n].has(i)||t[n].set(i,{}),e(i,o,n,[...a,"ENUM"]);else if(n==="types")i.types.forEach(p=>{p.flags&F.TypeFlags.Null||p.flags&F.TypeFlags.Undefined||b(p)||e(p,o,n,[...a,p.symbol?.getName()||`N/A ${this.checker.typeToString(p)}`])});else{let p=i.getNonNullableType();p.isUnion()&&!b(p)&&(H.warn(`Warning: Union types in input fields are not supported yet. Defaulting to the first type (${this.checker.typeToString(p)}) at path: ${a.join(" > ")}`),p=p.types[0]),e(p,o,n,[...a,"NON_NULLABLE"])}else if(_(i)){if(n==="inputs")return;if(!o.parentType)throw new Error("Cannot have a function without a parent type");let p=i.getCallSignatures()[0],u=p?.getParameters()||[],f=p?.getReturnType(),g=t[n].get(o.parentType)[o.propetyName];u.forEach(d=>{let m=this.checker.getTypeOfSymbolAtLocation(d,this.sfiFile);if(this.checker.isTupleType(m))m.target.labeledElementDeclarations.forEach((P,Fe)=>{let K=this.checker.getTypeAtLocation(P),V=P.name.text,pe=this.checker.getSymbolAtLocation(P),le=this.getSymbolDocumentation(pe||d);g.args[V]={type:K,isRequired:P.initializer===void 0?void 0:!1,documentation:le},e(K,{parentType:i},"inputs",[...a,V])});else if(d.valueDeclaration&&F.isParameter(d.valueDeclaration)&&d.valueDeclaration.dotDotDotToken)H.warn(`Warning: Rest parameters without explicit names are not supported. Skipping rest parameter at path: ${a.join(" > ")}.
|
|
44
44
|
|
|
45
45
|
Unsupported: \`function example(...args: any[]) { }\`.
|
|
46
46
|
Supported: \`function example(...namedArgs: [first: string, second: number]) { }\`.
|
|
47
|
-
Please provide named rest parameters to ensure proper type resolution.`);else{let
|
|
48
|
-
|
|
47
|
+
Please provide named rest parameters to ensure proper type resolution.`);else{let h=d.valueDeclaration;g.args&&(g.args[d.escapedName]={type:m,isRequired:h.initializer===void 0?void 0:!1,documentation:this.getSymbolDocumentation(d)},e(m,{parentType:i},"inputs",[...a,d.escapedName]))}}),f&&e(f,o,n,[...a,"RETURN_TYPE"])}else if(N(this.checker,i)){let p=this.checker.getIndexTypeOfType(i,F.IndexKind.Number);p&&!b(p)&&(t[n].has(i)||t[n].set(i,{}),e(p,o,n,[...a,"ITEM_TYPE"]))}else if(!b(i)){let p=oe(this.checker,i);t[n].has(i)||t[n].set(i,{}),p.forEach(u=>{let f=this.checker.getTypeOfSymbolAtLocation(u,this.sfiFile);t[n].get(i)[u.escapedName]||(t[n].get(i)[u.escapedName]={returnType:f,args:{}}),e(f,{propetyName:u.escapedName,parentType:i},n,[...a,u.escapedName])})}}};r.Query&&e(r.Query),r.Mutation&&e(r.Mutation),r.Subscription&&e(r.Subscription);let s=this.program.getSourceFiles();for(let i of s)F.forEachChild(i,o=>{if(F.isClassDeclaration(o)){let n=o.heritageClauses?.flatMap(a=>a.types.map(l=>l))||[];if(n.length>0)for(let a of n)t.types.has(this.checker.getTypeAtLocation(a))&&(t.classImplementsMap.set(this.checker.getTypeAtLocation(o),[this.checker.getTypeAtLocation(a)]),e(this.checker.getTypeAtLocation(o)))}});return t}};import C from"path";var M=class{program;checker;sfiFile;sfi;sfiFilePath;constructor(r){this.sfiFilePath=r;let t=this.loadTsConfigOptions(),e=S.sys.readDirectory(C.dirname(this.sfiFilePath),[".ts"],[".d.ts"]).concat([C.join(C.dirname(this.sfiFilePath),"..","pylon.d.ts")]);this.program=S.createProgram(e,t),this.checker=this.program.getTypeChecker(),this.loadSfi()}loadSfi(){let t=this.program.getSourceFiles().find(o=>C.resolve(o.fileName)===this.sfiFilePath);if(!t)throw new Error("Could not find index.ts (pylon entrypoint)");this.sfiFile=t;let e=this.checker.getSymbolAtLocation(t),i=this.checker.getExportsOfModule(e).find(o=>o.escapedName==="graphql");if(!i)throw new Error("Could not find graphql export");this.sfi=i}loadTsConfigOptions(){let r={target:S.ScriptTarget.ESNext,module:S.ModuleKind.CommonJS,strict:!0,esModuleInterop:!0,skipLibCheck:!1,forceConsistentCasingInFileNames:!0,noImplicitAny:!0,experimentalDecorators:!0},t=S.findConfigFile(C.dirname(this.sfiFilePath),S.sys.fileExists,"tsconfig.json");if(!t)return console.log("Could not find tsconfig.json"),r;let e=S.readConfigFile(t,S.sys.readFile);return e.error?(console.log("Could not read tsconfig.json",e.error),r):S.parseJsonConfigFileContent(e.config,S.sys,C.dirname(t)).options}build(){let r=this.checker.getTypeOfSymbolAtLocation(this.sfi,this.sfiFile),t=r.getProperty("Query"),e=r.getProperty("Mutation"),s=r.getProperty("Subscription"),i=t?this.checker.getTypeOfSymbolAtLocation(t,this.sfiFile):void 0,o=e?this.checker.getTypeOfSymbolAtLocation(e,this.sfiFile):void 0,n=s?this.checker.getTypeOfSymbolAtLocation(s,this.sfiFile):void 0,a=new U(this.checker,this.sfiFile,this.program);return a.parse({Query:i,Mutation:o,Subscription:n}),{typeDefs:a.toString(),schema:a.getSchema(),resolvers:a.getResolvers()}}};var J=async c=>{let r=new $(c.sfiFilePath,c.outputFilePath),t=new M(he.join(process.cwd(),c.sfiFilePath));return await r.build({getBuildDefs:()=>{let e=t.build();return{typeDefs:e.typeDefs,resolvers:e.resolvers}},onBuild:c.onBuild})};import G from"path";import q from"fs/promises";import{generateClient as ge}from"@gqty/cli";import{buildSchema as Te}from"graphql";var ae=G.join(process.cwd(),".pylon/schema.graphql"),Q=G.join(process.cwd(),".pylon/client/index.ts"),W=async({schemaChanged:c})=>{try{await q.access(ae)}catch{throw new Error("Schema not found. Please run `pylon build` or `pylon dev` first.")}if(!c)try{await q.access(Q);return}catch{}let r=await q.readFile(ae,"utf-8"),t=Te(r);await q.mkdir(G.dirname(Q),{recursive:!0}),await v(Q,be),await ge(t,{endpoint:"will-be-overwritten",frameworks:["react"],destination:Q,react:!0,scalarTypes:{Number:"number",Object:"Record<string, unknown>"}})},be=`/**
|
|
48
|
+
* GQty: You can safely modify this file based on your needs.
|
|
49
|
+
*/
|
|
49
50
|
|
|
50
|
-
|
|
51
|
+
import {createReactClient} from '@gqty/react'
|
|
52
|
+
import {
|
|
53
|
+
Cache,
|
|
54
|
+
createClient,
|
|
55
|
+
defaultResponseHandler,
|
|
56
|
+
type QueryFetcher
|
|
57
|
+
} from 'gqty'
|
|
58
|
+
import {
|
|
59
|
+
generatedSchema,
|
|
60
|
+
scalarsEnumsHash,
|
|
61
|
+
type GeneratedSchema
|
|
62
|
+
} from './schema.generated'
|
|
51
63
|
|
|
52
|
-
|
|
53
|
-
|
|
64
|
+
const queryFetcher: QueryFetcher = async function (
|
|
65
|
+
{query, variables, operationName},
|
|
66
|
+
fetchOptions
|
|
67
|
+
) {
|
|
68
|
+
let browserOrInternalFetch: typeof fetch | typeof app.request = fetch
|
|
54
69
|
|
|
55
|
-
|
|
56
|
-
|
|
70
|
+
try {
|
|
71
|
+
const moduleNameToPreventBundling = '@getcronit/pylon'
|
|
72
|
+
const {app} = await import(moduleNameToPreventBundling)
|
|
73
|
+
|
|
74
|
+
browserOrInternalFetch = app.request
|
|
75
|
+
} catch (error) {
|
|
76
|
+
// Pylon is not found. Maybe we are running in a different environment.
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
const response = await browserOrInternalFetch('/graphql', {
|
|
80
|
+
method: 'POST',
|
|
81
|
+
headers: {
|
|
82
|
+
'Content-Type': 'application/json'
|
|
83
|
+
},
|
|
84
|
+
body: JSON.stringify({
|
|
85
|
+
query,
|
|
86
|
+
variables,
|
|
87
|
+
operationName
|
|
88
|
+
}),
|
|
89
|
+
mode: 'cors',
|
|
90
|
+
...fetchOptions
|
|
91
|
+
})
|
|
92
|
+
|
|
93
|
+
return await defaultResponseHandler(response)
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const cache = new Cache(
|
|
97
|
+
undefined,
|
|
98
|
+
/**
|
|
99
|
+
* Default option is immediate cache expiry but keep it for 5 minutes,
|
|
100
|
+
* allowing soft refetches in background.
|
|
101
|
+
*/
|
|
102
|
+
{
|
|
103
|
+
maxAge: Infinity,
|
|
104
|
+
staleWhileRevalidate: 5 * 60 * 1000,
|
|
105
|
+
normalization: true
|
|
106
|
+
}
|
|
107
|
+
)
|
|
108
|
+
|
|
109
|
+
export const client = createClient<GeneratedSchema>({
|
|
110
|
+
schema: generatedSchema,
|
|
111
|
+
scalars: scalarsEnumsHash,
|
|
112
|
+
cache,
|
|
113
|
+
fetchOptions: {
|
|
114
|
+
fetcher: queryFetcher
|
|
115
|
+
}
|
|
116
|
+
})
|
|
117
|
+
|
|
118
|
+
// Core functions
|
|
119
|
+
export const {resolve, subscribe, schema} = client
|
|
120
|
+
|
|
121
|
+
// Legacy functions
|
|
122
|
+
export const {query, mutation, mutate, subscription, resolved, refetch, track} =
|
|
123
|
+
client
|
|
124
|
+
|
|
125
|
+
export const {
|
|
126
|
+
graphql,
|
|
127
|
+
useQuery,
|
|
128
|
+
usePaginatedQuery,
|
|
129
|
+
useTransactionQuery,
|
|
130
|
+
useLazyQuery,
|
|
131
|
+
useRefetch,
|
|
132
|
+
useMutation,
|
|
133
|
+
useMetaState,
|
|
134
|
+
prepareReactRender,
|
|
135
|
+
useHydrateCache,
|
|
136
|
+
prepareQuery
|
|
137
|
+
} = createReactClient<GeneratedSchema>(client, {
|
|
138
|
+
defaults: {
|
|
139
|
+
// Enable Suspense, you can override this option for each hook.
|
|
140
|
+
suspense: false
|
|
141
|
+
}
|
|
142
|
+
})
|
|
143
|
+
|
|
144
|
+
export * from './schema.generated'`;we.config();z.name("pylon-dev").description("Pylon Development CLI").version(Y);z.command("build").description("Build the Pylon Schema").action(async()=>{let c=await J({sfiFilePath:"./src/index.ts",outputFilePath:"./.pylon",onBuild:async({totalFiles:r,totalSize:t,duration:e,schemaChanged:s})=>{await ce.sendBuildEvent({duration:e,totalFiles:r,totalSize:t,isDevelopment:!1}),await W({schemaChanged:s})}});await c.rebuild(),await c.dispose()});z.name("dev").option("-c, --command <command>","Command to run the server","bun run .pylon/index.js").action(Se);async function Se(c,r){R.connect(async function(t){t&&(A.error(t),process.exit(1));let e=await J({sfiFilePath:"./src/index.ts",outputFilePath:"./.pylon",onBuild:async({schemaChanged:s,totalFiles:i,totalSize:o,duration:n})=>{await W({schemaChanged:s})}});await e.watch(),R.launchBus((s,i)=>{if(s){A.error(s);return}i.on("log:out",o=>{A.log(o.data)}),i.on("log:err",o=>{A.error(o.data)})}),R.start({name:"pylon-dev",script:c.command,exec_mode:"fork",instances:1,autorestart:!0,watch:["./.pylon"],restart_delay:1e3,watch_delay:1e3,ignore_watch:["node_modules"],env:{...process.env,NODE_ENV:"development"}},function(s,i){if(s)throw s;A.box(`
|
|
145
|
+
Pylon is up and running!
|
|
146
|
+
|
|
147
|
+
Press \`Ctrl + C\` to stop the server.
|
|
148
|
+
|
|
149
|
+
Encounter any issues? Report them here:
|
|
150
|
+
https://github.com/getcronit/pylon/issues
|
|
151
|
+
|
|
152
|
+
We value your feedback\u2014help us make Pylon even better!`)}),process.on("SIGINT",async s=>{await e.cancel(),R.delete("pylon-dev",function(i){R.disconnect(),process.exit(0)})})})}z.parse();
|
|
57
153
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/index.ts", "../package.json", "../src/builder/index.ts", "../src/builder/bundler/bundler.ts", "../src/builder/bundler/plugins/inject-code-plugin.ts", "../src/builder/bundler/plugins/notify-plugin.ts", "../src/builder/schema/builder.ts", "../src/builder/schema/schema-parser.ts", "../src/builder/schema/types-helper.ts", "../src/builder/schema/type-definition-builder.ts"],
|
|
4
|
-
"sourcesContent": ["#!/usr/bin/env node\n\nimport {fetchSchema, generateClient} from '@gqty/cli'\nimport {program, type Command} from 'commander'\nimport consola from 'consola'\nimport path from 'path'\nimport {version} from '../package.json'\nimport {ChildProcess, spawn} from 'child_process'\nimport psTree from 'ps-tree'\nimport * as telemetry from '@getcronit/pylon-telemetry'\nimport dotenv from 'dotenv'\nimport {build} from './builder'\n\ndotenv.config()\n\nprogram.name('pylon-dev').description('Pylon Development CLI').version(version)\n\nprogram\n .command('build')\n .description('Build the Pylon Schema')\n .action(async () => {\n const ctx = await build({\n sfiFilePath: './src/index.ts',\n outputFilePath: './.pylon',\n onBuild: async ({totalFiles, totalSize, duration}) => {\n await telemetry.sendBuildEvent({\n duration,\n totalFiles,\n totalSize,\n isDevelopment: false\n })\n }\n })\n\n await ctx.rebuild()\n await ctx.dispose()\n })\n\nprogram\n .name('dev')\n .option(\n '-c, --command <command>',\n 'Command to run the server',\n 'bun run .pylon/index.js'\n )\n .option('--client', \"Generate the client from the server's schema\")\n .option('--test', 'Test')\n .option(\n '--client-path <clientPath>',\n 'Path to generate the client to',\n 'gqty/index.ts'\n )\n .option(\n '--client-port <clientPort>',\n 'Port of the pylon server to generate the client from',\n '3000'\n )\n .action(main)\n\ntype ArgOptions = {\n command: string\n client: boolean\n clientPath: string\n clientPort: string\n}\n\nconst start = Date.now()\n\nasync function main(options: ArgOptions, command: Command) {\n consola.log(`[Pylon]: ${command.name()} version ${command.version()}`)\n\n const ctx = await build({\n sfiFilePath: './src/index.ts',\n outputFilePath: `./.pylon`,\n onBuild: async ({schemaChanged, totalFiles, totalSize, duration}) => {\n const isServerRunning = currentProc !== null\n\n if (isServerRunning) {\n consola.start('[Pylon]: Reloading server')\n } else {\n consola.start('[Pylon]: Starting server')\n }\n\n await serve(schemaChanged)\n\n if (isServerRunning) {\n consola.ready('[Pylon]: Server reloaded')\n } else {\n consola.box(`\n Pylon is up and running!\n\n Press \\`Ctrl + C\\` to stop the server.\n\n Encounter any issues? Report them here: \n https://github.com/getcronit/pylon/issues\n\n We value your feedback\u2014help us make Pylon even better!\n `)\n }\n\n if (schemaChanged) {\n await telemetry.sendBuildEvent({\n duration,\n totalFiles,\n totalSize,\n isDevelopment: true\n })\n }\n }\n })\n\n async function killProcessAndChildren(pid: number) {\n await ctx.cancel()\n psTree(pid, (err, children) => {\n if (err) {\n console.error('Error fetching child processes:', err)\n return\n }\n\n // Kill the parent process and all its children\n const allPids = children.map(child => parseInt(child.PID)).concat(pid)\n allPids.forEach(childPid => {\n try {\n process.kill(childPid, 'SIGINT')\n } catch (error) {}\n })\n })\n }\n\n let currentProc: ChildProcess | null = null\n\n let serve = async (shouldGenerateClient: boolean = false) => {\n if (currentProc?.pid) {\n // Remove all listeners to prevent the pylon dev server from crashing\n currentProc.removeAllListeners()\n\n await killProcessAndChildren(currentProc.pid)\n }\n\n const [commandName, ...args] = options.command.split(' ')\n\n currentProc = spawn(commandName, args, {\n shell: true,\n stdio: 'inherit',\n env: {\n ...process.env,\n NODE_ENV: 'development'\n }\n })\n\n currentProc.on('exit', code => {\n // if (code === 143 || code === null) {\n // return\n // }\n\n if (code === 0) {\n consola.success('Pylon server stopped')\n process.exit(0)\n }\n\n consola.error(\n `Pylon exited with code ${code}, fix the error and save the file to restart the server`\n )\n })\n\n if (\n shouldGenerateClient &&\n options.client &&\n options.clientPath &&\n options.clientPort\n ) {\n const clientPath = path.resolve(process.cwd(), options.clientPath)\n\n const endpoint = `http://localhost:${options.clientPort}/graphql`\n\n console.log('Generating client...', endpoint)\n\n const generate = async () => {\n consola.start('[Pylon]: Fetching schema from server')\n\n const schema = await fetchSchema(endpoint, {\n silent: true\n })\n\n consola.success('[Pylon]: Schema fetched')\n\n consola.start('[Pylon]: Generating client')\n\n await generateClient(schema, {\n endpoint,\n destination: clientPath,\n react: true,\n scalarTypes: {\n Number: 'number',\n Object: 'Record<string, unknown>'\n }\n })\n\n consola.success('[Pylon]: Client generated')\n }\n\n let retries = 0\n\n const generateWithRetry = async () => {\n try {\n await generate()\n } catch (e) {\n retries++\n\n if (retries < 5) {\n setTimeout(() => {\n generateWithRetry()\n }, 1000)\n }\n }\n }\n\n generateWithRetry()\n }\n }\n\n try {\n await ctx.watch()\n } catch (e) {\n consola.error(\"[Pylon]: Couldn't build schema\", e)\n\n // Kill the server if it's running\n const proc = currentProc as ChildProcess | null\n if (proc?.pid) {\n proc.removeAllListeners()\n\n await killProcessAndChildren(proc.pid)\n }\n }\n\n process.on('SIGINT', async code => {\n try {\n if (currentProc?.pid) {\n currentProc.removeAllListeners()\n\n await killProcessAndChildren(currentProc.pid)\n }\n } catch {\n // Ignore\n } finally {\n await telemetry.sendDevEvent({\n duration: Date.now() - start,\n clientPath: options.clientPath,\n clientPort: parseInt(options.clientPort)\n })\n\n process.exit(0)\n }\n })\n}\n\nprogram.parse()\n", "{\n \"name\": \"@getcronit/pylon-dev\",\n \"type\": \"module\",\n \"version\": \"2.0.0-canary-20250206125311.f228add1e2e04c8af5d91db6063583bd317de463\",\n \"description\": \"CLI for creating a Pylon\",\n \"scripts\": {\n \"build\": \"rimraf ./dist && esbuild ./src/index.ts --bundle --platform=node --target=node18 --format=esm --minify --outdir=./dist --sourcemap=linked --packages=external\"\n },\n \"bin\": {\n \"pylon\": \"./dist/index.js\"\n },\n \"files\": [\n \"dist\"\n ],\n \"author\": \"Nico Schett <nico.schett@cronit.io>\",\n \"license\": \"Apache-2.0\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/getcronit/pylon.git\",\n \"directory\": \"packages/create-pylon\"\n },\n \"homepage\": \"https://pylon.cronit.io\",\n \"dependencies\": {\n \"@getcronit/pylon-telemetry\": \"workspace:^\",\n \"@gqty/cli\": \"^4.2.0\",\n \"commander\": \"^12.1.0\",\n \"consola\": \"^3.2.3\",\n \"dotenv\": \"^16.4.5\",\n \"ps-tree\": \"^1.2.0\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"engines\": {\n \"node\": \">=18.0.0\"\n },\n \"devDependencies\": {\n \"@types/ps-tree\": \"^1.1.6\",\n \"esbuild\": \"^0.23.1\",\n \"esbuild-plugin-tsc\": \"^0.4.0\",\n \"typescript\": \"^5.7.3\"\n },\n \"peerDependencies\": {\n \"@getcronit/pylon\": \"workspace:3.0.0-canary-20250206125311.f228add1e2e04c8af5d91db6063583bd317de463\"\n }\n}\n", "import path from 'path'\nimport {Bundler} from './bundler/bundler.js'\nimport {SchemaBuilder} from './schema/builder.js'\n\nexport interface BuildOptions {\n sfiFilePath: string\n outputFilePath: string\n onBuild?: (output: {\n totalFiles: number\n totalSize: number\n schemaChanged: boolean\n duration: number\n }) => void\n}\n\nexport {SchemaBuilder}\n\nexport const build = async (options: BuildOptions) => {\n const bundler = new Bundler(options.sfiFilePath, options.outputFilePath)\n\n return await bundler.build({\n getBuildDefs: () => {\n const builder = new SchemaBuilder(\n path.join(process.cwd(), options.sfiFilePath)\n )\n\n const built = builder.build()\n\n const typeDefs = built.typeDefs\n\n return {\n typeDefs: typeDefs,\n resolvers: built.resolvers\n }\n },\n onBuild: options.onBuild\n })\n}\n", "// bundler.ts\nimport {context} from 'esbuild'\nimport esbuildPluginTsc from 'esbuild-plugin-tsc'\nimport type {PylonConfig} from '@getcronit/pylon'\n\nimport path from 'path'\nimport {\n InjectCodePluginOptions,\n injectCodePlugin\n} from './plugins/inject-code-plugin'\nimport {NotifyPluginOptions, notifyPlugin} from './plugins/notify-plugin'\n\nexport interface BundlerBuildOptions {\n getBuildDefs: InjectCodePluginOptions['getBuildDefs']\n onBuild?: NotifyPluginOptions['onBuild']\n}\n\nexport class Bundler {\n sfiFilePath: string\n outputDir: string\n\n constructor(sfiFilePath: string, outputDir: string = './.pylon') {\n this.sfiFilePath = sfiFilePath\n this.outputDir = outputDir\n }\n\n private async loadAndExexConfigPluginsBuild() {\n const configPath = path.join(process.cwd(), this.outputDir, 'index.js')\n\n let config: PylonConfig | undefined\n try {\n let configModule = await import(configPath)\n\n config = configModule.config\n } catch (e) {\n console.error('Error loading config', e)\n }\n\n const plugins = config?.plugins || []\n\n for (const plugin of plugins) {\n if (plugin.build) {\n await plugin.build()\n }\n }\n }\n\n public async build(options: BundlerBuildOptions) {\n const inputPath = path.join(process.cwd(), this.sfiFilePath)\n const dir = path.join(process.cwd(), this.outputDir)\n\n const ctx = await context({\n logLevel: 'silent',\n metafile: true,\n entryPoints: [inputPath],\n outdir: dir,\n bundle: true,\n format: 'esm',\n sourcemap: 'inline',\n packages: 'external',\n\n plugins: [\n notifyPlugin({\n dir,\n onBuild: options.onBuild\n }),\n injectCodePlugin({\n getBuildDefs: options.getBuildDefs,\n outputDir: this.outputDir\n }),\n esbuildPluginTsc({\n tsconfigPath: path.join(process.cwd(), 'tsconfig.json')\n })\n ]\n })\n\n await this.loadAndExexConfigPluginsBuild()\n\n return ctx\n }\n}\n", "import {Plugin} from 'esbuild'\nimport path from 'path'\nimport fs from 'fs/promises'\n\nexport interface InjectCodePluginOptions {\n getBuildDefs: () => {\n typeDefs: string\n resolvers: Record<\n string,\n {\n __resolveType?: (obj: any) => string\n }\n >\n }\n outputDir: string\n}\n\nexport const injectCodePlugin = ({\n getBuildDefs,\n outputDir\n}: InjectCodePluginOptions): Plugin => ({\n name: 'inject-code',\n setup(build) {\n build.onLoad(\n {filter: /src[\\/\\\\]index\\.ts$/, namespace: 'file'},\n async args => {\n // Convert to relative path to ensure we match `src/index.ts` at root\n const relativePath = path.relative(process.cwd(), args.path)\n\n if (relativePath !== path.join('src', 'index.ts')) {\n return\n }\n\n const {typeDefs, resolvers} = getBuildDefs()\n\n const preparedResolvers = prepareObjectInjection(resolvers)\n\n const contents = await fs.readFile(args.path, 'utf-8')\n\n // Write the typeDefs to a file\n const typeDefsPath = path.join(\n process.cwd(),\n outputDir,\n 'schema.graphql'\n )\n\n await fs.writeFile(typeDefsPath, typeDefs)\n\n // Write base resolvers to a file\n\n const resolversPath = path.join(\n process.cwd(),\n outputDir,\n 'resolvers.js'\n )\n\n await fs.writeFile(\n resolversPath,\n `export const resolvers = ${preparedResolvers}`\n )\n\n return {\n loader: 'ts',\n contents:\n contents +\n `\n import {handler as __internalPylonHandler} from \"@getcronit/pylon\"\n\n let __internalPylonConfig = undefined\n\n try {\n __internalPylonConfig = config\n } catch {\n // config is not declared, pylonConfig remains undefined\n }\n\n app.use(__internalPylonHandler({\n typeDefs: ${JSON.stringify(typeDefs)},\n graphql,\n resolvers: ${preparedResolvers},\n config: __internalPylonConfig\n }))\n `\n }\n }\n )\n }\n})\n\nfunction prepareObjectInjection(obj: object) {\n const entries = Object.entries(obj).map(([key, value]) => {\n if (value === undefined) {\n return undefined\n } else if (typeof value === 'string') {\n return `${key}:${value}`\n } else if (typeof value === 'function') {\n return `${key}:${value.toString()}`\n } else if (typeof value === 'object' && !Array.isArray(value)) {\n return `${key}:${prepareObjectInjection(value)}`\n } else {\n return `${key}:${JSON.stringify(value)}`\n }\n })\n\n return `{${entries.join(',')}}`\n}\n", "import {Plugin} from 'esbuild'\nimport path from 'path'\nimport fs from 'fs/promises'\nimport consola from 'consola'\n\nexport interface NotifyPluginOptions {\n onBuild?: (output: {\n totalFiles: number\n totalSize: number\n schemaChanged: boolean\n duration: number\n }) => void\n dir: string\n}\n\nexport const notifyPlugin = ({dir, onBuild}: NotifyPluginOptions): Plugin => ({\n name: 'notify',\n async setup(build) {\n const loadSchema = async () => {\n const schemaPath = path.join(dir, 'schema.graphql')\n\n try {\n await fs.access(schemaPath)\n } catch {\n return null\n }\n\n return await fs.readFile(schemaPath, 'utf-8')\n }\n\n let cachedSchema: string | null = await loadSchema()\n\n let startTime = Date.now()\n build.onStart(async () => {\n startTime = Date.now()\n consola.start('[Pylon]: Building...')\n })\n\n build.onEnd(async result => {\n if (result.errors.length > 0) {\n for (const error of result.errors) {\n consola.error(`[Pylon]: ${error.text}\n${\n error.location\n ? `at ${error.location.file}:${error.location.line}:${error.location.column}`\n : ''\n}\n${error.detail ? error.detail : ''}`)\n }\n\n throw new Error('Failed to build Pylon')\n }\n\n if (result.warnings.length > 0) {\n for (const warning of result.warnings) {\n consola.warn(warning)\n }\n }\n\n const duration = Date.now() - startTime\n\n const totalFiles = Object.keys(result.metafile!.inputs).length\n\n const totalSize = Object.values(result.metafile!.outputs).reduce(\n (acc, output) => acc + output.bytes,\n 0\n )\n\n const latestSchema = await loadSchema()\n\n consola.success(`[Pylon]: Built in ${duration}ms`)\n\n const schemaChanged = latestSchema !== cachedSchema\n\n if (schemaChanged) {\n consola.info('[Pylon]: Schema updated')\n\n cachedSchema = latestSchema\n }\n\n if (onBuild) {\n onBuild({\n totalFiles,\n totalSize,\n schemaChanged: true,\n duration\n })\n }\n })\n }\n})\n", "import ts from 'typescript'\nimport {SchemaParser} from './schema-parser'\nimport path from 'path'\n\nexport class SchemaBuilder {\n private program: ts.Program\n private checker: ts.TypeChecker\n private sfiFile!: ts.SourceFile\n private sfi!: ts.Symbol\n private sfiFilePath: string\n\n constructor(sfiFilePath: string) {\n this.sfiFilePath = sfiFilePath\n\n const tsConfigOptions = this.loadTsConfigOptions()\n\n const filesInSfiDir = ts.sys\n .readDirectory(path.dirname(this.sfiFilePath), ['.ts'], ['.d.ts'])\n .concat([path.join(path.dirname(this.sfiFilePath), '..', 'pylon.d.ts')])\n\n this.program = ts.createProgram(filesInSfiDir, tsConfigOptions)\n\n this.checker = this.program.getTypeChecker()\n\n this.loadSfi()\n }\n\n private loadSfi() {\n const sourceFiles = this.program.getSourceFiles()\n\n const file = sourceFiles.find(\n file => path.resolve(file.fileName) === this.sfiFilePath\n )\n\n if (!file) {\n throw new Error('Could not find index.ts (pylon entrypoint)')\n }\n\n this.sfiFile = file\n\n const sfiFileSymbol = this.checker.getSymbolAtLocation(file)!\n const sfiFileExports = this.checker.getExportsOfModule(sfiFileSymbol!)\n const sfiFileDefaultExport = sfiFileExports.find(\n exportSymbol => exportSymbol.escapedName === 'graphql'\n )\n\n if (!sfiFileDefaultExport) {\n throw new Error('Could not find graphql export')\n }\n\n this.sfi = sfiFileDefaultExport\n }\n\n private loadTsConfigOptions() {\n const defaultOptions: ts.CompilerOptions = {\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.CommonJS,\n strict: true,\n esModuleInterop: true,\n skipLibCheck: false,\n forceConsistentCasingInFileNames: true,\n noImplicitAny: true,\n experimentalDecorators: true\n }\n\n // Find the tsconfig.json file\n const configPath = ts.findConfigFile(\n path.dirname(this.sfiFilePath), // Directory to start searching from\n ts.sys.fileExists, // Function to check if a file exists\n 'tsconfig.json' // File name to search for\n )\n\n if (!configPath) {\n console.log('Could not find tsconfig.json')\n return defaultOptions\n }\n\n // Read the tsconfig.json file\n const configFile = ts.readConfigFile(configPath, ts.sys.readFile)\n\n if (configFile.error) {\n console.log('Could not read tsconfig.json', configFile.error)\n return defaultOptions\n }\n\n // Parse the tsconfig.json file\n const parsedConfig = ts.parseJsonConfigFileContent(\n configFile.config,\n ts.sys,\n path.dirname(configPath)\n )\n\n return parsedConfig.options\n }\n\n public build() {\n const sfiType = this.checker.getTypeOfSymbolAtLocation(\n this.sfi,\n this.sfiFile\n )\n\n // const plainResolversProperty = sfiType.getProperty('plainResolvers')\n\n // if (!plainResolversProperty) {\n // throw new Error('Could not find plainResolvers property')\n // }\n\n // const plainResolversType = this.checker.getTypeOfSymbolAtLocation(\n // plainResolversProperty,\n // this.sfiFile\n // )\n\n const queryProperty = sfiType.getProperty('Query')\n const mutationProperty = sfiType.getProperty('Mutation')\n const subscriptionProperty = sfiType.getProperty('Subscription')\n\n const queryType = queryProperty\n ? this.checker.getTypeOfSymbolAtLocation(queryProperty, this.sfiFile)\n : undefined\n const mutationType = mutationProperty\n ? this.checker.getTypeOfSymbolAtLocation(mutationProperty, this.sfiFile)\n : undefined\n const subscriptionType = subscriptionProperty\n ? this.checker.getTypeOfSymbolAtLocation(\n subscriptionProperty,\n this.sfiFile\n )\n : undefined\n\n const parser = new SchemaParser(this.checker, this.sfiFile, this.program)\n\n parser.parse({\n Query: queryType,\n Mutation: mutationType,\n Subscription: subscriptionType\n })\n\n return {\n typeDefs: parser.toString(),\n schema: parser.getSchema(),\n resolvers: parser.getResolvers()\n }\n }\n}\n", "import ts from 'typescript'\nimport {\n getPromiseType,\n getPublicPropertiesOfType,\n isPrimitiveUnion,\n isFunction,\n isList,\n isPrimitive,\n isPromise,\n isSubscriptionRepeater\n} from './types-helper.js'\nimport {\n TypeDefinitionBuilder,\n Union as _Union,\n Enum as _Enum\n} from './type-definition-builder.js'\nimport consola from 'consola'\n\ntype Union = _Union & {\n description: string\n __resolveType?: (obj: any) => string\n}\n\ntype Interface = {\n name: string\n description: string\n fields: Array<Field>\n __resolveType?: (obj: any) => string\n}\n\ntype Enum = _Enum & {\n description: string\n}\n\ninterface TypeDefinition {\n name: string\n isList: boolean\n isRequired: boolean\n description: string\n}\n\ninterface Field {\n name: string\n type: TypeDefinition\n}\n\ninterface Input {\n name: string\n description: string\n fields: Array<{\n name: string\n type: TypeDefinition\n }>\n}\n\ninterface Type {\n name: string\n description: string\n fields: Array<\n Field & {\n args: Array<{\n name: string\n type: TypeDefinition\n }>\n }\n >\n implements?: Array<string>\n rawType: ts.Type\n}\n\nexport interface Schema {\n types: Array<Type>\n inputs: Array<Input>\n interfaces: Array<Interface>\n unions: Array<Union>\n enums: Array<Enum>\n scalars: Array<string>\n}\n\ntype ReferenceSchemaType = {\n returnType: ts.Type\n args: {\n // value needs to be inputs type\n [key: string]: {\n type: ts.Type\n isRequired?: boolean\n documentation: string\n }\n }\n}\n\ninterface ReferenceSchema {\n types: Map<\n ts.Type,\n {\n [key: string]: ReferenceSchemaType\n }\n >\n classImplementsMap: Map<ts.Type, ts.Type[]>\n inputs: ReferenceSchema['types']\n}\n\ninterface Index {\n Query?: ts.Type\n Mutation?: ts.Type\n Subscription?: ts.Type\n}\n\nexport class SchemaParser {\n private schema: Schema\n private checker: ts.TypeChecker\n private program: ts.Program\n private sfiFile: ts.SourceFile\n private typeDefinitionBuilder: TypeDefinitionBuilder\n\n constructor(\n checker: ts.TypeChecker,\n sfiFile: ts.SourceFile,\n program: ts.Program\n ) {\n this.schema = {\n types: [],\n inputs: [],\n interfaces: [],\n unions: [],\n enums: [],\n scalars: [\n 'ID',\n 'Int',\n 'Float',\n 'Number',\n 'Any',\n 'Void',\n 'Object',\n 'File',\n 'Date',\n 'JSON',\n 'String',\n 'Boolean'\n ]\n }\n\n this.checker = checker\n this.sfiFile = sfiFile\n this.program = program\n\n this.typeDefinitionBuilder = new TypeDefinitionBuilder(checker, this.schema)\n }\n\n public parse(index: Index) {\n const referenceSchema = this.makeReferenceSchema(index)\n\n for (const [type, properties] of referenceSchema.types) {\n let typeName: string | undefined = undefined\n\n if (index.Query === type) {\n typeName = 'Query'\n } else if (index.Mutation === type) {\n typeName = 'Mutation'\n } else if (index.Subscription === type) {\n typeName = 'Subscription'\n }\n\n this.processSchemaReference(type, properties, typeName, 'types')\n }\n\n for (const [type, properties] of referenceSchema.inputs) {\n this.processSchemaReference(type, properties, undefined, 'inputs')\n }\n\n this.extractForbiddenFieldNamesFromSchema()\n\n this.schema.unions = this.typeDefinitionBuilder\n .getUnions()\n .map((union): Union => {\n return {\n ...union,\n description: this.getTypeDocumentation(union.rawType)\n }\n })\n\n this.schema.enums = this.typeDefinitionBuilder\n .getEnums()\n .map((enumType): Enum => {\n return {\n ...enumType,\n description: this.getTypeDocumentation(enumType.rawType)\n }\n })\n\n // Remove `types` and `inputs` that are represented as enums\n this.schema.types = this.schema.types.filter(type => {\n return !this.schema.enums.find(e => e.name === type.name)\n })\n\n this.schema.inputs = this.schema.inputs.filter(input => {\n return !this.schema.enums.find(e => e.name === input.name)\n })\n\n // Go through all unions and check if it could be an interface\n\n this.schema.unions.forEach(union => {\n const interfaceUnion = this.checkIfInterfaceIsPossibleForUnion(\n union,\n this.schema.types\n )\n\n if (interfaceUnion) {\n this.schema.interfaces.push(interfaceUnion)\n\n // Remove the union from the types\n this.schema.unions = this.schema.unions.filter(\n type => type.name !== union.name\n )\n\n // Add the `implements` field to the types that implement the interface\n this.schema.types.map(type => {\n if (union.types.includes(type.name)) {\n if (!type.implements) {\n type.implements = []\n }\n\n type.implements.push(interfaceUnion.name)\n\n return type\n }\n })\n }\n })\n\n // // Go through all types and check if a type is an interface\n\n for (const [\n classType,\n implementingTypes\n ] of referenceSchema.classImplementsMap) {\n this.schema.types.map(type => {\n const schemaType = this.schema.types.find(t => t.rawType === classType)\n\n if (schemaType) {\n schemaType.implements = Array.from(\n new Set([\n ...(schemaType.implements || []),\n ...implementingTypes.map(t => this.checker.typeToString(t))\n ])\n )\n }\n\n return type\n })\n\n // Add the implementing types to the interfaces\n for (const implementingType of implementingTypes) {\n const schemaType = this.schema.types.find(\n t => t.rawType === implementingType\n )\n\n // Remove the implementing type from the types and add it to the interfaces\n\n if (schemaType) {\n this.schema.interfaces.push({\n name: this.checker.typeToString(implementingType),\n description: this.getTypeDocumentation(implementingType),\n fields: schemaType.fields\n })\n\n this.schema.types = this.schema.types.filter(\n type => type.rawType !== implementingType\n )\n }\n }\n }\n\n // Remove `Void` fields from types when they have a implementation or are part of a union\n this.schema.types = this.schema.types.map(type => {\n if (\n type.implements ||\n this.schema.unions.find(u => u.types.includes(type.name))\n ) {\n // Remove Void fields\n type.fields = type.fields.filter(field => {\n return field.type.name !== 'Void'\n })\n }\n\n return type\n })\n\n // Generate the __resolveType function for the unions\n this.schema.unions = this.schema.unions.map(union => {\n return {\n ...union,\n __resolveType: this.getResolveTypeForUnionOrInterface(\n union,\n this.schema.types\n )\n }\n })\n\n // Generate the __resolveType function for the interfaces\n this.schema.interfaces = this.schema.interfaces.map(intf => {\n return {\n ...intf,\n __resolveType: this.getResolveTypeForUnionOrInterface(\n intf,\n this.schema.types\n )\n }\n })\n }\n\n private checkIfInterfaceIsPossibleForUnion(\n union: Union,\n types: Array<Type>\n ): Interface | null {\n const unionTypes = union.types.map(t => {\n const type = types.find(type => type.name === t)\n\n if (!type) {\n throw new Error(`Type ${t} not found`)\n }\n\n return type\n })\n\n const baseType = unionTypes[0]\n\n // Check which fields are common in all types\n\n const commonFields = baseType.fields.filter(field => {\n return unionTypes.every(type => {\n return type.fields.some(\n f => JSON.stringify(f) === JSON.stringify(field)\n )\n })\n })\n\n if (commonFields.length > 0) {\n return {\n name: union.name,\n description: union.description,\n fields: commonFields\n }\n }\n\n return null\n }\n\n private getResolveTypeForUnionOrInterface(\n entity: Union | Interface,\n types: Array<Type>\n ) {\n const entityTypes =\n 'types' in entity\n ? types.filter(t => entity.types.includes(t.name))\n : types.filter(t => t.implements?.includes(entity.name))\n\n // Sort fieldTypes by the number of fields in descending order.\n // This prioritizes types with more properties, which are more likely\n // to match a given node, thus reducing ambiguity in type resolution.\n entityTypes.sort((a, b) => b.fields.length - a.fields.length)\n\n // Check for unions with the exact same fields\n const fieldSignatures = new Map<string, Type>()\n\n entityTypes.forEach(type => {\n // Create a signature based on sorted field names\n const fieldNames = type.fields\n .map(field => field.name)\n .sort()\n .join(', ')\n\n if (fieldSignatures.has(fieldNames)) {\n const existingType = fieldSignatures.get(fieldNames)\n consola.warn(\n `Warning: Union types \"${type.name}\" and \"${existingType?.name}\" have the same fields: [${fieldNames}]. ` +\n `\\nConsider differentiating these types by adding unique fields or using different type names.` +\n `\\nThis may cause ambiguity in type resolution.`\n )\n } else {\n fieldSignatures.set(fieldNames, type)\n }\n })\n\n const checks = entityTypes.map(type => {\n const fields = type.fields\n\n const fieldChecks = fields\n .map(field => `\"${field.name}\" in node`)\n .join(' && ')\n\n return `if (${fieldChecks}) {return '${type.name}'};`\n })\n\n const str = `function resolveType(node) { if (node && typeof node === 'object') { ${checks.join(\n ' '\n )} } }`\n\n return new Function('return ' + str)()\n }\n\n public toString() {\n const {typeDefinitionToGraphQLType} = this.typeDefinitionBuilder\n\n const addDescription = (description: string) => {\n if (!description) return ''\n\n return `\"\"\"\\n${description}\\n\"\"\"\\n`\n }\n\n // build a valid GraphQL schema string from the schema object\n let schemaString = ''\n\n // loop over the input objects in the schema\n for (const input of this.schema.inputs) {\n // add the input object to the schema string\n\n schemaString += addDescription(input.description)\n schemaString += `input ${input.name} {\\n`\n\n // add a nop field to the input object if it has no fields\n if (input.fields.length === 0) {\n schemaString += `\\t_ : String\\n`\n }\n\n // loop over the fields in the input object\n for (const field of input.fields) {\n // add the field to the input object in the schema string\n schemaString += `${addDescription(field.type.description)}`\n schemaString += `\\t${field.name}: ${typeDefinitionToGraphQLType(\n field.type\n )}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // loop over the type objects in the schema\n for (const type of this.schema.types) {\n if (type.fields.length === 0) continue\n\n // add the type object to the schema string\n schemaString += addDescription(type.description)\n schemaString += `type ${type.name}`\n if (type.implements) {\n schemaString += ` implements ${type.implements.join(' & ')}`\n }\n schemaString += ` {\\n`\n\n // loop over the fields in the type object\n for (const field of type.fields) {\n // build the argument list for the field if there is at least one argument\n let args = ''\n\n if (field.args.length > 0) {\n args = `(${field.args\n .map(\n arg =>\n `${addDescription(arg.type.description)}${\n arg.name\n }: ${typeDefinitionToGraphQLType(arg.type)}`\n )\n .join(', ')})`\n }\n\n // add the field to the type object in the schema string\n schemaString += `${addDescription(field.type.description)}`\n schemaString += `${field.name}${args}: ${typeDefinitionToGraphQLType(\n field.type\n )}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // loop over the union objects in the schema\n for (const union of this.schema.unions) {\n // add the union object to the schema string\n schemaString += addDescription(union.description)\n schemaString += `union ${union.name} = ${union.types.join(' | ')}\\n`\n }\n\n // loop over the interface objects in the schema\n for (const intf of this.schema.interfaces) {\n // add the interface object to the schema string\n schemaString += addDescription(intf.description)\n schemaString += `interface ${intf.name} {\\n`\n\n // loop over the fields in the interface object\n for (const field of intf.fields) {\n // add the field to the interface object in the schema string\n schemaString += `${addDescription(field.type.description)}`\n schemaString += `${field.name}: ${typeDefinitionToGraphQLType(\n field.type\n )}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // loop over the scalar objects in the schema\n for (const scalar of this.schema.scalars) {\n // add the scalar object to the schema string\n schemaString += `scalar ${scalar}\\n`\n }\n\n // loop over the enum objects in the schema\n for (const enumType of this.schema.enums) {\n // add the enum object to the schema string\n schemaString += addDescription(enumType.description)\n schemaString += `enum ${enumType.name} {\\n`\n\n // loop over the values in the enum object\n for (const value of enumType.values) {\n // add the value to the enum object in the schema string\n schemaString += `\\t${value}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // return the schema string\n return schemaString\n }\n\n public getSchema() {\n return this.schema\n }\n\n public getResolvers() {\n // Get union and interface resolvers\n\n const resolvers: Record<\n string,\n {\n __resolveType?: (obj: any) => string\n }\n > = {}\n\n // loop over the union objects in the schema\n for (const union of this.schema.unions) {\n resolvers[union.name] = {\n __resolveType: union.__resolveType\n }\n }\n\n // loop over the interface objects in the schema\n for (const intf of this.schema.interfaces) {\n resolvers[intf.name] = {\n __resolveType: intf.__resolveType\n }\n }\n\n return resolvers\n }\n\n private processSchemaReference(\n type: ts.Type,\n properties: {[key: string]: ReferenceSchemaType},\n typeName?: string,\n processing: 'inputs' | 'types' = 'types'\n ) {\n const {getTypeDefinition} = this.typeDefinitionBuilder\n\n const isInputType = processing === 'inputs'\n\n const def = getTypeDefinition(type, {isInputType})\n\n const name = typeName || def.name\n\n let root = this.schema[processing].find(t => t.name === name)\n\n if (!root) {\n if (this.schema.scalars.includes(name)) {\n return\n } else {\n this.schema[processing].push({\n name,\n description: this.getTypeDocumentation(type),\n fields: [],\n rawType: isList(this.checker, type)\n ? type.getNumberIndexType() || type.getStringIndexType() || type\n : type\n })\n\n root = this.schema[processing][this.schema[processing].length - 1]!\n }\n }\n\n for (const [propertyName, property] of Object.entries(properties)) {\n const fieldType = property.returnType\n\n const fieldDef = getTypeDefinition(fieldType, {\n isInputType,\n propertyName\n })\n\n if (processing === 'types') {\n const field: Type['fields'][number] = {\n name: propertyName,\n type: {\n ...fieldDef,\n description: this.getTypeDocumentation(fieldType)\n },\n args: []\n }\n\n if (property.args) {\n for (const [argName, arg] of Object.entries(property.args)) {\n const argType = arg\n\n const fieldDef = getTypeDefinition(argType.type, {\n isInputType: true,\n propertyName: argName,\n isRequired: arg.isRequired\n })\n\n if (\n this.schema.scalars.includes(\n this.checker.typeToString(argType.type)\n )\n ) {\n fieldDef.name = this.checker.typeToString(argType.type)\n }\n\n field.args.push({\n name: argName,\n type: {\n ...fieldDef,\n description: argType.documentation\n }\n })\n }\n }\n\n root.fields.push(field)\n } else if (processing === 'inputs') {\n const field: Input['fields'][number] = {\n name: propertyName,\n type: {\n ...fieldDef,\n description: this.getTypeDocumentation(fieldType)\n }\n }\n\n if (!root.fields.find(f => f.name === field.name)) {\n root.fields.push(field)\n }\n }\n }\n }\n\n private getSymbolDocumentation(symbol: ts.Symbol) {\n let header = ''\n\n header += ts.displayPartsToString(\n symbol.getDocumentationComment(this.checker)\n )\n\n const tags = symbol\n .getJsDocTags(this.checker)\n .map(t => `@${t.name} ${ts.displayPartsToString(t.text)}`)\n .join('\\n')\n\n if (tags) {\n header += '\\n' + tags\n }\n\n return header\n }\n\n private getTypeDocumentation = (type: ts.Type) => {\n const symbol = type.getSymbol()\n\n if (symbol) {\n return this.getSymbolDocumentation(symbol)\n }\n\n return ''\n }\n\n /**\n * Extracts reserved field names from the schema by removing them from their respective types and inputs.\n */\n private extractForbiddenFieldNamesFromSchema(): void {\n // Define a regular expression to check if a field name is a valid GraphQL field name.\n const validFieldNameRegExp = /^[_A-Za-z][_0-9A-Za-z]*$/\n\n // Define a helper function to check if a field name is reserved.\n const isReserved = (name: string): boolean => {\n if (!validFieldNameRegExp.test(name)) {\n // console.warn(\n // `\\x1b[33mWarning: forbidden field name \"${name}\" detected\\x1b[0m`\n // )\n return true\n }\n // Fields starting with \"__\" are considered reserved.\n return name.startsWith('__')\n }\n\n // Loop over each type in the schema and remove any reserved fields.\n for (const type of this.schema.types) {\n type.fields = type.fields.filter(field => {\n if (isReserved(field.name)) {\n // console.warn(\n // `\\x1b[33mWarning: forbidden field \"${field.name}\" detected in type \"${type.name}\". This field will be excluded from the schema.\\x1b[0m`\n // )\n return false\n }\n return true\n })\n }\n\n // Loop over each input in the schema and remove any reserved fields.\n for (const input of this.schema.inputs) {\n input.fields = input.fields.filter(field => {\n if (isReserved(field.name)) {\n // console.warn(\n // `\\x1b[33mWarning: reserved field \"${field.name}\" detected in input \"${input.name}\". This field will be excluded from the schema.\\x1b[0m`\n // )\n return false\n }\n return true\n })\n }\n }\n\n private makeReferenceSchema(index: Index): ReferenceSchema {\n const referenceSchema: ReferenceSchema = {\n types: new Map(),\n inputs: new Map(),\n classImplementsMap: new Map()\n }\n\n const recLoop = (\n type: ts.Type,\n info: {\n propetyName?: string\n parentType?: ts.Type\n } = {},\n processing: 'inputs' | 'types' = 'types',\n path: Array<string> = []\n ) => {\n if (referenceSchema[processing].has(type)) {\n return\n }\n\n if (isSubscriptionRepeater(type)) {\n // type: Repeater<{ id: number; title: string; content: string; }, any, unknown>\n\n const repeaterItemType = this.checker.getTypeArguments(type as any)[0]\n\n recLoop(repeaterItemType, info, processing, [...path, 'REPEATER_ITEM'])\n\n return\n }\n\n // check if argType is a real type to ignore '[]'\n const wrongType = this.checker.typeToString(type) === '[]'\n\n if (wrongType) {\n return\n }\n\n // skip if scalar\n if (this.schema.scalars.includes(this.checker.typeToString(type))) {\n return\n }\n\n if (isPrimitive(type)) {\n return\n }\n\n if (isPromise(type)) {\n // skip if input\n if (processing === 'inputs') {\n return\n }\n\n const promiseType = getPromiseType(type)\n\n if (promiseType) {\n recLoop(promiseType, info, processing, [...path, 'PROMISE'])\n }\n\n return\n }\n\n if (type.isClass()) {\n const baseTypes = type.getBaseTypes()\n if (baseTypes) {\n baseTypes.forEach(baseType => {\n if (!referenceSchema.classImplementsMap.has(baseType)) {\n referenceSchema.classImplementsMap.set(baseType, [])\n }\n referenceSchema.classImplementsMap.get(baseType)!.push(type)\n })\n }\n }\n\n if (type.isUnion()) {\n if (isPrimitiveUnion(type)) {\n if (!referenceSchema[processing].has(type)) {\n referenceSchema[processing].set(type, {})\n }\n\n recLoop(type, info, processing, [...path, 'ENUM'])\n } else {\n if (processing === 'types') {\n type.types.forEach(t => {\n // if null or undefined, skip\n if (\n t.flags & ts.TypeFlags.Null ||\n t.flags & ts.TypeFlags.Undefined ||\n isPrimitive(t)\n ) {\n return\n }\n\n recLoop(t, info, processing, [\n ...path,\n t.symbol?.getName() || `N/A ${this.checker.typeToString(t)}`\n ])\n })\n } else {\n let firstType = type.getNonNullableType()\n\n if (firstType.isUnion() && !isPrimitive(firstType)) {\n consola.warn(\n `Warning: Union types in input fields are not supported yet. Defaulting to the first type (${this.checker.typeToString(\n firstType\n )}) at path: ${path.join(' > ')}`\n )\n\n firstType = firstType.types[0]\n }\n\n recLoop(firstType, info, processing, [...path, 'NON_NULLABLE'])\n }\n }\n } else if (isFunction(type)) {\n // skip fn for inputs\n if (processing === 'inputs') {\n return\n }\n\n if (!info.parentType) {\n throw new Error('Cannot have a function without a parent type')\n }\n\n const signature = type.getCallSignatures()[0]\n const args = signature?.getParameters() || []\n const returnType = signature?.getReturnType()\n\n const schemaType = referenceSchema[processing].get(info.parentType)![\n info.propetyName!\n ]!\n\n args.forEach(arg => {\n const argType = this.checker.getTypeOfSymbolAtLocation(\n arg,\n this.sfiFile\n )\n\n if (this.checker.isTupleType(argType)) {\n // Iterate over the rest of the arguments\n const tupleType = argType as ts.TupleType\n\n const elements = (tupleType.target as any)\n .labeledElementDeclarations\n\n elements.forEach((element, idx: number) => {\n const elementType = this.checker.getTypeAtLocation(element)\n\n const elementName = element.name.text\n const elementSymbol = this.checker.getSymbolAtLocation(element)\n\n const elementDocumentation = this.getSymbolDocumentation(\n elementSymbol || arg\n )\n\n schemaType.args[elementName] = {\n type: elementType,\n isRequired:\n element.initializer === undefined ? undefined : false,\n documentation: elementDocumentation\n }\n\n recLoop(\n elementType,\n {\n parentType: type\n },\n 'inputs',\n [...path, elementName]\n )\n })\n } else if (\n arg.valueDeclaration &&\n ts.isParameter(arg.valueDeclaration) &&\n arg.valueDeclaration.dotDotDotToken\n ) {\n consola.warn(\n `Warning: Rest parameters without explicit names are not supported. ` +\n `Skipping rest parameter at path: ${path.join(' > ')}.\\n\\n` +\n `Unsupported: \\`function example(...args: any[]) { }\\`.\\n` +\n `Supported: \\`function example(...namedArgs: [first: string, second: number]) { }\\`.\\n` +\n `Please provide named rest parameters to ensure proper type resolution.`\n )\n } else {\n const valueDeclaration =\n arg.valueDeclaration as ts.ParameterDeclaration\n\n // set args to empty object if not set\n if (schemaType.args) {\n schemaType.args[arg.escapedName as string] = {\n type: argType,\n isRequired:\n valueDeclaration.initializer === undefined\n ? undefined\n : false,\n documentation: this.getSymbolDocumentation(arg)\n }\n\n recLoop(\n argType,\n {\n parentType: type\n },\n 'inputs',\n [...path, arg.escapedName as string]\n )\n }\n }\n })\n\n if (returnType) {\n recLoop(returnType, info, processing, [...path, 'RETURN_TYPE'])\n }\n } else if (isList(this.checker, type)) {\n const itemType = this.checker.getIndexTypeOfType(\n type,\n ts.IndexKind.Number\n )\n\n if (itemType && !isPrimitive(itemType)) {\n if (!referenceSchema[processing].has(type)) {\n referenceSchema[processing].set(type, {})\n }\n\n recLoop(itemType, info, processing, [...path, 'ITEM_TYPE'])\n }\n } else if (!isPrimitive(type)) {\n const properties = getPublicPropertiesOfType(this.checker, type)\n\n if (!referenceSchema[processing].has(type)) {\n referenceSchema[processing].set(type, {})\n }\n\n properties.forEach(property => {\n const propertyType = this.checker.getTypeOfSymbolAtLocation(\n property,\n this.sfiFile\n )\n\n if (\n !referenceSchema[processing].get(type)![\n property.escapedName as string\n ]\n ) {\n referenceSchema[processing].get(type)![\n property.escapedName as string\n ] = {\n returnType: propertyType,\n args: {}\n }\n }\n\n recLoop(\n propertyType,\n {\n propetyName: property.escapedName as string,\n parentType: type\n },\n processing,\n [...path, property.escapedName as string]\n )\n })\n }\n }\n\n if (index.Query) {\n recLoop(index.Query)\n }\n\n if (index.Mutation) {\n recLoop(index.Mutation)\n }\n\n if (index.Subscription) {\n recLoop(index.Subscription)\n }\n\n // Handle classes that implement interfaces of the schema\n const sourceFiles = this.program.getSourceFiles()\n\n for (const sourceFile of sourceFiles) {\n ts.forEachChild(sourceFile, node => {\n if (ts.isClassDeclaration(node)) {\n const baseTypes =\n node.heritageClauses?.flatMap(heritage =>\n heritage.types.map(type => {\n return type\n })\n ) || []\n\n // Check if the class implements an interface\n if (baseTypes.length > 0) {\n for (const baseType of baseTypes) {\n if (\n referenceSchema.types.has(\n this.checker.getTypeAtLocation(baseType)\n )\n ) {\n referenceSchema.classImplementsMap.set(\n this.checker.getTypeAtLocation(node),\n [this.checker.getTypeAtLocation(baseType)]\n )\n\n recLoop(this.checker.getTypeAtLocation(node))\n }\n }\n }\n }\n })\n }\n\n return referenceSchema\n }\n}\n", "import ts from 'typescript'\n\nexport const isEmptyObject = (type: ts.Type) => {\n return (\n type.flags & ts.TypeFlags.Object &&\n type.getProperties().length === 0 &&\n type.getCallSignatures().length === 0\n )\n}\n\nexport const isList = (checker: ts.TypeChecker, type: ts.Type) => {\n const typeNode = checker.typeToTypeNode(type, undefined, undefined)\n\n const is = !!(\n typeNode &&\n (typeNode.kind === ts.SyntaxKind.ArrayType ||\n typeNode.kind === ts.SyntaxKind.TupleType)\n )\n\n if (!is) {\n // Check if type references an array\n const isArray = type.getSymbol()?.getName() === 'Array'\n\n if (isArray) {\n return true\n }\n }\n\n return is\n}\n\nexport const isBoolean = (type: ts.Type) => {\n // check if is union and all types are boolean\n if (type.isUnion()) {\n const isAllBooleans = type.types.every(\n t => t.flags & ts.TypeFlags.BooleanLiteral\n )\n\n return isAllBooleans\n }\n\n return false\n}\n\nexport const isPrimitive = (type: ts.Type) => {\n const primitive =\n type.flags & ts.TypeFlags.String ||\n type.flags & ts.TypeFlags.Number ||\n type.flags & ts.TypeFlags.Boolean ||\n type.flags & ts.TypeFlags.StringLiteral ||\n type.flags & ts.TypeFlags.NumberLiteral ||\n type.flags & ts.TypeFlags.BooleanLiteral\n\n return primitive\n}\n\nexport const isFunction = (type: ts.Type) => {\n return type.getCallSignatures().length > 0\n}\n\nexport const isPrimitiveUnion = (type: ts.Type) => {\n if (isPrimitive(type)) return false\n\n const isUnion = (type as ts.UnionType).types?.length > 1\n\n if (isUnion) {\n // check if all types are primitives\n const isAllPrimitives = (type as ts.UnionType).types.every(\n t =>\n t.flags & ts.TypeFlags.StringLiteral ||\n t.flags & ts.TypeFlags.NumberLiteral ||\n t.flags & ts.TypeFlags.BooleanLiteral\n )\n\n if (isAllPrimitives) {\n return true\n }\n }\n\n return false\n}\n\nexport const isPromise = (type: ts.Type) => {\n // check if type is a promise\n return type.getSymbol()?.getName() === 'Promise'\n}\n\nexport const getPromiseType = (type: ts.Type) => {\n let objectType = type as ts.ObjectType\n\n if (objectType.objectFlags & ts.ObjectFlags.Reference) {\n const reference = type as ts.TypeReference\n const typeArguments = reference.typeArguments\n if (typeArguments && typeArguments.length > 0) {\n return typeArguments[0]\n }\n }\n}\n\nexport const excludeNullUndefinedFromType = (type: ts.Type) => {\n if (!type.isUnion())\n return {\n type,\n wasOptional: false\n }\n\n const types = type.types.filter(\n t => !(t.flags & ts.TypeFlags.Undefined || t.flags & ts.TypeFlags.Null)\n )\n\n const wasOptional = types.length !== type.types.length\n\n return {\n type: type.getNonNullableType(),\n wasOptional\n }\n}\n\nexport function getPublicPropertiesOfType(\n checker: ts.TypeChecker,\n _type: ts.Type\n): ts.Symbol[] {\n let type = _type\n\n if (type.isUnion()) {\n // Filter out array types from the union if their non-array counterparts are also present\n const nonArrayTypes = type.types.filter(\n t =>\n !(\n t.flags & ts.TypeFlags.Object &&\n (t as ts.ObjectType).objectFlags & ts.ObjectFlags.Reference &&\n (t as ts.TypeReference).typeArguments?.length\n )\n )\n const arrayElementTypes = type.types\n .filter(\n t =>\n t.flags & ts.TypeFlags.Object &&\n (t as ts.ObjectType).objectFlags & ts.ObjectFlags.Reference &&\n (t as ts.TypeReference).typeArguments?.length\n )\n .map(t => (t as ts.TypeReference).typeArguments![0])\n const filteredTypes = nonArrayTypes.filter(\n t => !arrayElementTypes.some(et => et === t)\n )\n // .filter(t => {\n // // filter out primitive types\n // return !isPrimitive(t)\n // })\n\n // Create a new type that is the union of all the types in the union\n // This is necessary because the type checker will not resolve properties\n // that are only present on some types in the union\n // getUnionType is not available in TS 3.7, so we have to use the private API\n type = (checker as any).getUnionType(filteredTypes) as ts.Type\n }\n\n const properties: ts.Symbol[] = []\n\n // if type is a primitive, return empty array\n if (isList(checker, type) || isPrimitive(type) || isPrimitiveUnion(type))\n return properties\n\n let typeProperties: ts.Symbol[] = []\n\n typeProperties =\n (type as any).resolvedProperties || type.getProperties() || []\n\n for (const prop of typeProperties) {\n const isPublic =\n prop.valueDeclaration &&\n !(\n ts.getCombinedModifierFlags(prop.valueDeclaration) &\n ts.ModifierFlags.Private\n ) &&\n !prop.getName().startsWith('#')\n\n if (isPublic === false) {\n continue\n }\n\n properties.push(prop)\n }\n\n return properties\n}\n\nexport const safeTypeName = (name: string) => {\n return name.replace(/[^0-9a-zA-Z_]/g, '_')\n}\n\nexport const isSubscriptionRepeater = (type: ts.Type) => {\n return !!type\n .getSymbol()\n ?.getDeclarations()\n ?.some(d => {\n const sourceFile = d.getSourceFile().fileName\n\n return sourceFile.includes('@repeaterjs')\n })\n}\n", "import ts from 'typescript'\nimport {\n excludeNullUndefinedFromType,\n getPromiseType,\n isEmptyObject,\n isPrimitiveUnion,\n isFunction,\n isList,\n isPrimitive,\n isPromise,\n isSubscriptionRepeater,\n safeTypeName\n} from './types-helper.js'\nimport {Schema} from './schema-parser.js'\n\nexport interface Union {\n name: string\n rawType: ts.Type\n types: Array<string>\n}\n\nexport interface Enum {\n name: string\n rawType: ts.Type\n values: Array<string>\n}\n\ninterface FieldDefinition {\n name: string\n isList: boolean\n isRequired: boolean\n isListRequired?: boolean\n}\n\nexport class TypeDefinitionBuilder {\n private checker: ts.TypeChecker\n private schema: Schema\n\n private typesNameMap: Map<ts.Type, string> = new Map()\n private inputsNameMap: Map<ts.Type, string> = new Map()\n\n private unions: Array<Union> = []\n private enums: Array<Enum> = []\n\n constructor(checker: ts.TypeChecker, schema: Schema) {\n this.checker = checker\n this.schema = schema\n }\n\n getTypeDefinition = (\n rawType: ts.Type,\n options: {\n isInputType?: boolean\n isRequired?: boolean\n propertyName?: string\n } = {\n isInputType: false\n }\n ): FieldDefinition => {\n const {type, wasOptional} = excludeNullUndefinedFromType(rawType)\n\n if (\n type.flags & ts.TypeFlags.Void ||\n type.flags & ts.TypeFlags.Undefined ||\n type.flags & ts.TypeFlags.Null\n ) {\n return {\n name: 'Void',\n isList: false,\n isRequired: false\n }\n }\n\n if (isSubscriptionRepeater(type)) {\n const repeaterItemType = this.checker.getTypeArguments(type as any)[0]\n\n if (repeaterItemType) {\n return this.getTypeDefinition(repeaterItemType, options)\n }\n }\n\n if (isPromise(type)) {\n const promiseType = getPromiseType(type)\n if (promiseType) {\n return this.getTypeDefinition(promiseType, options)\n }\n }\n\n const isRequired =\n options.isRequired !== undefined ? options.isRequired : !wasOptional\n\n if (isEmptyObject(type)) {\n return {\n name: 'Object',\n isList: false,\n isRequired\n }\n }\n\n let nameMap = options.isInputType ? this.inputsNameMap : this.typesNameMap\n\n if (nameMap.has(type)) {\n const typeName = nameMap.get(type) as string\n\n return {\n name: typeName,\n isList: false,\n isRequired\n }\n }\n\n let typeName: string | undefined =\n type.aliasSymbol?.escapedName?.toString() ||\n type.symbol?.escapedName.toString()\n\n if (typeName === '__type' || typeName === '__object') {\n if (!options.propertyName) {\n typeName = undefined\n } else {\n const capitalizedPropertyName =\n options.propertyName.charAt(0).toUpperCase() +\n options.propertyName.slice(1)\n\n typeName = capitalizedPropertyName\n }\n }\n\n if (typeName) {\n typeName = safeTypeName(typeName)\n }\n\n const duplicateName = (name: string) => {\n // find name in typeNameMap\n return Array.from(nameMap.values()).includes(name)\n }\n\n if (typeName && !this.schema.scalars.includes(typeName)) {\n if (options.isInputType) {\n typeName = `${typeName}Input`\n }\n\n let i = 1\n let originalTypeName = typeName\n while (duplicateName(typeName as string)) {\n typeName = `${originalTypeName}_${i}`\n\n i++\n }\n }\n\n if (typeName && this.schema.scalars.includes(typeName)) {\n return {\n name: typeName,\n isList: false,\n isRequired\n }\n }\n\n if (isList(this.checker, type)) {\n const listType = this.checker.getIndexTypeOfType(\n type,\n ts.IndexKind.Number\n )\n\n if (listType) {\n const def = this.getTypeDefinition(listType, options)\n\n return {\n name: def.name,\n isList: true,\n isRequired: def.isRequired,\n isListRequired: isRequired\n }\n }\n } else if (isPrimitiveUnion(type)) {\n const typeNode = this.checker.typeToTypeNode(\n type,\n undefined,\n undefined\n ) as any | undefined\n\n const types = (type as ts.UnionType).types\n\n // enumerate all members of the enum\n const members = types.map((t: ts.Type) => {\n if (t.isLiteral()) {\n const name = t.value?.toString()\n\n if (!name) {\n throw new Error('Enum member name is undefined')\n }\n\n return safeTypeName(name)\n }\n\n throw new Error('Invalid type for enum member')\n })\n\n if (members.length > 0) {\n typeName = typeName || typeNode.typeName?.symbol?.escapedName\n\n if (!typeName) {\n typeName = members.join('_').toUpperCase()\n typeName = options.isInputType ? `${typeName}Input` : typeName\n }\n\n this.enums.push({\n name: typeName,\n values: members,\n rawType: type\n })\n }\n }\n // handle primitives\n else if (isPrimitive(type)) {\n let typeName = this.checker.typeToString(type)\n\n if (type.flags & ts.TypeFlags.StringLiteral) {\n typeName = 'String'\n } else if (type.flags & ts.TypeFlags.NumberLiteral) {\n typeName = 'Number'\n } else if (type.flags & ts.TypeFlags.BooleanLiteral) {\n typeName = 'Boolean'\n } else if (type.flags & ts.TypeFlags.String) {\n typeName = 'String'\n } else if (type.flags & ts.TypeFlags.Number) {\n typeName = 'Number'\n } else if (type.flags & ts.TypeFlags.Boolean) {\n typeName = 'Boolean'\n }\n\n return {\n name: safeTypeName(typeName),\n isList: false,\n isRequired\n }\n } else if (type.isIntersection()) {\n const intersectionTypes = type.types\n\n const typeNames = intersectionTypes.map(t => {\n const typeDef = this.getTypeDefinition(t, options)\n\n return typeDef.name\n })\n\n typeName = safeTypeName(typeName || typeNames.join('And'))\n } else if (type.isUnion()) {\n const unionTypes = type.types\n const required = type.types.length === unionTypes.length\n\n const hasPrimitivesOrEnum = unionTypes.some(t => {\n // If t is a array take the element type\n const type = isList(this.checker, t)\n ? this.checker.getIndexTypeOfType(t, ts.IndexKind.Number)\n : t\n\n if (!type) {\n // Return true if the type is undefined because we don't know what it is\n // Marking it as a primitive or enum will make it more error prone\n return true\n }\n\n return isPrimitive(type) || isPrimitiveUnion(type)\n })\n\n const unionTypeDefs = [\n ...new Set(\n unionTypes.map(t =>\n this.getTypeDefinition(t, {...options, isRequired: required})\n )\n )\n ]\n\n // If the union contains a array of some type, remove the type from the union because\n // the array type will be handled by the list type\n\n const listTypes = unionTypeDefs.filter(t => t.isList)\n\n // Check if the union contains the same type as a list\n for (const listType of listTypes) {\n const index = unionTypeDefs.findIndex(\n t => t.name === listType.name && !t.isList\n )\n\n if (index > -1) {\n unionTypeDefs.splice(index, 1)\n }\n }\n\n const typeNames = unionTypeDefs.map(t => t.name)\n\n typeName = safeTypeName(typeName || typeNames.join('Or'))\n\n // check if typeName is a duplicate\n if (typeName) {\n let i = 1\n let originalTypeName = typeName\n while (duplicateName(typeName as string)) {\n typeName = `${originalTypeName}_${i}`\n\n i++\n }\n }\n\n if (\n unionTypeDefs.length > 1 &&\n !options.isInputType &&\n !hasPrimitivesOrEnum\n ) {\n this.unions.push({\n name: typeName,\n types: typeNames,\n rawType: type\n })\n } else {\n // We only care about the first type in the union since GraphQL doesn't support unions of input types\n const typeDef = unionTypeDefs[0]\n\n if (!typeDef) {\n throw new Error('Cannot get type definition')\n }\n\n // If the types contain a list of the same type as the first type, then we can make the first type a list\n const isList = unionTypeDefs.some(t => {\n return t.isList && t.name === typeDef.name\n })\n\n return {\n name: typeDef.name,\n isList,\n isRequired\n }\n }\n }\n // handle functions\n else if (isFunction(type)) {\n const signature = type.getCallSignatures()[0]\n let returnType = signature?.getReturnType()\n\n if (returnType) {\n if (isPromise(returnType)) {\n const pt = getPromiseType(returnType)\n\n if (pt) {\n returnType = pt\n }\n }\n }\n\n if (returnType) {\n const def = this.getTypeDefinition(returnType, options)\n\n return def\n }\n }\n\n if (!typeName) {\n typeName = 'Any'\n }\n\n nameMap.set(type, typeName)\n\n return {\n name: typeName,\n isList: false,\n isRequired\n }\n }\n\n public getUnions(): Array<Union> {\n return this.unions\n }\n\n public getEnums(): Array<Enum> {\n return this.enums\n }\n\n public typeDefinitionToGraphQLType = (\n typeDefinition: FieldDefinition\n ): string => {\n let type = typeDefinition.name\n const {isList, isRequired, isListRequired} = typeDefinition\n\n if (isRequired) {\n type = `${type}!`\n }\n\n if (isList) {\n type = `[${type}]`\n\n if (isListRequired) {\n type = `${type}!`\n }\n }\n\n return type\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["
|
|
3
|
+
"sources": ["../src/index.ts", "../package.json", "../src/builder/index.ts", "../src/builder/bundler/bundler.ts", "../src/builder/bundler/plugins/inject-code-plugin.ts", "../src/builder/update-file-if-changed.ts", "../src/builder/bundler/plugins/notify-plugin.ts", "../src/builder/schema/builder.ts", "../src/builder/schema/schema-parser.ts", "../src/builder/schema/types-helper.ts", "../src/builder/schema/type-definition-builder.ts", "../src/builder/build-client.ts"],
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\n\nimport * as telemetry from '@getcronit/pylon-telemetry'\nimport {program, type Command} from 'commander'\nimport consola from 'consola'\nimport dotenv from 'dotenv'\nimport pm2 from 'pm2'\n\nimport {version} from '../package.json'\nimport {build} from './builder'\nimport {buildClient} from './builder/build-client'\n\ndotenv.config()\n\nprogram.name('pylon-dev').description('Pylon Development CLI').version(version)\n\nprogram\n .command('build')\n .description('Build the Pylon Schema')\n .action(async () => {\n const ctx = await build({\n sfiFilePath: './src/index.ts',\n outputFilePath: './.pylon',\n onBuild: async ({totalFiles, totalSize, duration, schemaChanged}) => {\n await telemetry.sendBuildEvent({\n duration,\n totalFiles,\n totalSize,\n isDevelopment: false\n })\n\n await buildClient({schemaChanged})\n }\n })\n\n await ctx.rebuild()\n await ctx.dispose()\n })\n\nprogram\n .name('dev')\n .option(\n '-c, --command <command>',\n 'Command to run the server',\n 'bun run .pylon/index.js'\n )\n .action(main)\n\ntype ArgOptions = {\n command: string\n client: boolean\n clientPath: string\n clientPort: string\n}\n\nasync function main(options: ArgOptions, command: Command) {\n pm2.connect(async function (err) {\n if (err) {\n consola.error(err)\n process.exit(1)\n }\n\n const ctx = await build({\n sfiFilePath: './src/index.ts',\n outputFilePath: `./.pylon`,\n onBuild: async ({schemaChanged, totalFiles, totalSize, duration}) => {\n await buildClient({schemaChanged})\n // Restart the server\n // pm2.restart('pylon-dev', function (err) {\n // if (err) throw err\n // })\n }\n })\n\n await ctx.watch()\n\n pm2.launchBus((err, bus) => {\n if (err) {\n consola.error(err)\n return\n }\n\n bus.on('log:out', data => {\n consola.log(data.data)\n })\n\n bus.on('log:err', data => {\n consola.error(data.data)\n })\n })\n\n pm2.start(\n {\n name: 'pylon-dev',\n script: options.command,\n // args: args,\n exec_mode: 'fork',\n instances: 1,\n autorestart: true,\n watch: ['./.pylon'],\n restart_delay: 1000,\n watch_delay: 1000 as any,\n ignore_watch: ['node_modules'],\n env: {\n ...process.env,\n NODE_ENV: 'development'\n }\n } as any,\n function (err, apps) {\n // Check if it is a duplicate start\n if (err) throw err\n\n consola.box(`\nPylon is up and running!\n \nPress \\`Ctrl + C\\` to stop the server.\n \nEncounter any issues? Report them here:\nhttps://github.com/getcronit/pylon/issues\n \nWe value your feedback\u2014help us make Pylon even better!`)\n }\n )\n\n process.on('SIGINT', async code => {\n await ctx.cancel()\n pm2.delete('pylon-dev', function (err) {\n pm2.disconnect()\n process.exit(0)\n })\n })\n })\n}\n\nprogram.parse()\n", "{\n \"name\": \"@getcronit/pylon-dev\",\n \"type\": \"module\",\n \"version\": \"2.0.0-canary-20250211153808.b2b63f4e67c55542413f7be6d62ce8139cfcbdbe\",\n \"description\": \"CLI for creating a Pylon\",\n \"scripts\": {\n \"build\": \"rimraf ./dist && esbuild ./src/index.ts --bundle --platform=node --target=node18 --format=esm --minify --outdir=./dist --sourcemap=linked --packages=external\"\n },\n \"bin\": {\n \"pylon\": \"./dist/index.js\"\n },\n \"files\": [\n \"dist\"\n ],\n \"author\": \"Nico Schett <nico.schett@cronit.io>\",\n \"license\": \"Apache-2.0\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/getcronit/pylon.git\",\n \"directory\": \"packages/create-pylon\"\n },\n \"homepage\": \"https://pylon.cronit.io\",\n \"dependencies\": {\n \"@getcronit/pylon-telemetry\": \"workspace:^\",\n \"@gqty/cli\": \"^4.2.0\",\n \"commander\": \"^12.1.0\",\n \"consola\": \"^3.2.3\",\n \"dotenv\": \"^16.4.5\"\n },\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"engines\": {\n \"node\": \">=18.0.0\"\n },\n \"devDependencies\": {\n \"@types/ps-tree\": \"^1.1.6\",\n \"esbuild\": \"^0.23.1\",\n \"esbuild-plugin-tsc\": \"^0.4.0\",\n \"pm2\": \"^5.4.3\",\n \"typescript\": \"^5.7.3\"\n },\n \"peerDependencies\": {\n \"@getcronit/pylon\": \"workspace:3.0.0-canary-20250211153808.b2b63f4e67c55542413f7be6d62ce8139cfcbdbe\",\n \"graphql\": \"^16.9.0\"\n }\n}\n", "import path from 'path'\nimport {Bundler} from './bundler/bundler.js'\nimport {SchemaBuilder} from './schema/builder.js'\n\nexport interface BuildOptions {\n sfiFilePath: string\n outputFilePath: string\n onBuild?: (output: {\n totalFiles: number\n totalSize: number\n schemaChanged: boolean\n duration: number\n }) => void\n}\n\nexport {SchemaBuilder}\n\nexport const build = async (options: BuildOptions) => {\n const bundler = new Bundler(options.sfiFilePath, options.outputFilePath)\n\n const builder = new SchemaBuilder(\n path.join(process.cwd(), options.sfiFilePath)\n )\n\n return await bundler.build({\n getBuildDefs: () => {\n const built = builder.build()\n\n const typeDefs = built.typeDefs\n\n return {\n typeDefs: typeDefs,\n resolvers: built.resolvers\n }\n },\n onBuild: options.onBuild\n })\n}\n", "// bundler.ts\nimport esbuild, {context} from 'esbuild'\nimport esbuildPluginTsc from 'esbuild-plugin-tsc'\nimport type {PylonConfig, Plugin} from '@getcronit/pylon'\n\nimport path from 'path'\nimport fs from 'fs/promises'\nimport {\n InjectCodePluginOptions,\n injectCodePlugin\n} from './plugins/inject-code-plugin'\nimport {NotifyPluginOptions, notifyPlugin} from './plugins/notify-plugin'\nimport {updateFileIfChanged} from '../update-file-if-changed'\n\nexport interface BundlerBuildOptions {\n getBuildDefs: InjectCodePluginOptions['getBuildDefs']\n onBuild?: NotifyPluginOptions['onBuild']\n}\n\nexport class Bundler {\n sfiFilePath: string\n outputDir: string\n\n constructor(sfiFilePath: string, outputDir: string = './.pylon') {\n this.sfiFilePath = sfiFilePath\n this.outputDir = outputDir\n }\n\n private async initBuildPlugins(args: {onBuild: () => void}) {\n const configPath = path.join(process.cwd(), this.outputDir, 'index.js')\n\n let config: PylonConfig | undefined\n try {\n let configModule = await import(configPath)\n\n config = configModule.config\n } catch (e) {\n console.error('Error loading config', e)\n }\n\n const buildContexts: ReturnType<NonNullable<Plugin['build']>>[] = []\n\n const plugins = config?.plugins || []\n\n for (const plugin of plugins) {\n if (plugin.build) {\n const ctx = plugin.build({onBuild: args.onBuild})\n\n buildContexts.push(ctx)\n }\n }\n\n return buildContexts\n }\n\n public async build(options: BundlerBuildOptions) {\n const inputPath = path.join(process.cwd(), this.sfiFilePath)\n const dir = path.join(process.cwd(), this.outputDir)\n\n // Create directory if it doesn't exist\n await fs.mkdir(dir, {recursive: true})\n\n const writeOnEndPlugin: esbuild.Plugin = {\n name: 'write-on-end',\n setup(build) {\n build.onEnd(async result => {\n result.outputFiles?.forEach(async file => {\n await fs.mkdir(path.dirname(file.path), {recursive: true})\n await updateFileIfChanged(file.path, file.text)\n })\n })\n }\n }\n\n const ctx = await context({\n write: false,\n logLevel: 'silent',\n metafile: true,\n entryPoints: [inputPath],\n outdir: dir,\n bundle: true,\n format: 'esm',\n sourcemap: 'inline',\n packages: 'external',\n\n plugins: [\n notifyPlugin({\n dir,\n onBuild: async output => {\n await options.onBuild?.(output)\n }\n }),\n injectCodePlugin({\n getBuildDefs: options.getBuildDefs,\n outputDir: this.outputDir\n }),\n esbuildPluginTsc({\n tsconfigPath: path.join(process.cwd(), 'tsconfig.json')\n }),\n writeOnEndPlugin\n ]\n })\n\n const pluginCtxs = await this.initBuildPlugins({\n onBuild: () => {\n options.onBuild?.({\n totalFiles: 0,\n totalSize: 0,\n schemaChanged: false,\n duration: 0\n })\n }\n })\n\n return {\n watch: async () => {\n for (const ctx of pluginCtxs) {\n const c = await ctx\n\n await c.watch()\n }\n\n return await ctx.watch()\n },\n rebuild: async () => {\n for (const ctx of pluginCtxs) {\n const c = await ctx\n\n await c.rebuild()\n }\n\n await ctx.rebuild()\n },\n dispose: async () => {\n for (const ctx of pluginCtxs) {\n const c = await ctx\n\n await c.dispose()\n }\n\n await ctx.dispose()\n },\n cancel: async () => {\n for (const ctx of pluginCtxs) {\n const c = await ctx\n\n await c.cancel()\n }\n\n await ctx.cancel()\n }\n }\n }\n}\n", "import {Plugin} from 'esbuild'\nimport path from 'path'\nimport fs from 'fs/promises'\nimport {updateFileIfChanged} from '../../update-file-if-changed'\n\nexport interface InjectCodePluginOptions {\n getBuildDefs: () => {\n typeDefs: string\n resolvers: Record<\n string,\n {\n __resolveType?: (obj: any) => string\n }\n >\n }\n outputDir: string\n}\n\nexport const injectCodePlugin = ({\n getBuildDefs,\n outputDir\n}: InjectCodePluginOptions): Plugin => ({\n name: 'inject-code',\n setup(build) {\n build.onLoad(\n {filter: /src[\\/\\\\]index\\.ts$/, namespace: 'file'},\n async args => {\n // Convert to relative path to ensure we match `src/index.ts` at root\n const relativePath = path.relative(process.cwd(), args.path)\n\n if (relativePath !== path.join('src', 'index.ts')) {\n return\n }\n\n const {typeDefs, resolvers} = getBuildDefs()\n\n const preparedResolvers = prepareObjectInjection(resolvers)\n\n const contents = await fs.readFile(args.path, 'utf-8')\n\n // Write the typeDefs to a file\n const typeDefsPath = path.join(\n process.cwd(),\n outputDir,\n 'schema.graphql'\n )\n\n await updateFileIfChanged(typeDefsPath, typeDefs)\n\n // Write base resolvers to a file\n\n const resolversPath = path.join(\n process.cwd(),\n outputDir,\n 'resolvers.js'\n )\n\n await updateFileIfChanged(\n resolversPath,\n `export const resolvers = ${preparedResolvers}`\n )\n\n return {\n loader: 'ts',\n contents:\n contents +\n `\n import {handler as __internalPylonHandler} from \"@getcronit/pylon\"\n\n let __internalPylonConfig = undefined\n\n try {\n __internalPylonConfig = config\n } catch {\n // config is not declared, pylonConfig remains undefined\n }\n\n app.use(__internalPylonHandler({\n typeDefs: ${JSON.stringify(typeDefs)},\n graphql,\n resolvers: ${preparedResolvers},\n config: __internalPylonConfig\n }))\n `\n }\n }\n )\n }\n})\n\nfunction prepareObjectInjection(obj: object) {\n const entries = Object.entries(obj).map(([key, value]) => {\n if (value === undefined) {\n return undefined\n } else if (typeof value === 'string') {\n return `${key}:${value}`\n } else if (typeof value === 'function') {\n return `${key}:${value.toString()}`\n } else if (typeof value === 'object' && !Array.isArray(value)) {\n return `${key}:${prepareObjectInjection(value)}`\n } else {\n return `${key}:${JSON.stringify(value)}`\n }\n })\n\n return `{${entries.join(',')}}`\n}\n", "import fs from 'fs/promises'\n\nexport async function updateFileIfChanged(path: string, newContent: string) {\n try {\n const currentContent = await fs.readFile(path, 'utf8')\n if (currentContent === newContent) {\n return false // No update needed\n }\n } catch (err: any) {\n if (err.code !== 'ENOENT') throw err // Ignore file not found error\n }\n\n await fs.writeFile(path, newContent, 'utf8')\n return true // File created or updated\n}\n", "import {Plugin} from 'esbuild'\nimport path from 'path'\nimport fs from 'fs/promises'\nimport consola from 'consola'\n\nexport interface NotifyPluginOptions {\n onBuild?: (output: {\n totalFiles: number\n totalSize: number\n schemaChanged: boolean\n duration: number\n }) => Promise<void> | void\n dir: string\n}\n\nexport const notifyPlugin = ({dir, onBuild}: NotifyPluginOptions): Plugin => ({\n name: 'notify',\n async setup(build) {\n const loadSchema = async () => {\n const schemaPath = path.join(dir, 'schema.graphql')\n\n try {\n await fs.access(schemaPath)\n } catch {\n return null\n }\n\n return await fs.readFile(schemaPath, 'utf-8')\n }\n\n let cachedSchema: string | null = await loadSchema()\n\n let startTime = Date.now()\n build.onStart(async () => {\n startTime = Date.now()\n consola.start('[Pylon]: Building...')\n })\n\n build.onEnd(async result => {\n if (result.errors.length > 0) {\n for (const error of result.errors) {\n consola.error(`[Pylon]: ${error.text}\n${\n error.location\n ? `at ${error.location.file}:${error.location.line}:${error.location.column}`\n : ''\n}\n${error.detail ? error.detail : ''}`)\n }\n\n throw new Error('Failed to build Pylon')\n }\n\n if (result.warnings.length > 0) {\n for (const warning of result.warnings) {\n consola.warn(warning)\n }\n }\n\n const duration = Date.now() - startTime\n\n const totalFiles = Object.keys(result.metafile!.inputs).length\n\n const totalSize = Object.values(result.metafile!.outputs).reduce(\n (acc, output) => acc + output.bytes,\n 0\n )\n\n const latestSchema = await loadSchema()\n\n consola.success(`[Pylon]: Built in ${duration}ms`)\n\n const schemaChanged = latestSchema !== cachedSchema\n\n if (schemaChanged) {\n consola.info('[Pylon]: Schema updated')\n\n cachedSchema = latestSchema\n }\n\n if (onBuild) {\n await onBuild({\n totalFiles,\n totalSize,\n schemaChanged,\n duration\n })\n }\n })\n }\n})\n", "import ts from 'typescript'\nimport {SchemaParser} from './schema-parser'\nimport path from 'path'\n\nexport class SchemaBuilder {\n private program: ts.Program\n private checker: ts.TypeChecker\n private sfiFile!: ts.SourceFile\n private sfi!: ts.Symbol\n private sfiFilePath: string\n\n constructor(sfiFilePath: string) {\n this.sfiFilePath = sfiFilePath\n\n const tsConfigOptions = this.loadTsConfigOptions()\n\n const filesInSfiDir = ts.sys\n .readDirectory(path.dirname(this.sfiFilePath), ['.ts'], ['.d.ts'])\n .concat([path.join(path.dirname(this.sfiFilePath), '..', 'pylon.d.ts')])\n\n this.program = ts.createProgram(filesInSfiDir, tsConfigOptions)\n\n this.checker = this.program.getTypeChecker()\n\n this.loadSfi()\n }\n\n private loadSfi() {\n const sourceFiles = this.program.getSourceFiles()\n\n const file = sourceFiles.find(\n file => path.resolve(file.fileName) === this.sfiFilePath\n )\n\n if (!file) {\n throw new Error('Could not find index.ts (pylon entrypoint)')\n }\n\n this.sfiFile = file\n\n const sfiFileSymbol = this.checker.getSymbolAtLocation(file)!\n const sfiFileExports = this.checker.getExportsOfModule(sfiFileSymbol!)\n const sfiFileDefaultExport = sfiFileExports.find(\n exportSymbol => exportSymbol.escapedName === 'graphql'\n )\n\n if (!sfiFileDefaultExport) {\n throw new Error('Could not find graphql export')\n }\n\n this.sfi = sfiFileDefaultExport\n }\n\n private loadTsConfigOptions() {\n const defaultOptions: ts.CompilerOptions = {\n target: ts.ScriptTarget.ESNext,\n module: ts.ModuleKind.CommonJS,\n strict: true,\n esModuleInterop: true,\n skipLibCheck: false,\n forceConsistentCasingInFileNames: true,\n noImplicitAny: true,\n experimentalDecorators: true\n }\n\n // Find the tsconfig.json file\n const configPath = ts.findConfigFile(\n path.dirname(this.sfiFilePath), // Directory to start searching from\n ts.sys.fileExists, // Function to check if a file exists\n 'tsconfig.json' // File name to search for\n )\n\n if (!configPath) {\n console.log('Could not find tsconfig.json')\n return defaultOptions\n }\n\n // Read the tsconfig.json file\n const configFile = ts.readConfigFile(configPath, ts.sys.readFile)\n\n if (configFile.error) {\n console.log('Could not read tsconfig.json', configFile.error)\n return defaultOptions\n }\n\n // Parse the tsconfig.json file\n const parsedConfig = ts.parseJsonConfigFileContent(\n configFile.config,\n ts.sys,\n path.dirname(configPath)\n )\n\n return parsedConfig.options\n }\n\n public build() {\n const sfiType = this.checker.getTypeOfSymbolAtLocation(\n this.sfi,\n this.sfiFile\n )\n\n // const plainResolversProperty = sfiType.getProperty('plainResolvers')\n\n // if (!plainResolversProperty) {\n // throw new Error('Could not find plainResolvers property')\n // }\n\n // const plainResolversType = this.checker.getTypeOfSymbolAtLocation(\n // plainResolversProperty,\n // this.sfiFile\n // )\n\n const queryProperty = sfiType.getProperty('Query')\n const mutationProperty = sfiType.getProperty('Mutation')\n const subscriptionProperty = sfiType.getProperty('Subscription')\n\n const queryType = queryProperty\n ? this.checker.getTypeOfSymbolAtLocation(queryProperty, this.sfiFile)\n : undefined\n const mutationType = mutationProperty\n ? this.checker.getTypeOfSymbolAtLocation(mutationProperty, this.sfiFile)\n : undefined\n const subscriptionType = subscriptionProperty\n ? this.checker.getTypeOfSymbolAtLocation(\n subscriptionProperty,\n this.sfiFile\n )\n : undefined\n\n const parser = new SchemaParser(this.checker, this.sfiFile, this.program)\n\n parser.parse({\n Query: queryType,\n Mutation: mutationType,\n Subscription: subscriptionType\n })\n\n return {\n typeDefs: parser.toString(),\n schema: parser.getSchema(),\n resolvers: parser.getResolvers()\n }\n }\n}\n", "import ts from 'typescript'\nimport {\n getPromiseType,\n getPublicPropertiesOfType,\n isPrimitiveUnion,\n isFunction,\n isList,\n isPrimitive,\n isPromise,\n isSubscriptionRepeater\n} from './types-helper.js'\nimport {\n TypeDefinitionBuilder,\n Union as _Union,\n Enum as _Enum\n} from './type-definition-builder.js'\nimport consola from 'consola'\n\ntype Union = _Union & {\n description: string\n __resolveType?: (obj: any) => string\n}\n\ntype Interface = {\n name: string\n description: string\n fields: Array<Field>\n __resolveType?: (obj: any) => string\n}\n\ntype Enum = _Enum & {\n description: string\n}\n\ninterface TypeDefinition {\n name: string\n isList: boolean\n isRequired: boolean\n description: string\n}\n\ninterface Field {\n name: string\n type: TypeDefinition\n}\n\ninterface Input {\n name: string\n description: string\n fields: Array<{\n name: string\n type: TypeDefinition\n }>\n}\n\ninterface Type {\n name: string\n description: string\n fields: Array<\n Field & {\n args: Array<{\n name: string\n type: TypeDefinition\n }>\n }\n >\n implements?: Array<string>\n rawType: ts.Type\n}\n\nexport interface Schema {\n types: Array<Type>\n inputs: Array<Input>\n interfaces: Array<Interface>\n unions: Array<Union>\n enums: Array<Enum>\n scalars: Array<string>\n}\n\ntype ReferenceSchemaType = {\n returnType: ts.Type\n args: {\n // value needs to be inputs type\n [key: string]: {\n type: ts.Type\n isRequired?: boolean\n documentation: string\n }\n }\n}\n\ninterface ReferenceSchema {\n types: Map<\n ts.Type,\n {\n [key: string]: ReferenceSchemaType\n }\n >\n classImplementsMap: Map<ts.Type, ts.Type[]>\n inputs: ReferenceSchema['types']\n}\n\ninterface Index {\n Query?: ts.Type\n Mutation?: ts.Type\n Subscription?: ts.Type\n}\n\nexport class SchemaParser {\n private schema: Schema\n private checker: ts.TypeChecker\n private program: ts.Program\n private sfiFile: ts.SourceFile\n private typeDefinitionBuilder: TypeDefinitionBuilder\n\n constructor(\n checker: ts.TypeChecker,\n sfiFile: ts.SourceFile,\n program: ts.Program\n ) {\n this.schema = {\n types: [],\n inputs: [],\n interfaces: [],\n unions: [],\n enums: [],\n scalars: [\n 'ID',\n 'Int',\n 'Float',\n 'Number',\n 'Any',\n 'Void',\n 'Object',\n 'File',\n 'Date',\n 'JSON',\n 'String',\n 'Boolean'\n ]\n }\n\n this.checker = checker\n this.sfiFile = sfiFile\n this.program = program\n\n this.typeDefinitionBuilder = new TypeDefinitionBuilder(checker, this.schema)\n }\n\n public parse(index: Index) {\n const referenceSchema = this.makeReferenceSchema(index)\n\n for (const [type, properties] of referenceSchema.types) {\n let typeName: string | undefined = undefined\n\n if (index.Query === type) {\n typeName = 'Query'\n } else if (index.Mutation === type) {\n typeName = 'Mutation'\n } else if (index.Subscription === type) {\n typeName = 'Subscription'\n }\n\n this.processSchemaReference(type, properties, typeName, 'types')\n }\n\n for (const [type, properties] of referenceSchema.inputs) {\n this.processSchemaReference(type, properties, undefined, 'inputs')\n }\n\n this.extractForbiddenFieldNamesFromSchema()\n\n this.schema.unions = this.typeDefinitionBuilder\n .getUnions()\n .map((union): Union => {\n return {\n ...union,\n description: this.getTypeDocumentation(union.rawType)\n }\n })\n\n this.schema.enums = this.typeDefinitionBuilder\n .getEnums()\n .map((enumType): Enum => {\n return {\n ...enumType,\n description: this.getTypeDocumentation(enumType.rawType)\n }\n })\n\n // Remove `types` and `inputs` that are represented as enums\n this.schema.types = this.schema.types.filter(type => {\n return !this.schema.enums.find(e => e.name === type.name)\n })\n\n this.schema.inputs = this.schema.inputs.filter(input => {\n return !this.schema.enums.find(e => e.name === input.name)\n })\n\n // Go through all unions and check if it could be an interface\n\n this.schema.unions.forEach(union => {\n const interfaceUnion = this.checkIfInterfaceIsPossibleForUnion(\n union,\n this.schema.types\n )\n\n if (interfaceUnion) {\n this.schema.interfaces.push(interfaceUnion)\n\n // Remove the union from the types\n this.schema.unions = this.schema.unions.filter(\n type => type.name !== union.name\n )\n\n // Add the `implements` field to the types that implement the interface\n this.schema.types.map(type => {\n if (union.types.includes(type.name)) {\n if (!type.implements) {\n type.implements = []\n }\n\n type.implements.push(interfaceUnion.name)\n\n return type\n }\n })\n }\n })\n\n // // Go through all types and check if a type is an interface\n\n for (const [\n classType,\n implementingTypes\n ] of referenceSchema.classImplementsMap) {\n this.schema.types.map(type => {\n const schemaType = this.schema.types.find(t => t.rawType === classType)\n\n if (schemaType) {\n schemaType.implements = Array.from(\n new Set([\n ...(schemaType.implements || []),\n ...implementingTypes.map(t => this.checker.typeToString(t))\n ])\n )\n }\n\n return type\n })\n\n // Add the implementing types to the interfaces\n for (const implementingType of implementingTypes) {\n const schemaType = this.schema.types.find(\n t => t.rawType === implementingType\n )\n\n // Remove the implementing type from the types and add it to the interfaces\n\n if (schemaType) {\n this.schema.interfaces.push({\n name: this.checker.typeToString(implementingType),\n description: this.getTypeDocumentation(implementingType),\n fields: schemaType.fields\n })\n\n this.schema.types = this.schema.types.filter(\n type => type.rawType !== implementingType\n )\n }\n }\n }\n\n // Remove `Void` fields from types when they have a implementation or are part of a union\n this.schema.types = this.schema.types.map(type => {\n if (\n type.implements ||\n this.schema.unions.find(u => u.types.includes(type.name))\n ) {\n // Remove Void fields\n type.fields = type.fields.filter(field => {\n return field.type.name !== 'Void'\n })\n }\n\n return type\n })\n\n // Generate the __resolveType function for the unions\n this.schema.unions = this.schema.unions.map(union => {\n return {\n ...union,\n __resolveType: this.getResolveTypeForUnionOrInterface(\n union,\n this.schema.types\n )\n }\n })\n\n // Generate the __resolveType function for the interfaces\n this.schema.interfaces = this.schema.interfaces.map(intf => {\n return {\n ...intf,\n __resolveType: this.getResolveTypeForUnionOrInterface(\n intf,\n this.schema.types\n )\n }\n })\n }\n\n private checkIfInterfaceIsPossibleForUnion(\n union: Union,\n types: Array<Type>\n ): Interface | null {\n const unionTypes = union.types.map(t => {\n const type = types.find(type => type.name === t)\n\n if (!type) {\n throw new Error(`Type ${t} not found`)\n }\n\n return type\n })\n\n const baseType = unionTypes[0]\n\n // Check which fields are common in all types\n\n const commonFields = baseType.fields.filter(field => {\n return unionTypes.every(type => {\n return type.fields.some(\n f => JSON.stringify(f) === JSON.stringify(field)\n )\n })\n })\n\n if (commonFields.length > 0) {\n return {\n name: union.name,\n description: union.description,\n fields: commonFields\n }\n }\n\n return null\n }\n\n private getResolveTypeForUnionOrInterface(\n entity: Union | Interface,\n types: Array<Type>\n ) {\n const entityTypes =\n 'types' in entity\n ? types.filter(t => entity.types.includes(t.name))\n : types.filter(t => t.implements?.includes(entity.name))\n\n // Sort fieldTypes by the number of fields in descending order.\n // This prioritizes types with more properties, which are more likely\n // to match a given node, thus reducing ambiguity in type resolution.\n entityTypes.sort((a, b) => b.fields.length - a.fields.length)\n\n // Check for unions with the exact same fields\n const fieldSignatures = new Map<string, Type>()\n\n entityTypes.forEach(type => {\n // Create a signature based on sorted field names\n const fieldNames = type.fields\n .map(field => field.name)\n .sort()\n .join(', ')\n\n if (fieldSignatures.has(fieldNames)) {\n const existingType = fieldSignatures.get(fieldNames)\n consola.warn(\n `Warning: Union types \"${type.name}\" and \"${existingType?.name}\" have the same fields: [${fieldNames}]. ` +\n `\\nConsider differentiating these types by adding unique fields or using different type names.` +\n `\\nThis may cause ambiguity in type resolution.`\n )\n } else {\n fieldSignatures.set(fieldNames, type)\n }\n })\n\n const checks = entityTypes.map(type => {\n const fields = type.fields\n\n const fieldChecks = fields\n .map(field => `\"${field.name}\" in node`)\n .join(' && ')\n\n return `if (${fieldChecks}) {return '${type.name}'};`\n })\n\n const str = `function resolveType(node) { if (node && typeof node === 'object') { ${checks.join(\n ' '\n )} } }`\n\n return new Function('return ' + str)()\n }\n\n public toString() {\n const {typeDefinitionToGraphQLType} = this.typeDefinitionBuilder\n\n const addDescription = (description: string) => {\n if (!description) return ''\n\n return `\"\"\"\\n${description}\\n\"\"\"\\n`\n }\n\n // build a valid GraphQL schema string from the schema object\n let schemaString = ''\n\n // loop over the input objects in the schema\n for (const input of this.schema.inputs) {\n // add the input object to the schema string\n\n schemaString += addDescription(input.description)\n schemaString += `input ${input.name} {\\n`\n\n // add a nop field to the input object if it has no fields\n if (input.fields.length === 0) {\n schemaString += `\\t_ : String\\n`\n }\n\n // loop over the fields in the input object\n for (const field of input.fields) {\n // add the field to the input object in the schema string\n schemaString += `${addDescription(field.type.description)}`\n schemaString += `\\t${field.name}: ${typeDefinitionToGraphQLType(\n field.type\n )}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // loop over the type objects in the schema\n for (const type of this.schema.types) {\n if (type.fields.length === 0) continue\n\n // add the type object to the schema string\n schemaString += addDescription(type.description)\n schemaString += `type ${type.name}`\n if (type.implements) {\n schemaString += ` implements ${type.implements.join(' & ')}`\n }\n schemaString += ` {\\n`\n\n // loop over the fields in the type object\n for (const field of type.fields) {\n // build the argument list for the field if there is at least one argument\n let args = ''\n\n if (field.args.length > 0) {\n args = `(${field.args\n .map(\n arg =>\n `${addDescription(arg.type.description)}${\n arg.name\n }: ${typeDefinitionToGraphQLType(arg.type)}`\n )\n .join(', ')})`\n }\n\n // add the field to the type object in the schema string\n schemaString += `${addDescription(field.type.description)}`\n schemaString += `${field.name}${args}: ${typeDefinitionToGraphQLType(\n field.type\n )}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // loop over the union objects in the schema\n for (const union of this.schema.unions) {\n // add the union object to the schema string\n schemaString += addDescription(union.description)\n schemaString += `union ${union.name} = ${union.types.join(' | ')}\\n`\n }\n\n // loop over the interface objects in the schema\n for (const intf of this.schema.interfaces) {\n // add the interface object to the schema string\n schemaString += addDescription(intf.description)\n schemaString += `interface ${intf.name} {\\n`\n\n // loop over the fields in the interface object\n for (const field of intf.fields) {\n // add the field to the interface object in the schema string\n schemaString += `${addDescription(field.type.description)}`\n schemaString += `${field.name}: ${typeDefinitionToGraphQLType(\n field.type\n )}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // loop over the scalar objects in the schema\n for (const scalar of this.schema.scalars) {\n // add the scalar object to the schema string\n schemaString += `scalar ${scalar}\\n`\n }\n\n // loop over the enum objects in the schema\n for (const enumType of this.schema.enums) {\n // add the enum object to the schema string\n schemaString += addDescription(enumType.description)\n schemaString += `enum ${enumType.name} {\\n`\n\n // loop over the values in the enum object\n for (const value of enumType.values) {\n // add the value to the enum object in the schema string\n schemaString += `\\t${value}\\n`\n }\n\n schemaString += `}\\n`\n }\n\n // return the schema string\n return schemaString\n }\n\n public getSchema() {\n return this.schema\n }\n\n public getResolvers() {\n // Get union and interface resolvers\n\n const resolvers: Record<\n string,\n {\n __resolveType?: (obj: any) => string\n }\n > = {}\n\n // loop over the union objects in the schema\n for (const union of this.schema.unions) {\n resolvers[union.name] = {\n __resolveType: union.__resolveType\n }\n }\n\n // loop over the interface objects in the schema\n for (const intf of this.schema.interfaces) {\n resolvers[intf.name] = {\n __resolveType: intf.__resolveType\n }\n }\n\n return resolvers\n }\n\n private processSchemaReference(\n type: ts.Type,\n properties: {[key: string]: ReferenceSchemaType},\n typeName?: string,\n processing: 'inputs' | 'types' = 'types'\n ) {\n const {getTypeDefinition} = this.typeDefinitionBuilder\n\n const isInputType = processing === 'inputs'\n\n const def = getTypeDefinition(type, {isInputType})\n\n const name = typeName || def.name\n\n let root = this.schema[processing].find(t => t.name === name)\n\n if (!root) {\n if (this.schema.scalars.includes(name)) {\n return\n } else {\n this.schema[processing].push({\n name,\n description: this.getTypeDocumentation(type),\n fields: [],\n rawType: isList(this.checker, type)\n ? type.getNumberIndexType() || type.getStringIndexType() || type\n : type\n })\n\n root = this.schema[processing][this.schema[processing].length - 1]!\n }\n }\n\n for (const [propertyName, property] of Object.entries(properties)) {\n const fieldType = property.returnType\n\n const fieldDef = getTypeDefinition(fieldType, {\n isInputType,\n propertyName\n })\n\n if (processing === 'types') {\n const field: Type['fields'][number] = {\n name: propertyName,\n type: {\n ...fieldDef,\n description: this.getTypeDocumentation(fieldType)\n },\n args: []\n }\n\n if (property.args) {\n for (const [argName, arg] of Object.entries(property.args)) {\n const argType = arg\n\n const fieldDef = getTypeDefinition(argType.type, {\n isInputType: true,\n propertyName: argName,\n isRequired: arg.isRequired\n })\n\n if (\n this.schema.scalars.includes(\n this.checker.typeToString(argType.type)\n )\n ) {\n fieldDef.name = this.checker.typeToString(argType.type)\n }\n\n field.args.push({\n name: argName,\n type: {\n ...fieldDef,\n description: argType.documentation\n }\n })\n }\n }\n\n root.fields.push(field)\n } else if (processing === 'inputs') {\n const field: Input['fields'][number] = {\n name: propertyName,\n type: {\n ...fieldDef,\n description: this.getTypeDocumentation(fieldType)\n }\n }\n\n if (!root.fields.find(f => f.name === field.name)) {\n root.fields.push(field)\n }\n }\n }\n }\n\n private getSymbolDocumentation(symbol: ts.Symbol) {\n let header = ''\n\n header += ts.displayPartsToString(\n symbol.getDocumentationComment(this.checker)\n )\n\n const tags = symbol\n .getJsDocTags(this.checker)\n .map(t => `@${t.name} ${ts.displayPartsToString(t.text)}`)\n .join('\\n')\n\n if (tags) {\n header += '\\n' + tags\n }\n\n return header\n }\n\n private getTypeDocumentation = (type: ts.Type) => {\n const symbol = type.getSymbol()\n\n if (symbol) {\n return this.getSymbolDocumentation(symbol)\n }\n\n return ''\n }\n\n /**\n * Extracts reserved field names from the schema by removing them from their respective types and inputs.\n */\n private extractForbiddenFieldNamesFromSchema(): void {\n // Define a regular expression to check if a field name is a valid GraphQL field name.\n const validFieldNameRegExp = /^[_A-Za-z][_0-9A-Za-z]*$/\n\n // Define a helper function to check if a field name is reserved.\n const isReserved = (name: string): boolean => {\n if (!validFieldNameRegExp.test(name)) {\n // console.warn(\n // `\\x1b[33mWarning: forbidden field name \"${name}\" detected\\x1b[0m`\n // )\n return true\n }\n // Fields starting with \"__\" are considered reserved.\n return name.startsWith('__')\n }\n\n // Loop over each type in the schema and remove any reserved fields.\n for (const type of this.schema.types) {\n type.fields = type.fields.filter(field => {\n if (isReserved(field.name)) {\n // console.warn(\n // `\\x1b[33mWarning: forbidden field \"${field.name}\" detected in type \"${type.name}\". This field will be excluded from the schema.\\x1b[0m`\n // )\n return false\n }\n return true\n })\n }\n\n // Loop over each input in the schema and remove any reserved fields.\n for (const input of this.schema.inputs) {\n input.fields = input.fields.filter(field => {\n if (isReserved(field.name)) {\n // console.warn(\n // `\\x1b[33mWarning: reserved field \"${field.name}\" detected in input \"${input.name}\". This field will be excluded from the schema.\\x1b[0m`\n // )\n return false\n }\n return true\n })\n }\n }\n\n private makeReferenceSchema(index: Index): ReferenceSchema {\n const referenceSchema: ReferenceSchema = {\n types: new Map(),\n inputs: new Map(),\n classImplementsMap: new Map()\n }\n\n const recLoop = (\n type: ts.Type,\n info: {\n propetyName?: string\n parentType?: ts.Type\n } = {},\n processing: 'inputs' | 'types' = 'types',\n path: Array<string> = []\n ) => {\n if (referenceSchema[processing].has(type)) {\n return\n }\n\n if (isSubscriptionRepeater(type)) {\n // type: Repeater<{ id: number; title: string; content: string; }, any, unknown>\n\n const repeaterItemType = this.checker.getTypeArguments(type as any)[0]\n\n recLoop(repeaterItemType, info, processing, [...path, 'REPEATER_ITEM'])\n\n return\n }\n\n // check if argType is a real type to ignore '[]'\n const wrongType = this.checker.typeToString(type) === '[]'\n\n if (wrongType) {\n return\n }\n\n // skip if scalar\n if (this.schema.scalars.includes(this.checker.typeToString(type))) {\n return\n }\n\n if (isPrimitive(type)) {\n return\n }\n\n if (isPromise(type)) {\n // skip if input\n if (processing === 'inputs') {\n return\n }\n\n const promiseType = getPromiseType(type)\n\n if (promiseType) {\n recLoop(promiseType, info, processing, [...path, 'PROMISE'])\n }\n\n return\n }\n\n if (type.isClass()) {\n const baseTypes = type.getBaseTypes()\n if (baseTypes) {\n baseTypes.forEach(baseType => {\n if (!referenceSchema.classImplementsMap.has(baseType)) {\n referenceSchema.classImplementsMap.set(baseType, [])\n }\n referenceSchema.classImplementsMap.get(baseType)!.push(type)\n })\n }\n }\n\n if (type.isUnion()) {\n if (isPrimitiveUnion(type)) {\n if (!referenceSchema[processing].has(type)) {\n referenceSchema[processing].set(type, {})\n }\n\n recLoop(type, info, processing, [...path, 'ENUM'])\n } else {\n if (processing === 'types') {\n type.types.forEach(t => {\n // if null or undefined, skip\n if (\n t.flags & ts.TypeFlags.Null ||\n t.flags & ts.TypeFlags.Undefined ||\n isPrimitive(t)\n ) {\n return\n }\n\n recLoop(t, info, processing, [\n ...path,\n t.symbol?.getName() || `N/A ${this.checker.typeToString(t)}`\n ])\n })\n } else {\n let firstType = type.getNonNullableType()\n\n if (firstType.isUnion() && !isPrimitive(firstType)) {\n consola.warn(\n `Warning: Union types in input fields are not supported yet. Defaulting to the first type (${this.checker.typeToString(\n firstType\n )}) at path: ${path.join(' > ')}`\n )\n\n firstType = firstType.types[0]\n }\n\n recLoop(firstType, info, processing, [...path, 'NON_NULLABLE'])\n }\n }\n } else if (isFunction(type)) {\n // skip fn for inputs\n if (processing === 'inputs') {\n return\n }\n\n if (!info.parentType) {\n throw new Error('Cannot have a function without a parent type')\n }\n\n const signature = type.getCallSignatures()[0]\n const args = signature?.getParameters() || []\n const returnType = signature?.getReturnType()\n\n const schemaType = referenceSchema[processing].get(info.parentType)![\n info.propetyName!\n ]!\n\n args.forEach(arg => {\n const argType = this.checker.getTypeOfSymbolAtLocation(\n arg,\n this.sfiFile\n )\n\n if (this.checker.isTupleType(argType)) {\n // Iterate over the rest of the arguments\n const tupleType = argType as ts.TupleType\n\n const elements = (tupleType.target as any)\n .labeledElementDeclarations\n\n elements.forEach((element, idx: number) => {\n const elementType = this.checker.getTypeAtLocation(element)\n\n const elementName = element.name.text\n const elementSymbol = this.checker.getSymbolAtLocation(element)\n\n const elementDocumentation = this.getSymbolDocumentation(\n elementSymbol || arg\n )\n\n schemaType.args[elementName] = {\n type: elementType,\n isRequired:\n element.initializer === undefined ? undefined : false,\n documentation: elementDocumentation\n }\n\n recLoop(\n elementType,\n {\n parentType: type\n },\n 'inputs',\n [...path, elementName]\n )\n })\n } else if (\n arg.valueDeclaration &&\n ts.isParameter(arg.valueDeclaration) &&\n arg.valueDeclaration.dotDotDotToken\n ) {\n consola.warn(\n `Warning: Rest parameters without explicit names are not supported. ` +\n `Skipping rest parameter at path: ${path.join(' > ')}.\\n\\n` +\n `Unsupported: \\`function example(...args: any[]) { }\\`.\\n` +\n `Supported: \\`function example(...namedArgs: [first: string, second: number]) { }\\`.\\n` +\n `Please provide named rest parameters to ensure proper type resolution.`\n )\n } else {\n const valueDeclaration =\n arg.valueDeclaration as ts.ParameterDeclaration\n\n // set args to empty object if not set\n if (schemaType.args) {\n schemaType.args[arg.escapedName as string] = {\n type: argType,\n isRequired:\n valueDeclaration.initializer === undefined\n ? undefined\n : false,\n documentation: this.getSymbolDocumentation(arg)\n }\n\n recLoop(\n argType,\n {\n parentType: type\n },\n 'inputs',\n [...path, arg.escapedName as string]\n )\n }\n }\n })\n\n if (returnType) {\n recLoop(returnType, info, processing, [...path, 'RETURN_TYPE'])\n }\n } else if (isList(this.checker, type)) {\n const itemType = this.checker.getIndexTypeOfType(\n type,\n ts.IndexKind.Number\n )\n\n if (itemType && !isPrimitive(itemType)) {\n if (!referenceSchema[processing].has(type)) {\n referenceSchema[processing].set(type, {})\n }\n\n recLoop(itemType, info, processing, [...path, 'ITEM_TYPE'])\n }\n } else if (!isPrimitive(type)) {\n const properties = getPublicPropertiesOfType(this.checker, type)\n\n if (!referenceSchema[processing].has(type)) {\n referenceSchema[processing].set(type, {})\n }\n\n properties.forEach(property => {\n const propertyType = this.checker.getTypeOfSymbolAtLocation(\n property,\n this.sfiFile\n )\n\n if (\n !referenceSchema[processing].get(type)![\n property.escapedName as string\n ]\n ) {\n referenceSchema[processing].get(type)![\n property.escapedName as string\n ] = {\n returnType: propertyType,\n args: {}\n }\n }\n\n recLoop(\n propertyType,\n {\n propetyName: property.escapedName as string,\n parentType: type\n },\n processing,\n [...path, property.escapedName as string]\n )\n })\n }\n }\n\n if (index.Query) {\n recLoop(index.Query)\n }\n\n if (index.Mutation) {\n recLoop(index.Mutation)\n }\n\n if (index.Subscription) {\n recLoop(index.Subscription)\n }\n\n // Handle classes that implement interfaces of the schema\n const sourceFiles = this.program.getSourceFiles()\n\n for (const sourceFile of sourceFiles) {\n ts.forEachChild(sourceFile, node => {\n if (ts.isClassDeclaration(node)) {\n const baseTypes =\n node.heritageClauses?.flatMap(heritage =>\n heritage.types.map(type => {\n return type\n })\n ) || []\n\n // Check if the class implements an interface\n if (baseTypes.length > 0) {\n for (const baseType of baseTypes) {\n if (\n referenceSchema.types.has(\n this.checker.getTypeAtLocation(baseType)\n )\n ) {\n referenceSchema.classImplementsMap.set(\n this.checker.getTypeAtLocation(node),\n [this.checker.getTypeAtLocation(baseType)]\n )\n\n recLoop(this.checker.getTypeAtLocation(node))\n }\n }\n }\n }\n })\n }\n\n return referenceSchema\n }\n}\n", "import ts from 'typescript'\n\nexport const isEmptyObject = (type: ts.Type) => {\n return (\n type.flags & ts.TypeFlags.Object &&\n type.getProperties().length === 0 &&\n type.getCallSignatures().length === 0\n )\n}\n\nexport const isList = (checker: ts.TypeChecker, type: ts.Type) => {\n const typeNode = checker.typeToTypeNode(type, undefined, undefined)\n\n const is = !!(\n typeNode &&\n (typeNode.kind === ts.SyntaxKind.ArrayType ||\n typeNode.kind === ts.SyntaxKind.TupleType)\n )\n\n if (!is) {\n // Check if type references an array\n const isArray = type.getSymbol()?.getName() === 'Array'\n\n if (isArray) {\n return true\n }\n }\n\n return is\n}\n\nexport const isBoolean = (type: ts.Type) => {\n // check if is union and all types are boolean\n if (type.isUnion()) {\n const isAllBooleans = type.types.every(\n t => t.flags & ts.TypeFlags.BooleanLiteral\n )\n\n return isAllBooleans\n }\n\n return false\n}\n\nexport const isPrimitive = (type: ts.Type) => {\n const primitive =\n type.flags & ts.TypeFlags.String ||\n type.flags & ts.TypeFlags.Number ||\n type.flags & ts.TypeFlags.Boolean ||\n type.flags & ts.TypeFlags.StringLiteral ||\n type.flags & ts.TypeFlags.NumberLiteral ||\n type.flags & ts.TypeFlags.BooleanLiteral\n\n return primitive\n}\n\nexport const isFunction = (type: ts.Type) => {\n return type.getCallSignatures().length > 0\n}\n\nexport const isPrimitiveUnion = (type: ts.Type) => {\n if (isPrimitive(type)) return false\n\n const isUnion = (type as ts.UnionType).types?.length > 1\n\n if (isUnion) {\n // check if all types are primitives\n const isAllPrimitives = (type as ts.UnionType).types.every(\n t =>\n t.flags & ts.TypeFlags.StringLiteral ||\n t.flags & ts.TypeFlags.NumberLiteral ||\n t.flags & ts.TypeFlags.BooleanLiteral\n )\n\n if (isAllPrimitives) {\n return true\n }\n }\n\n return false\n}\n\nexport const isPromise = (type: ts.Type) => {\n // check if type is a promise\n return type.getSymbol()?.getName() === 'Promise'\n}\n\nexport const getPromiseType = (type: ts.Type) => {\n let objectType = type as ts.ObjectType\n\n if (objectType.objectFlags & ts.ObjectFlags.Reference) {\n const reference = type as ts.TypeReference\n const typeArguments = reference.typeArguments\n if (typeArguments && typeArguments.length > 0) {\n return typeArguments[0]\n }\n }\n}\n\nexport const excludeNullUndefinedFromType = (type: ts.Type) => {\n if (!type.isUnion())\n return {\n type,\n wasOptional: false\n }\n\n const types = type.types.filter(\n t => !(t.flags & ts.TypeFlags.Undefined || t.flags & ts.TypeFlags.Null)\n )\n\n const wasOptional = types.length !== type.types.length\n\n return {\n type: type.getNonNullableType(),\n wasOptional\n }\n}\n\nexport function getPublicPropertiesOfType(\n checker: ts.TypeChecker,\n _type: ts.Type\n): ts.Symbol[] {\n let type = _type\n\n if (type.isUnion()) {\n // Filter out array types from the union if their non-array counterparts are also present\n const nonArrayTypes = type.types.filter(\n t =>\n !(\n t.flags & ts.TypeFlags.Object &&\n (t as ts.ObjectType).objectFlags & ts.ObjectFlags.Reference &&\n (t as ts.TypeReference).typeArguments?.length\n )\n )\n const arrayElementTypes = type.types\n .filter(\n t =>\n t.flags & ts.TypeFlags.Object &&\n (t as ts.ObjectType).objectFlags & ts.ObjectFlags.Reference &&\n (t as ts.TypeReference).typeArguments?.length\n )\n .map(t => (t as ts.TypeReference).typeArguments![0])\n const filteredTypes = nonArrayTypes.filter(\n t => !arrayElementTypes.some(et => et === t)\n )\n // .filter(t => {\n // // filter out primitive types\n // return !isPrimitive(t)\n // })\n\n // Create a new type that is the union of all the types in the union\n // This is necessary because the type checker will not resolve properties\n // that are only present on some types in the union\n // getUnionType is not available in TS 3.7, so we have to use the private API\n type = (checker as any).getUnionType(filteredTypes) as ts.Type\n }\n\n const properties: ts.Symbol[] = []\n\n // if type is a primitive, return empty array\n if (isList(checker, type) || isPrimitive(type) || isPrimitiveUnion(type))\n return properties\n\n let typeProperties: ts.Symbol[] = []\n\n typeProperties =\n (type as any).resolvedProperties || type.getProperties() || []\n\n for (const prop of typeProperties) {\n const isPublic =\n prop.valueDeclaration &&\n !(\n ts.getCombinedModifierFlags(prop.valueDeclaration) &\n ts.ModifierFlags.Private\n ) &&\n !prop.getName().startsWith('#')\n\n if (isPublic === false) {\n continue\n }\n\n properties.push(prop)\n }\n\n return properties\n}\n\nexport const safeTypeName = (name: string) => {\n return name.replace(/[^0-9a-zA-Z_]/g, '_')\n}\n\nexport const isSubscriptionRepeater = (type: ts.Type) => {\n return !!type\n .getSymbol()\n ?.getDeclarations()\n ?.some(d => {\n const sourceFile = d.getSourceFile().fileName\n\n return sourceFile.includes('@repeaterjs')\n })\n}\n", "import ts from 'typescript'\nimport {\n excludeNullUndefinedFromType,\n getPromiseType,\n isEmptyObject,\n isPrimitiveUnion,\n isFunction,\n isList,\n isPrimitive,\n isPromise,\n isSubscriptionRepeater,\n safeTypeName\n} from './types-helper.js'\nimport {Schema} from './schema-parser.js'\n\nexport interface Union {\n name: string\n rawType: ts.Type\n types: Array<string>\n}\n\nexport interface Enum {\n name: string\n rawType: ts.Type\n values: Array<string>\n}\n\ninterface FieldDefinition {\n name: string\n isList: boolean\n isRequired: boolean\n isListRequired?: boolean\n}\n\nexport class TypeDefinitionBuilder {\n private checker: ts.TypeChecker\n private schema: Schema\n\n private typesNameMap: Map<ts.Type, string> = new Map()\n private inputsNameMap: Map<ts.Type, string> = new Map()\n\n private unions: Array<Union> = []\n private enums: Array<Enum> = []\n\n constructor(checker: ts.TypeChecker, schema: Schema) {\n this.checker = checker\n this.schema = schema\n }\n\n getTypeDefinition = (\n rawType: ts.Type,\n options: {\n isInputType?: boolean\n isRequired?: boolean\n propertyName?: string\n } = {\n isInputType: false\n }\n ): FieldDefinition => {\n const {type, wasOptional} = excludeNullUndefinedFromType(rawType)\n\n if (\n type.flags & ts.TypeFlags.Void ||\n type.flags & ts.TypeFlags.Undefined ||\n type.flags & ts.TypeFlags.Null\n ) {\n return {\n name: 'Void',\n isList: false,\n isRequired: false\n }\n }\n\n if (isSubscriptionRepeater(type)) {\n const repeaterItemType = this.checker.getTypeArguments(type as any)[0]\n\n if (repeaterItemType) {\n return this.getTypeDefinition(repeaterItemType, options)\n }\n }\n\n if (isPromise(type)) {\n const promiseType = getPromiseType(type)\n if (promiseType) {\n return this.getTypeDefinition(promiseType, options)\n }\n }\n\n const isRequired =\n options.isRequired !== undefined ? options.isRequired : !wasOptional\n\n if (isEmptyObject(type)) {\n return {\n name: 'Object',\n isList: false,\n isRequired\n }\n }\n\n let nameMap = options.isInputType ? this.inputsNameMap : this.typesNameMap\n\n if (nameMap.has(type)) {\n const typeName = nameMap.get(type) as string\n\n return {\n name: typeName,\n isList: false,\n isRequired\n }\n }\n\n let typeName: string | undefined =\n type.aliasSymbol?.escapedName?.toString() ||\n type.symbol?.escapedName.toString()\n\n if (typeName === '__type' || typeName === '__object') {\n if (!options.propertyName) {\n typeName = undefined\n } else {\n const capitalizedPropertyName =\n options.propertyName.charAt(0).toUpperCase() +\n options.propertyName.slice(1)\n\n typeName = capitalizedPropertyName\n }\n }\n\n if (typeName) {\n typeName = safeTypeName(typeName)\n }\n\n const duplicateName = (name: string) => {\n // find name in typeNameMap\n return Array.from(nameMap.values()).includes(name)\n }\n\n if (typeName && !this.schema.scalars.includes(typeName)) {\n if (options.isInputType) {\n typeName = `${typeName}Input`\n }\n\n let i = 1\n let originalTypeName = typeName\n while (duplicateName(typeName as string)) {\n typeName = `${originalTypeName}_${i}`\n\n i++\n }\n }\n\n if (typeName && this.schema.scalars.includes(typeName)) {\n return {\n name: typeName,\n isList: false,\n isRequired\n }\n }\n\n if (isList(this.checker, type)) {\n const listType = this.checker.getIndexTypeOfType(\n type,\n ts.IndexKind.Number\n )\n\n if (listType) {\n const def = this.getTypeDefinition(listType, options)\n\n return {\n name: def.name,\n isList: true,\n isRequired: def.isRequired,\n isListRequired: isRequired\n }\n }\n } else if (isPrimitiveUnion(type)) {\n const typeNode = this.checker.typeToTypeNode(\n type,\n undefined,\n undefined\n ) as any | undefined\n\n const types = (type as ts.UnionType).types\n\n // enumerate all members of the enum\n const members = types.map((t: ts.Type) => {\n if (t.isLiteral()) {\n const name = t.value?.toString()\n\n if (!name) {\n throw new Error('Enum member name is undefined')\n }\n\n return safeTypeName(name)\n }\n\n throw new Error('Invalid type for enum member')\n })\n\n if (members.length > 0) {\n typeName = typeName || typeNode.typeName?.symbol?.escapedName\n\n if (!typeName) {\n typeName = members.join('_').toUpperCase()\n typeName = options.isInputType ? `${typeName}Input` : typeName\n }\n\n this.enums.push({\n name: typeName,\n values: members,\n rawType: type\n })\n }\n }\n // handle primitives\n else if (isPrimitive(type)) {\n let typeName = this.checker.typeToString(type)\n\n if (type.flags & ts.TypeFlags.StringLiteral) {\n typeName = 'String'\n } else if (type.flags & ts.TypeFlags.NumberLiteral) {\n typeName = 'Number'\n } else if (type.flags & ts.TypeFlags.BooleanLiteral) {\n typeName = 'Boolean'\n } else if (type.flags & ts.TypeFlags.String) {\n typeName = 'String'\n } else if (type.flags & ts.TypeFlags.Number) {\n typeName = 'Number'\n } else if (type.flags & ts.TypeFlags.Boolean) {\n typeName = 'Boolean'\n }\n\n return {\n name: safeTypeName(typeName),\n isList: false,\n isRequired\n }\n } else if (type.isIntersection()) {\n const intersectionTypes = type.types\n\n const typeNames = intersectionTypes.map(t => {\n const typeDef = this.getTypeDefinition(t, options)\n\n return typeDef.name\n })\n\n typeName = safeTypeName(typeName || typeNames.join('And'))\n } else if (type.isUnion()) {\n const unionTypes = type.types\n const required = type.types.length === unionTypes.length\n\n const hasPrimitivesOrEnum = unionTypes.some(t => {\n // If t is a array take the element type\n const type = isList(this.checker, t)\n ? this.checker.getIndexTypeOfType(t, ts.IndexKind.Number)\n : t\n\n if (!type) {\n // Return true if the type is undefined because we don't know what it is\n // Marking it as a primitive or enum will make it more error prone\n return true\n }\n\n return isPrimitive(type) || isPrimitiveUnion(type)\n })\n\n const unionTypeDefs = [\n ...new Set(\n unionTypes.map(t =>\n this.getTypeDefinition(t, {...options, isRequired: required})\n )\n )\n ]\n\n // If the union contains a array of some type, remove the type from the union because\n // the array type will be handled by the list type\n\n const listTypes = unionTypeDefs.filter(t => t.isList)\n\n // Check if the union contains the same type as a list\n for (const listType of listTypes) {\n const index = unionTypeDefs.findIndex(\n t => t.name === listType.name && !t.isList\n )\n\n if (index > -1) {\n unionTypeDefs.splice(index, 1)\n }\n }\n\n const typeNames = unionTypeDefs.map(t => t.name)\n\n typeName = safeTypeName(typeName || typeNames.join('Or'))\n\n // check if typeName is a duplicate\n if (typeName) {\n let i = 1\n let originalTypeName = typeName\n while (duplicateName(typeName as string)) {\n typeName = `${originalTypeName}_${i}`\n\n i++\n }\n }\n\n if (\n unionTypeDefs.length > 1 &&\n !options.isInputType &&\n !hasPrimitivesOrEnum\n ) {\n this.unions.push({\n name: typeName,\n types: typeNames,\n rawType: type\n })\n } else {\n // We only care about the first type in the union since GraphQL doesn't support unions of input types\n const typeDef = unionTypeDefs[0]\n\n if (!typeDef) {\n throw new Error('Cannot get type definition')\n }\n\n // If the types contain a list of the same type as the first type, then we can make the first type a list\n const isList = unionTypeDefs.some(t => {\n return t.isList && t.name === typeDef.name\n })\n\n return {\n name: typeDef.name,\n isList,\n isRequired\n }\n }\n }\n // handle functions\n else if (isFunction(type)) {\n const signature = type.getCallSignatures()[0]\n let returnType = signature?.getReturnType()\n\n if (returnType) {\n if (isPromise(returnType)) {\n const pt = getPromiseType(returnType)\n\n if (pt) {\n returnType = pt\n }\n }\n }\n\n if (returnType) {\n const def = this.getTypeDefinition(returnType, options)\n\n return def\n }\n }\n\n if (!typeName) {\n typeName = 'Any'\n }\n\n nameMap.set(type, typeName)\n\n return {\n name: typeName,\n isList: false,\n isRequired\n }\n }\n\n public getUnions(): Array<Union> {\n return this.unions\n }\n\n public getEnums(): Array<Enum> {\n return this.enums\n }\n\n public typeDefinitionToGraphQLType = (\n typeDefinition: FieldDefinition\n ): string => {\n let type = typeDefinition.name\n const {isList, isRequired, isListRequired} = typeDefinition\n\n if (isRequired) {\n type = `${type}!`\n }\n\n if (isList) {\n type = `[${type}]`\n\n if (isListRequired) {\n type = `${type}!`\n }\n }\n\n return type\n }\n}\n", "import path from 'path'\nimport fs from 'fs/promises'\nimport {generateClient} from '@gqty/cli'\nimport {buildSchema} from 'graphql'\nimport {updateFileIfChanged} from './update-file-if-changed'\n\nconst PYLON_SCHEMA_PATH = path.join(process.cwd(), '.pylon/schema.graphql')\nconst PYLON_CLIENT_PATH = path.join(process.cwd(), '.pylon/client/index.ts')\n\nexport interface BuildClientOptions {\n /**\n * Client will be generated if the schema has changed or if the client does not exist\n */\n schemaChanged: boolean\n}\n\nexport const buildClient = async ({schemaChanged}: BuildClientOptions) => {\n // Check if the schema exists\n\n try {\n await fs.access(PYLON_SCHEMA_PATH)\n } catch (e) {\n throw new Error(\n 'Schema not found. Please run `pylon build` or `pylon dev` first.'\n )\n }\n\n // Check if the client exists\n if (!schemaChanged) {\n // If the schema has not changed, we need to check if the client exists\n try {\n await fs.access(PYLON_CLIENT_PATH)\n return\n } catch (e) {\n // If the client does not exist, we need to generate it\n }\n }\n\n const schema = await fs.readFile(PYLON_SCHEMA_PATH, 'utf-8')\n\n const schemaObj = buildSchema(schema)\n\n // Write the custom client index file because the default one is not compatible with Pylon\n await fs.mkdir(path.dirname(PYLON_CLIENT_PATH), {recursive: true})\n await updateFileIfChanged(PYLON_CLIENT_PATH, customClientIndex)\n\n await generateClient(schemaObj, {\n endpoint: 'will-be-overwritten',\n frameworks: ['react'],\n destination: PYLON_CLIENT_PATH,\n react: true,\n scalarTypes: {\n Number: 'number',\n Object: 'Record<string, unknown>'\n }\n })\n}\n\nconst customClientIndex = `/**\n * GQty: You can safely modify this file based on your needs.\n */\n\nimport {createReactClient} from '@gqty/react'\nimport {\n Cache,\n createClient,\n defaultResponseHandler,\n type QueryFetcher\n} from 'gqty'\nimport {\n generatedSchema,\n scalarsEnumsHash,\n type GeneratedSchema\n} from './schema.generated'\n\nconst queryFetcher: QueryFetcher = async function (\n {query, variables, operationName},\n fetchOptions\n) {\n let browserOrInternalFetch: typeof fetch | typeof app.request = fetch\n\n try {\n const moduleNameToPreventBundling = '@getcronit/pylon'\n const {app} = await import(moduleNameToPreventBundling)\n\n browserOrInternalFetch = app.request\n } catch (error) {\n // Pylon is not found. Maybe we are running in a different environment.\n }\n\n const response = await browserOrInternalFetch('/graphql', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json'\n },\n body: JSON.stringify({\n query,\n variables,\n operationName\n }),\n mode: 'cors',\n ...fetchOptions\n })\n\n return await defaultResponseHandler(response)\n}\n\nconst cache = new Cache(\n undefined,\n /**\n * Default option is immediate cache expiry but keep it for 5 minutes,\n * allowing soft refetches in background.\n */\n {\n maxAge: Infinity,\n staleWhileRevalidate: 5 * 60 * 1000,\n normalization: true\n }\n)\n\nexport const client = createClient<GeneratedSchema>({\n schema: generatedSchema,\n scalars: scalarsEnumsHash,\n cache,\n fetchOptions: {\n fetcher: queryFetcher\n }\n})\n\n// Core functions\nexport const {resolve, subscribe, schema} = client\n\n// Legacy functions\nexport const {query, mutation, mutate, subscription, resolved, refetch, track} =\n client\n\nexport const {\n graphql,\n useQuery,\n usePaginatedQuery,\n useTransactionQuery,\n useLazyQuery,\n useRefetch,\n useMutation,\n useMetaState,\n prepareReactRender,\n useHydrateCache,\n prepareQuery\n} = createReactClient<GeneratedSchema>(client, {\n defaults: {\n // Enable Suspense, you can override this option for each hook.\n suspense: false\n }\n})\n\nexport * from './schema.generated'`\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["telemetry", "program", "consola", "dotenv", "pm2", "version", "path", "context", "esbuildPluginTsc", "path", "fs", "path", "fs", "fs", "updateFileIfChanged", "path", "newContent", "err", "injectCodePlugin", "getBuildDefs", "outputDir", "build", "args", "path", "typeDefs", "resolvers", "preparedResolvers", "prepareObjectInjection", "contents", "fs", "typeDefsPath", "updateFileIfChanged", "resolversPath", "obj", "key", "value", "path", "fs", "consola", "notifyPlugin", "dir", "onBuild", "build", "loadSchema", "schemaPath", "cachedSchema", "startTime", "result", "error", "warning", "duration", "totalFiles", "totalSize", "acc", "output", "latestSchema", "schemaChanged", "Bundler", "sfiFilePath", "outputDir", "args", "configPath", "path", "config", "e", "buildContexts", "plugins", "plugin", "ctx", "options", "inputPath", "dir", "fs", "writeOnEndPlugin", "build", "result", "file", "updateFileIfChanged", "context", "notifyPlugin", "output", "injectCodePlugin", "esbuildPluginTsc", "pluginCtxs", "ts", "ts", "ts", "isEmptyObject", "type", "isList", "checker", "typeNode", "is", "isPrimitive", "type", "ts", "isFunction", "isPrimitiveUnion", "t", "isPromise", "getPromiseType", "typeArguments", "excludeNullUndefinedFromType", "wasOptional", "getPublicPropertiesOfType", "checker", "_type", "nonArrayTypes", "arrayElementTypes", "filteredTypes", "et", "properties", "isList", "typeProperties", "prop", "safeTypeName", "name", "isSubscriptionRepeater", "d", "ts", "TypeDefinitionBuilder", "checker", "schema", "rawType", "options", "type", "wasOptional", "excludeNullUndefinedFromType", "ts", "isSubscriptionRepeater", "repeaterItemType", "isPromise", "promiseType", "getPromiseType", "isRequired", "isEmptyObject", "nameMap", "typeName", "safeTypeName", "duplicateName", "name", "i", "originalTypeName", "isList", "listType", "def", "isPrimitiveUnion", "typeNode", "members", "t", "isPrimitive", "typeNames", "unionTypes", "required", "hasPrimitivesOrEnum", "unionTypeDefs", "listTypes", "index", "typeDef", "isFunction", "returnType", "pt", "typeDefinition", "isListRequired", "consola", "SchemaParser", "checker", "sfiFile", "program", "TypeDefinitionBuilder", "index", "referenceSchema", "type", "properties", "typeName", "union", "enumType", "e", "input", "interfaceUnion", "classType", "implementingTypes", "schemaType", "t", "implementingType", "u", "field", "intf", "types", "unionTypes", "commonFields", "f", "entity", "entityTypes", "a", "b", "fieldSignatures", "fieldNames", "existingType", "str", "typeDefinitionToGraphQLType", "addDescription", "description", "schemaString", "args", "arg", "scalar", "value", "resolvers", "processing", "getTypeDefinition", "isInputType", "def", "name", "root", "isList", "propertyName", "property", "fieldType", "fieldDef", "argName", "argType", "symbol", "header", "ts", "tags", "validFieldNameRegExp", "isReserved", "recLoop", "info", "path", "isSubscriptionRepeater", "repeaterItemType", "isPrimitive", "isPromise", "promiseType", "getPromiseType", "baseTypes", "baseType", "isPrimitiveUnion", "firstType", "isFunction", "signature", "returnType", "element", "idx", "elementType", "elementName", "elementSymbol", "elementDocumentation", "valueDeclaration", "itemType", "getPublicPropertiesOfType", "propertyType", "sourceFiles", "sourceFile", "node", "heritage", "path", "SchemaBuilder", "sfiFilePath", "tsConfigOptions", "filesInSfiDir", "ts", "file", "sfiFileSymbol", "sfiFileDefaultExport", "exportSymbol", "defaultOptions", "configPath", "configFile", "sfiType", "queryProperty", "mutationProperty", "subscriptionProperty", "queryType", "mutationType", "subscriptionType", "parser", "SchemaParser", "build", "options", "bundler", "Bundler", "builder", "SchemaBuilder", "path", "built", "path", "fs", "generateClient", "buildSchema", "PYLON_SCHEMA_PATH", "path", "PYLON_CLIENT_PATH", "buildClient", "schemaChanged", "fs", "schema", "schemaObj", "buildSchema", "updateFileIfChanged", "customClientIndex", "generateClient", "dotenv", "program", "version", "ctx", "build", "totalFiles", "totalSize", "duration", "schemaChanged", "buildClient", "main", "options", "command", "pm2", "err", "consola", "bus", "data", "apps", "code"]
|
|
7
7
|
}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@getcronit/pylon-dev",
|
|
3
3
|
"type": "module",
|
|
4
|
-
"version": "2.0.0-canary-
|
|
4
|
+
"version": "2.0.0-canary-20250211153808.b2b63f4e67c55542413f7be6d62ce8139cfcbdbe",
|
|
5
5
|
"description": "CLI for creating a Pylon",
|
|
6
6
|
"bin": {
|
|
7
7
|
"pylon": "./dist/index.js"
|
|
@@ -22,8 +22,7 @@
|
|
|
22
22
|
"commander": "^12.1.0",
|
|
23
23
|
"consola": "^3.2.3",
|
|
24
24
|
"dotenv": "^16.4.5",
|
|
25
|
-
"
|
|
26
|
-
"@getcronit/pylon-telemetry": "^1.0.2"
|
|
25
|
+
"@getcronit/pylon-telemetry": "^1.0.3"
|
|
27
26
|
},
|
|
28
27
|
"publishConfig": {
|
|
29
28
|
"access": "public"
|
|
@@ -35,10 +34,12 @@
|
|
|
35
34
|
"@types/ps-tree": "^1.1.6",
|
|
36
35
|
"esbuild": "^0.23.1",
|
|
37
36
|
"esbuild-plugin-tsc": "^0.4.0",
|
|
37
|
+
"pm2": "^5.4.3",
|
|
38
38
|
"typescript": "^5.7.3"
|
|
39
39
|
},
|
|
40
40
|
"peerDependencies": {
|
|
41
|
-
"@getcronit/pylon": "3.0.0-canary-
|
|
41
|
+
"@getcronit/pylon": "3.0.0-canary-20250211153808.b2b63f4e67c55542413f7be6d62ce8139cfcbdbe",
|
|
42
|
+
"graphql": "^16.9.0"
|
|
42
43
|
},
|
|
43
44
|
"scripts": {
|
|
44
45
|
"build": "rimraf ./dist && esbuild ./src/index.ts --bundle --platform=node --target=node18 --format=esm --minify --outdir=./dist --sourcemap=linked --packages=external"
|