@getcronit/pylon-dev 1.0.0-beta.1 → 1.0.0-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/dist/index.js +99 -25
  2. package/package.json +7 -2
package/dist/index.js CHANGED
@@ -2,17 +2,19 @@
2
2
  // @bun
3
3
 
4
4
  // src/index.ts
5
- import {build} from "@getcronit/pylon-builder";
6
- import {fetchSchema, generateClient} from "@gqty/cli";
7
- import {program} from "commander";
5
+ import { build } from "@getcronit/pylon-builder";
6
+ import { fetchSchema, generateClient } from "@gqty/cli";
7
+ import { program } from "commander";
8
8
  import consola from "consola";
9
9
  import path from "path";
10
10
  // package.json
11
- var version = "2.0.0";
11
+ var version = "1.0.0";
12
12
 
13
13
  // src/index.ts
14
- import {spawn} from "child_process";
14
+ import { spawn } from "child_process";
15
15
  import kill from "treekill";
16
+ import * as telemetry from "@getcronit/pylon-telemetry";
17
+ import dotenv from "dotenv";
16
18
  async function main(options, command) {
17
19
  consola.log(`[Pylon]: ${command.name()} version ${command.version()}`);
18
20
  let currentProc = null;
@@ -25,7 +27,6 @@ async function main(options, command) {
25
27
  }
26
28
  });
27
29
  }
28
- await new Promise((resolve) => setTimeout(resolve, 1000));
29
30
  currentProc = spawn(options.command, {
30
31
  shell: true,
31
32
  stdio: "inherit",
@@ -80,23 +81,56 @@ async function main(options, command) {
80
81
  }
81
82
  };
82
83
  consola.start("[Pylon]: Building schema");
83
- await build({
84
- sfiFilePath: "./src/index.ts",
85
- outputFilePath: `./.pylon`,
86
- watch: true,
87
- onWatch: async (schemaChanged) => {
88
- await serve(schemaChanged);
89
- consola.start("[Pylon]: Reloading server");
90
- if (schemaChanged) {
91
- consola.info("[Pylon]: Schema updated");
84
+ try {
85
+ const { duration, totalFiles, totalSize } = await build({
86
+ sfiFilePath: "./src/index.ts",
87
+ outputFilePath: `./.pylon`,
88
+ watch: true,
89
+ onWatch: async ({ schemaChanged, totalFiles: totalFiles2, totalSize: totalSize2, duration: duration2 }) => {
90
+ const isServerRunning = currentProc !== null;
91
+ if (isServerRunning) {
92
+ consola.start("[Pylon]: Reloading server");
93
+ } else {
94
+ consola.start("[Pylon]: Starting server");
95
+ }
96
+ await serve(schemaChanged);
97
+ if (isServerRunning) {
98
+ consola.ready("[Pylon]: Server reloaded");
99
+ } else {
100
+ consola.ready("[Pylon]: Server started");
101
+ consola.box(`
102
+ Pylon is up and running!
103
+
104
+ Press \`Ctrl + C\` to stop the server.
105
+
106
+ Encounter any issues? Report them here:
107
+ https://github.com/getcronit/pylon/issues
108
+
109
+ We value your feedback\u2014help us make Pylon even better!
110
+ `);
111
+ }
112
+ if (schemaChanged) {
113
+ consola.info("[Pylon]: Schema updated");
114
+ await telemetry.sendBuildEvent({
115
+ duration: duration2,
116
+ totalFiles: totalFiles2,
117
+ totalSize: totalSize2,
118
+ isDevelopment: true
119
+ });
120
+ }
92
121
  }
93
- }
94
- });
95
- consola.success("[Pylon]: Schema built");
96
- consola.start("[Pylon]: Starting server");
97
- await serve(true);
98
- consola.ready("[Pylon]: Server started");
99
- consola.box(`
122
+ });
123
+ await telemetry.sendBuildEvent({
124
+ duration,
125
+ totalFiles,
126
+ totalSize,
127
+ isDevelopment: true
128
+ });
129
+ consola.success("[Pylon]: Schema built");
130
+ consola.start("[Pylon]: Starting server");
131
+ await serve(true);
132
+ consola.ready("[Pylon]: Server started");
133
+ consola.box(`
100
134
  Pylon is up and running!
101
135
 
102
136
  Press \`Ctrl + C\` to stop the server.
@@ -106,18 +140,58 @@ async function main(options, command) {
106
140
 
107
141
  We value your feedback\u2014help us make Pylon even better!
108
142
  `);
143
+ } catch (e) {
144
+ consola.error("[Pylon]: Couldn't build schema", e);
145
+ const proc = currentProc;
146
+ if (proc) {
147
+ proc.removeAllListeners();
148
+ kill(proc.pid, "SIGINT", (err) => {
149
+ if (err) {
150
+ consola.error(err);
151
+ }
152
+ });
153
+ }
154
+ }
155
+ process.on("SIGINT", async (code) => {
156
+ try {
157
+ if (currentProc) {
158
+ currentProc.removeAllListeners();
159
+ kill(currentProc.pid, "SIGINT", (err) => {
160
+ if (err) {
161
+ consola.error(err);
162
+ }
163
+ });
164
+ }
165
+ } catch {
166
+ } finally {
167
+ await telemetry.sendDevEvent({
168
+ duration: Date.now() - start,
169
+ clientPath: options.clientPath,
170
+ clientPort: parseInt(options.clientPort)
171
+ });
172
+ process.exit(0);
173
+ }
174
+ });
109
175
  }
176
+ dotenv.config();
110
177
  program.name("pylon-dev").description("Pylon Development CLI").version(version);
111
178
  program.command("build").description("Build the Pylon Schema").action(async () => {
112
179
  consola.start("[Pylon]: Building schema");
113
- await build({
180
+ const { totalFiles, totalSize, duration } = await build({
114
181
  sfiFilePath: "./src/index.ts",
115
182
  outputFilePath: "./.pylon"
116
183
  });
184
+ await telemetry.sendBuildEvent({
185
+ duration,
186
+ totalFiles,
187
+ totalSize,
188
+ isDevelopment: false
189
+ });
117
190
  consola.success("[Pylon]: Schema built");
118
191
  });
119
192
  program.name("dev").option("-c, --command <command>", "Command to run the server", "bun run .pylon/index.js").option("--client", "Generate the client from the server's schema").option("--test", "Test").option("--client-path <clientPath>", "Path to generate the client to", "gqty/index.ts").option("--client-port <clientPort>", "Port of the pylon server to generate the client from", "3000").action(main);
193
+ var start = Date.now();
120
194
  program.parse();
121
195
 
122
- //# debugId=3330F4B16D05BDA464756E2164756E21
123
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts"],
  "sourcesContent": [
    "#!/usr/bin/env node\n\nimport {build} from '@getcronit/pylon-builder'\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 kill from 'treekill'\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    consola.start('[Pylon]: Building schema')\n\n    await build({\n      sfiFilePath: './src/index.ts',\n      outputFilePath: './.pylon'\n    })\n\n    consola.success('[Pylon]: Schema built')\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\nasync function main(options: ArgOptions, command: Command) {\n  consola.log(`[Pylon]: ${command.name()} version ${command.version()}`)\n\n  let currentProc: ChildProcess | null = null\n\n  let serve = async (shouldGenerateClient: boolean = false) => {\n    if (currentProc) {\n      // Remove all listeners to prevent the pylon dev server from crashing\n      currentProc.removeAllListeners()\n\n      kill(currentProc.pid, 'SIGINT', err => {\n        if (err) {\n          consola.error(err)\n        }\n      })\n    }\n\n    await new Promise(resolve => setTimeout(resolve, 1000))\n\n    currentProc = spawn(options.command, {\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  consola.start('[Pylon]: Building schema')\n\n  await build({\n    sfiFilePath: './src/index.ts',\n    outputFilePath: `./.pylon`,\n    watch: true,\n    onWatch: async (schemaChanged: boolean) => {\n      await serve(schemaChanged)\n\n      consola.start('[Pylon]: Reloading server')\n\n      if (schemaChanged) {\n        consola.info('[Pylon]: Schema updated')\n      }\n    }\n  })\n\n  consola.success('[Pylon]: Schema built')\n\n  consola.start('[Pylon]: Starting server')\n  await serve(true)\n  consola.ready('[Pylon]: Server started')\n\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—help us make Pylon even better!\n  `)\n}\n\nprogram.parse()\n"
  ],
  "mappings": "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",
  "debugId": "3330F4B16D05BDA464756E2164756E21",
  "names": []
}
196
+ //# debugId=92B45C428EBD8DB164756E2164756E21
197
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts"],
  "sourcesContent": [
    "#!/usr/bin/env node\n\nimport {build} from '@getcronit/pylon-builder'\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 kill from 'treekill'\nimport * as telemetry from '@getcronit/pylon-telemetry'\nimport dotenv from 'dotenv'\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    consola.start('[Pylon]: Building schema')\n\n    const {totalFiles, totalSize, duration} = await build({\n      sfiFilePath: './src/index.ts',\n      outputFilePath: './.pylon'\n    })\n\n    await telemetry.sendBuildEvent({\n      duration: duration,\n      totalFiles,\n      totalSize,\n      isDevelopment: false\n    })\n\n    consola.success('[Pylon]: Schema built')\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  let currentProc: ChildProcess | null = null\n\n  let serve = async (shouldGenerateClient: boolean = false) => {\n    if (currentProc) {\n      // Remove all listeners to prevent the pylon dev server from crashing\n      currentProc.removeAllListeners()\n\n      kill(currentProc.pid, 'SIGINT', err => {\n        if (err) {\n          consola.error(err)\n        }\n      })\n    }\n\n    currentProc = spawn(options.command, {\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  consola.start('[Pylon]: Building schema')\n\n  try {\n    const {duration, totalFiles, totalSize} = await build({\n      sfiFilePath: './src/index.ts',\n      outputFilePath: `./.pylon`,\n      watch: true,\n      onWatch: 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.ready('[Pylon]: Server started')\n\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—help us make Pylon even better!\n          `)\n        }\n\n        if (schemaChanged) {\n          consola.info('[Pylon]: Schema updated')\n\n          await telemetry.sendBuildEvent({\n            duration,\n            totalFiles,\n            totalSize,\n            isDevelopment: true\n          })\n        }\n      }\n    })\n\n    await telemetry.sendBuildEvent({\n      duration,\n      totalFiles,\n      totalSize,\n      isDevelopment: true\n    })\n\n    consola.success('[Pylon]: Schema built')\n\n    consola.start('[Pylon]: Starting server')\n    await serve(true)\n    consola.ready('[Pylon]: Server started')\n\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—help us make Pylon even better!\n  `)\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) {\n      proc.removeAllListeners()\n\n      kill(proc.pid, 'SIGINT', err => {\n        if (err) {\n          consola.error(err)\n        }\n      })\n    }\n  }\n\n  process.on('SIGINT', async code => {\n    try {\n      if (currentProc) {\n        currentProc.removeAllListeners()\n\n        kill(currentProc.pid, 'SIGINT', err => {\n          if (err) {\n            consola.error(err)\n          }\n        })\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"
  ],
  "mappings": "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",
  "debugId": "92B45C428EBD8DB164756E2164756E21",
  "names": []
}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@getcronit/pylon-dev",
3
3
  "type": "module",
4
- "version": "1.0.0-beta.1",
4
+ "version": "1.0.0-beta.10",
5
5
  "description": "CLI for creating a Pylon",
6
6
  "scripts": {
7
7
  "build": "bun build ./src/index.ts --target=bun --outdir=./dist --sourcemap=inline --packages external"
@@ -21,13 +21,18 @@
21
21
  },
22
22
  "homepage": "https://pylon.cronit.io",
23
23
  "dependencies": {
24
- "@getcronit/pylon-builder": "*",
24
+ "@getcronit/pylon-builder": "^2.0.0",
25
+ "@getcronit/pylon-telemetry": "^1.0.0",
25
26
  "@gqty/cli": "^4.2.0",
26
27
  "commander": "^12.1.0",
27
28
  "consola": "^3.2.3",
29
+ "dotenv": "^16.4.5",
28
30
  "treekill": "^1.0.0"
29
31
  },
30
32
  "publishConfig": {
31
33
  "access": "public"
34
+ },
35
+ "engines": {
36
+ "node": ">=18.0.0"
32
37
  }
33
38
  }