create-pylon 1.0.2 → 1.0.4
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 +156 -156
- package/package.json +1 -1
- package/templates/bun/default/package.json +1 -1
- package/templates/bun/default/tsconfig.json +2 -1
- package/templates/cf-workers/default/package.json +1 -1
- package/templates/cf-workers/default/tsconfig.json +1 -1
- package/templates/node/default/package.json +1 -1
- package/templates/shared/pylon.d.ts +7 -0
- package/templates/shared/tsconfig.json +2 -1
package/dist/index.js
CHANGED
|
@@ -11,6 +11,13 @@ import * as fs from "fs";
|
|
|
11
11
|
import * as telemetry from "@getcronit/pylon-telemetry";
|
|
12
12
|
import { fileURLToPath } from "url";
|
|
13
13
|
import { dirname } from "path";
|
|
14
|
+
import { detect } from "detect-package-manager";
|
|
15
|
+
import { spawnSync } from "child_process";
|
|
16
|
+
var __filename2 = fileURLToPath(import.meta.url);
|
|
17
|
+
var __dirname2 = dirname(__filename2);
|
|
18
|
+
var version = (() => {
|
|
19
|
+
return JSON.parse(fs.readFileSync(path.join(__dirname2, "..", "package.json"), "utf-8")).version;
|
|
20
|
+
})();
|
|
14
21
|
function mkdirp(dir) {
|
|
15
22
|
try {
|
|
16
23
|
fs.mkdirSync(dir, { recursive: true });
|
|
@@ -22,160 +29,6 @@ function mkdirp(dir) {
|
|
|
22
29
|
throw e;
|
|
23
30
|
}
|
|
24
31
|
}
|
|
25
|
-
import { detect } from "detect-package-manager";
|
|
26
|
-
import { spawnSync } from "child_process";
|
|
27
|
-
async function main(targetDir, options, command) {
|
|
28
|
-
try {
|
|
29
|
-
consola.log(`${command.name()} version ${command.version()}`);
|
|
30
|
-
const {
|
|
31
|
-
install: installArg,
|
|
32
|
-
runtime: runtimeArg,
|
|
33
|
-
template: templateArg,
|
|
34
|
-
packageManager: packageManagerArg,
|
|
35
|
-
client: clientArg,
|
|
36
|
-
clientPath: clientPathArg,
|
|
37
|
-
clientPort: clientPortArg
|
|
38
|
-
} = options;
|
|
39
|
-
let target = "";
|
|
40
|
-
if (targetDir) {
|
|
41
|
-
target = targetDir;
|
|
42
|
-
consola.success(`Using target directory \u2026 ${target}`);
|
|
43
|
-
} else {
|
|
44
|
-
const answer = await input({
|
|
45
|
-
message: "Target directory",
|
|
46
|
-
default: "my-pylon"
|
|
47
|
-
});
|
|
48
|
-
target = answer;
|
|
49
|
-
}
|
|
50
|
-
let projectName = "";
|
|
51
|
-
if (target === ".") {
|
|
52
|
-
projectName = path.basename(process.cwd());
|
|
53
|
-
} else {
|
|
54
|
-
projectName = path.basename(target);
|
|
55
|
-
}
|
|
56
|
-
const runtimeName = runtimeArg || await select({
|
|
57
|
-
message: "Which runtime would you like to use?",
|
|
58
|
-
choices: runtimes.map((runtime2) => ({
|
|
59
|
-
name: `${runtime2.name} (${runtime2.website})`,
|
|
60
|
-
value: runtime2.key
|
|
61
|
-
})),
|
|
62
|
-
default: 0
|
|
63
|
-
});
|
|
64
|
-
if (!runtimeName) {
|
|
65
|
-
throw new Error("No runtime selected");
|
|
66
|
-
}
|
|
67
|
-
const runtime = runtimes.find(({ key }) => key === runtimeName);
|
|
68
|
-
if (!runtime) {
|
|
69
|
-
throw new Error(`Invalid runtime selected: ${runtimeName}`);
|
|
70
|
-
}
|
|
71
|
-
const templateName = templateArg || await select({
|
|
72
|
-
message: "Which template would you like to use?",
|
|
73
|
-
choices: templates.filter((template) => runtime.templates?.includes(template.key)).map((template) => ({
|
|
74
|
-
name: template.name,
|
|
75
|
-
value: template.key
|
|
76
|
-
})),
|
|
77
|
-
default: 0
|
|
78
|
-
});
|
|
79
|
-
if (!templateName) {
|
|
80
|
-
throw new Error("No template selected");
|
|
81
|
-
}
|
|
82
|
-
if (fs.existsSync(target)) {
|
|
83
|
-
if (fs.readdirSync(target).length > 0) {
|
|
84
|
-
const response = await confirm({
|
|
85
|
-
message: "Directory not empty. Continue?",
|
|
86
|
-
default: false
|
|
87
|
-
});
|
|
88
|
-
if (!response) {
|
|
89
|
-
process.exit(1);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
} else {
|
|
93
|
-
mkdirp(target);
|
|
94
|
-
}
|
|
95
|
-
const install = installArg || await confirm({ message: "Would you like to install dependencies?" });
|
|
96
|
-
await createTemplate({
|
|
97
|
-
name: projectName,
|
|
98
|
-
runtime: runtimeName,
|
|
99
|
-
template: templateName,
|
|
100
|
-
target
|
|
101
|
-
});
|
|
102
|
-
let packageManager = packageManagerArg;
|
|
103
|
-
if (runtimeName === "bun" && !packageManager) {
|
|
104
|
-
packageManager = "bun";
|
|
105
|
-
}
|
|
106
|
-
if (install) {
|
|
107
|
-
await installDependencies({ target, packageManager });
|
|
108
|
-
}
|
|
109
|
-
const client = clientArg || await confirm({
|
|
110
|
-
message: "Would you like to enable client generation? (https://pylon.cronit.io/docs/integrations/gqty)",
|
|
111
|
-
default: false
|
|
112
|
-
});
|
|
113
|
-
let clientRoot = "";
|
|
114
|
-
let clientPath = "";
|
|
115
|
-
let clientPort = "";
|
|
116
|
-
if (client) {
|
|
117
|
-
if (!clientPathArg) {
|
|
118
|
-
clientRoot = await input({
|
|
119
|
-
message: "Path to the root where the client should be generated",
|
|
120
|
-
default: "."
|
|
121
|
-
});
|
|
122
|
-
clientPath = await input({
|
|
123
|
-
message: "Path to generate the client to",
|
|
124
|
-
default: path.join(clientRoot, "gqty/index.ts"),
|
|
125
|
-
validate: (value) => {
|
|
126
|
-
if (!value.startsWith(clientRoot === "." ? "" : clientRoot)) {
|
|
127
|
-
return "Path must start with the client root";
|
|
128
|
-
}
|
|
129
|
-
return true;
|
|
130
|
-
}
|
|
131
|
-
});
|
|
132
|
-
}
|
|
133
|
-
clientPort = clientPortArg || await input({
|
|
134
|
-
message: "Port of the pylon server to generate the client from",
|
|
135
|
-
default: "3000"
|
|
136
|
-
});
|
|
137
|
-
consola.start(`Updating pylon dev script to generate client`);
|
|
138
|
-
const devScriptPath = path.join(target, "package.json");
|
|
139
|
-
const devScript = JSON.parse(fs.readFileSync(devScriptPath, "utf-8"));
|
|
140
|
-
devScript.scripts = {
|
|
141
|
-
...devScript.scripts,
|
|
142
|
-
dev: devScript.scripts.dev + ` --client --client-port ${clientPort} --client-path ${clientPath}`
|
|
143
|
-
};
|
|
144
|
-
fs.writeFileSync(devScriptPath, JSON.stringify(devScript, null, 2));
|
|
145
|
-
consola.success(`Pylon dev script updated`);
|
|
146
|
-
}
|
|
147
|
-
const message = `
|
|
148
|
-
\uD83C\uDF89 ${chalk.green.bold("Pylon created successfully.")}
|
|
149
|
-
|
|
150
|
-
\uD83D\uDCBB ${chalk.cyan.bold("Continue Developing")}
|
|
151
|
-
${chalk.yellow("Change directories:")} cd ${chalk.blue(target)}
|
|
152
|
-
${chalk.yellow("Start dev server:")} npm run start
|
|
153
|
-
${chalk.yellow("Deploy:")} npm run deploy
|
|
154
|
-
|
|
155
|
-
\uD83D\uDCD6 ${chalk.cyan.bold("Explore Documentation")}
|
|
156
|
-
${chalk.underline.blue("https://pylon.cronit.io/docs")}
|
|
157
|
-
|
|
158
|
-
\uD83D\uDCAC ${chalk.cyan.bold("Join our Community")}
|
|
159
|
-
${chalk.underline.blue("https://discord.gg/cbJjkVrnHe")}
|
|
160
|
-
`;
|
|
161
|
-
await telemetry.sendCreateEvent({
|
|
162
|
-
name: projectName,
|
|
163
|
-
pylonCreateVersion: version,
|
|
164
|
-
runtime: runtimeName,
|
|
165
|
-
template: templateName,
|
|
166
|
-
clientPath: clientPath || undefined,
|
|
167
|
-
clientPort: parseInt(clientPort) || undefined
|
|
168
|
-
});
|
|
169
|
-
consola.box(message);
|
|
170
|
-
} catch (e) {
|
|
171
|
-
consola.error(e);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
var __filename2 = fileURLToPath(import.meta.url);
|
|
175
|
-
var __dirname2 = dirname(__filename2);
|
|
176
|
-
var version = (() => {
|
|
177
|
-
return JSON.parse(fs.readFileSync(path.join(__dirname2, "..", "package.json"), "utf-8")).version;
|
|
178
|
-
})();
|
|
179
32
|
var runtimes = [
|
|
180
33
|
{
|
|
181
34
|
key: "bun",
|
|
@@ -332,7 +185,154 @@ var installDependencies = async (args) => {
|
|
|
332
185
|
consola.success(`Dependencies installed`);
|
|
333
186
|
};
|
|
334
187
|
program.name("create-pylon").version(version).arguments("[target]").addOption(new Option("-i, --install", "Install dependencies")).addOption(new Option("-r, --runtime <runtime>", "Runtime").choices(runtimes.map(({ key }) => key))).addOption(new Option("-t, --template <template>", "Template")).addOption(new Option("-pm, --package-manager <packageManager>", "Package manager")).addOption(new Option("--client", "Enable client generation (https://pylon.cronit.io/docs/integrations/gqty)")).addOption(new Option("--client-path <clientPath>", "Client path")).addOption(new Option("--client-port <clientPort>", "Client port")).action(main);
|
|
188
|
+
async function main(targetDir, options, command) {
|
|
189
|
+
try {
|
|
190
|
+
consola.log(`${command.name()} version ${command.version()}`);
|
|
191
|
+
const {
|
|
192
|
+
install: installArg,
|
|
193
|
+
runtime: runtimeArg,
|
|
194
|
+
template: templateArg,
|
|
195
|
+
packageManager: packageManagerArg,
|
|
196
|
+
client: clientArg,
|
|
197
|
+
clientPath: clientPathArg,
|
|
198
|
+
clientPort: clientPortArg
|
|
199
|
+
} = options;
|
|
200
|
+
let target = "";
|
|
201
|
+
if (targetDir) {
|
|
202
|
+
target = targetDir;
|
|
203
|
+
consola.success(`Using target directory \u2026 ${target}`);
|
|
204
|
+
} else {
|
|
205
|
+
const answer = await input({
|
|
206
|
+
message: "Target directory",
|
|
207
|
+
default: "my-pylon"
|
|
208
|
+
});
|
|
209
|
+
target = answer;
|
|
210
|
+
}
|
|
211
|
+
let projectName = "";
|
|
212
|
+
if (target === ".") {
|
|
213
|
+
projectName = path.basename(process.cwd());
|
|
214
|
+
} else {
|
|
215
|
+
projectName = path.basename(target);
|
|
216
|
+
}
|
|
217
|
+
const runtimeName = runtimeArg || await select({
|
|
218
|
+
message: "Which runtime would you like to use?",
|
|
219
|
+
choices: runtimes.map((runtime2) => ({
|
|
220
|
+
name: `${runtime2.name} (${runtime2.website})`,
|
|
221
|
+
value: runtime2.key
|
|
222
|
+
})),
|
|
223
|
+
default: 0
|
|
224
|
+
});
|
|
225
|
+
if (!runtimeName) {
|
|
226
|
+
throw new Error("No runtime selected");
|
|
227
|
+
}
|
|
228
|
+
const runtime = runtimes.find(({ key }) => key === runtimeName);
|
|
229
|
+
if (!runtime) {
|
|
230
|
+
throw new Error(`Invalid runtime selected: ${runtimeName}`);
|
|
231
|
+
}
|
|
232
|
+
const templateName = templateArg || await select({
|
|
233
|
+
message: "Which template would you like to use?",
|
|
234
|
+
choices: templates.filter((template) => runtime.templates?.includes(template.key)).map((template) => ({
|
|
235
|
+
name: template.name,
|
|
236
|
+
value: template.key
|
|
237
|
+
})),
|
|
238
|
+
default: 0
|
|
239
|
+
});
|
|
240
|
+
if (!templateName) {
|
|
241
|
+
throw new Error("No template selected");
|
|
242
|
+
}
|
|
243
|
+
if (fs.existsSync(target)) {
|
|
244
|
+
if (fs.readdirSync(target).length > 0) {
|
|
245
|
+
const response = await confirm({
|
|
246
|
+
message: "Directory not empty. Continue?",
|
|
247
|
+
default: false
|
|
248
|
+
});
|
|
249
|
+
if (!response) {
|
|
250
|
+
process.exit(1);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
} else {
|
|
254
|
+
mkdirp(target);
|
|
255
|
+
}
|
|
256
|
+
const install = installArg || await confirm({ message: "Would you like to install dependencies?" });
|
|
257
|
+
await createTemplate({
|
|
258
|
+
name: projectName,
|
|
259
|
+
runtime: runtimeName,
|
|
260
|
+
template: templateName,
|
|
261
|
+
target
|
|
262
|
+
});
|
|
263
|
+
let packageManager = packageManagerArg;
|
|
264
|
+
if (runtimeName === "bun" && !packageManager) {
|
|
265
|
+
packageManager = "bun";
|
|
266
|
+
}
|
|
267
|
+
if (install) {
|
|
268
|
+
await installDependencies({ target, packageManager });
|
|
269
|
+
}
|
|
270
|
+
const client = clientArg || await confirm({
|
|
271
|
+
message: "Would you like to enable client generation? (https://pylon.cronit.io/docs/integrations/gqty)",
|
|
272
|
+
default: false
|
|
273
|
+
});
|
|
274
|
+
let clientRoot = "";
|
|
275
|
+
let clientPath = "";
|
|
276
|
+
let clientPort = "";
|
|
277
|
+
if (client) {
|
|
278
|
+
if (!clientPathArg) {
|
|
279
|
+
clientRoot = await input({
|
|
280
|
+
message: "Path to the root where the client should be generated",
|
|
281
|
+
default: "."
|
|
282
|
+
});
|
|
283
|
+
clientPath = await input({
|
|
284
|
+
message: "Path to generate the client to",
|
|
285
|
+
default: path.join(clientRoot, "gqty/index.ts"),
|
|
286
|
+
validate: (value) => {
|
|
287
|
+
if (!value.startsWith(clientRoot === "." ? "" : clientRoot)) {
|
|
288
|
+
return "Path must start with the client root";
|
|
289
|
+
}
|
|
290
|
+
return true;
|
|
291
|
+
}
|
|
292
|
+
});
|
|
293
|
+
}
|
|
294
|
+
clientPort = clientPortArg || await input({
|
|
295
|
+
message: "Port of the pylon server to generate the client from",
|
|
296
|
+
default: "3000"
|
|
297
|
+
});
|
|
298
|
+
consola.start(`Updating pylon dev script to generate client`);
|
|
299
|
+
const devScriptPath = path.join(target, "package.json");
|
|
300
|
+
const devScript = JSON.parse(fs.readFileSync(devScriptPath, "utf-8"));
|
|
301
|
+
devScript.scripts = {
|
|
302
|
+
...devScript.scripts,
|
|
303
|
+
dev: devScript.scripts.dev + ` --client --client-port ${clientPort} --client-path ${clientPath}`
|
|
304
|
+
};
|
|
305
|
+
fs.writeFileSync(devScriptPath, JSON.stringify(devScript, null, 2));
|
|
306
|
+
consola.success(`Pylon dev script updated`);
|
|
307
|
+
}
|
|
308
|
+
const message = `
|
|
309
|
+
\uD83C\uDF89 ${chalk.green.bold("Pylon created successfully.")}
|
|
310
|
+
|
|
311
|
+
\uD83D\uDCBB ${chalk.cyan.bold("Continue Developing")}
|
|
312
|
+
${chalk.yellow("Change directories:")} cd ${chalk.blue(target)}
|
|
313
|
+
${chalk.yellow("Start dev server:")} npm run start
|
|
314
|
+
${chalk.yellow("Deploy:")} npm run deploy
|
|
315
|
+
|
|
316
|
+
\uD83D\uDCD6 ${chalk.cyan.bold("Explore Documentation")}
|
|
317
|
+
${chalk.underline.blue("https://pylon.cronit.io/docs")}
|
|
318
|
+
|
|
319
|
+
\uD83D\uDCAC ${chalk.cyan.bold("Join our Community")}
|
|
320
|
+
${chalk.underline.blue("https://discord.gg/cbJjkVrnHe")}
|
|
321
|
+
`;
|
|
322
|
+
await telemetry.sendCreateEvent({
|
|
323
|
+
name: projectName,
|
|
324
|
+
pylonCreateVersion: version,
|
|
325
|
+
runtime: runtimeName,
|
|
326
|
+
template: templateName,
|
|
327
|
+
clientPath: clientPath || undefined,
|
|
328
|
+
clientPort: parseInt(clientPort) || undefined
|
|
329
|
+
});
|
|
330
|
+
consola.box(message);
|
|
331
|
+
} catch (e) {
|
|
332
|
+
consola.error(e);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
335
|
program.parse();
|
|
336
336
|
|
|
337
|
-
//# debugId=
|
|
338
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts"],
  "sourcesContent": [
    "#!/usr/bin/env node\n\nimport {Option, program, type Command} from 'commander'\nimport consola from 'consola'\nimport {input, select, confirm} from '@inquirer/prompts'\nimport path from 'path'\nimport chalk from 'chalk'\nimport * as fs from 'fs'\n\nimport * as telemetry from '@getcronit/pylon-telemetry'\n\nimport {fileURLToPath} from 'url'\nimport {dirname} from 'path'\n\nconst __filename = fileURLToPath(import.meta.url)\nconst __dirname = dirname(__filename)\n\nconst version = (() => {\n  return JSON.parse(\n    fs.readFileSync(path.join(__dirname, '..', 'package.json'), 'utf-8')\n  ).version as string\n})()\n\nfunction mkdirp(dir: string) {\n  try {\n    fs.mkdirSync(dir, {recursive: true})\n  } catch (e) {\n    if (e instanceof Error) {\n      if ('code' in e && e.code === 'EEXIST') return\n    }\n    throw e\n  }\n}\n\nconst runtimes: {\n  key: string\n  name: string\n  website: string\n  templates?: string[]\n}[] = [\n  {\n    key: 'bun',\n    name: 'Bun.js',\n    website: 'https://bunjs.dev',\n    templates: ['default']\n  },\n  {\n    key: 'node',\n    name: 'Node.js',\n    website: 'https://nodejs.org',\n    templates: ['default']\n  },\n  {\n    key: 'cf-workers',\n    name: 'Cloudflare Workers',\n    website: 'https://workers.cloudflare.com',\n    templates: ['default']\n  }\n]\n\nconst templates: {\n  key: string\n  name: string\n  description: string\n}[] = [\n  {\n    key: 'default',\n    name: 'Default',\n    description: 'Default template'\n  },\n  {\n    key: 'database',\n    name: 'Database (Prisma)',\n    description: 'Template with Prisma ORM'\n  }\n]\n\nconst injectVariablesInContent = (\n  content: string,\n  variables: Record<string, string>\n) => {\n  let result = content\n\n  Object.entries(variables).forEach(([key, value]) => {\n    result = result.replaceAll(key, value)\n  })\n\n  return result\n}\nconst readdirFilesSyncRecursive = (dir: string): string[] => {\n  const run = (dir: string): string[] => {\n    const result: string[] = []\n\n    const files = fs.readdirSync(dir)\n\n    files.forEach(file => {\n      const filePath = path.join(dir, file)\n\n      if (fs.statSync(filePath).isDirectory()) {\n        result.push(...run(filePath))\n      }\n\n      // Only add files\n      if (fs.statSync(filePath).isFile()) {\n        result.push(filePath)\n      }\n    })\n\n    return result\n  }\n\n  return run(dir).map(file => {\n    return file.replace(dir, '.')\n  })\n}\n\nconst createTemplate = async (options: {\n  name: string\n  runtime: string\n  template: string\n  target: string\n}) => {\n  const {runtime, template, target} = options\n\n  const runtimeName = runtimes.find(({key}) => key === runtime)?.name\n  const templateName = templates.find(({key}) => key === template)?.name\n\n  if (!runtimeName) {\n    throw new Error(`Invalid runtime: ${runtime}`)\n  }\n\n  if (!templateName) {\n    throw new Error(`Invalid template: ${template}`)\n  }\n\n  // The templates are stored in the `templates` directory\n  const sharedTemplateDir = path.join(__dirname, '..', 'templates', 'shared')\n\n  if (!fs.existsSync(sharedTemplateDir)) {\n    throw new Error(`Shared templates not found: ${sharedTemplateDir}`)\n  }\n\n  const templateDir = path.join(__dirname, '..', 'templates', runtime, template)\n\n  if (!fs.existsSync(templateDir)) {\n    throw new Error(`Template not found: ${templateDir}`)\n  }\n\n  // The target directory is already created\n  const targetDirectoryPath = path.join(process.cwd(), target)\n\n  consola.start(`Creating pylon in ${targetDirectoryPath}`)\n\n  const inject = (content: string) => {\n    return injectVariablesInContent(content, {\n      __PYLON_NAME__: options.name\n    })\n  }\n\n  // Copy the shared template files\n  readdirFilesSyncRecursive(sharedTemplateDir).forEach(file => {\n    const source = path.join(sharedTemplateDir, file)\n    let target = path.join(targetDirectoryPath, file)\n\n    // Create folder recursively and copy file\n\n    const targetDir = path.dirname(target)\n\n    // Skip the .github/workflows directory for cf-workers runtime\n    if (\n      runtime === 'cf-workers' &&\n      source.includes('.github/workflows/publish.yaml')\n    ) {\n      return\n    }\n\n    if (!fs.existsSync(targetDir)) {\n      fs.mkdirSync(targetDir, {recursive: true})\n    }\n\n    // If the target ends with `.example`, remove the suffix.\n    // This is useful for `.gitignore.example` files because they are not published in\n    // the `create-pylon` package when named `.gitignore`.\n    if (target.endsWith('.example')) {\n      target = target.replace('.example', '')\n    }\n\n    const injectedContent = inject(fs.readFileSync(source, 'utf-8'))\n\n    fs.writeFileSync(target, injectedContent)\n  })\n\n  // Copy the runtime specific template files\n  readdirFilesSyncRecursive(templateDir).forEach(file => {\n    const source = path.join(templateDir, file)\n    let target = path.join(targetDirectoryPath, file)\n\n    // Create folder recursively and copy file\n    const targetDir = path.dirname(target)\n\n    if (!fs.existsSync(targetDir)) {\n      fs.mkdirSync(targetDir, {recursive: true})\n    }\n\n    // If the target ends with `.example`, remove the suffix.\n    // This is useful for `.gitignore.example` files because they are not published in\n    // the `create-pylon` package when named `.gitignore`.\n    if (target.endsWith('.example')) {\n      target = target.replace('.example', '')\n    }\n\n    const injectedContent = inject(fs.readFileSync(source, 'utf-8'))\n\n    fs.writeFileSync(target, injectedContent)\n  })\n\n  consola.success(`Pylon created`)\n}\n\nimport {detect} from 'detect-package-manager'\nimport {spawnSync} from 'child_process'\n\nconst installDependencies = async (args: {\n  target: string\n  packageManager?: string\n}) => {\n  const target = path.resolve(args.target)\n\n  console.log('target', target)\n\n  if (!args.packageManager) {\n    args.packageManager = await detect({\n      cwd: target,\n      includeGlobalBun: true\n    })\n  }\n\n  if (!args.packageManager) {\n    throw new Error('No package manager found')\n  }\n\n  // yarn', 'npm', or 'pnpm', 'bun'\n  const {packageManager} = args\n\n  let command = ''\n\n  switch (packageManager) {\n    case 'yarn':\n      command = 'yarn'\n      break\n    case 'npm':\n      command = 'npm install'\n      break\n    case 'pnpm':\n      command = 'pnpm install'\n      break\n    case 'bun':\n      command = 'bun install'\n      break\n    default:\n      throw new Error(`Invalid package manager: ${packageManager}`)\n  }\n\n  consola.start(`Installing dependencies using ${packageManager}`)\n\n  const proc = spawnSync(command, {\n    cwd: target,\n    shell: true,\n    stdio: 'inherit'\n  })\n\n  if (proc.status !== 0) {\n    throw new Error(`Failed to install dependencies`)\n  }\n\n  consola.success(`Dependencies installed`)\n}\n\nprogram\n  .name('create-pylon')\n  .version(version)\n  .arguments('[target]')\n  .addOption(new Option('-i, --install', 'Install dependencies'))\n  .addOption(\n    new Option('-r, --runtime <runtime>', 'Runtime').choices(\n      runtimes.map(({key}) => key)\n    )\n  )\n  .addOption(new Option('-t, --template <template>', 'Template'))\n  .addOption(\n    new Option('-pm, --package-manager <packageManager>', 'Package manager')\n  )\n  .addOption(\n    new Option(\n      '--client',\n      'Enable client generation (https://pylon.cronit.io/docs/integrations/gqty)'\n    )\n  )\n  .addOption(new Option('--client-path <clientPath>', 'Client path'))\n  .addOption(new Option('--client-port <clientPort>', 'Client port'))\n  .action(main)\n\ntype ArgOptions = {\n  install: boolean\n  runtime: string\n  template: string\n  packageManager?: string\n  client?: boolean\n  clientPath?: string\n  clientPort?: string\n}\n\nasync function main(\n  targetDir: string | undefined,\n  options: ArgOptions,\n  command: Command\n) {\n  try {\n    consola.log(`${command.name()} version ${command.version()}`)\n\n    const {\n      install: installArg,\n      runtime: runtimeArg,\n      template: templateArg,\n      packageManager: packageManagerArg,\n      client: clientArg,\n      clientPath: clientPathArg,\n      clientPort: clientPortArg\n    } = options\n\n    let target = ''\n\n    if (targetDir) {\n      target = targetDir\n\n      consola.success(`Using target directory … ${target}`)\n    } else {\n      const answer = await input({\n        message: 'Target directory',\n        default: 'my-pylon'\n      })\n      target = answer\n    }\n\n    let projectName = ''\n\n    if (target === '.') {\n      projectName = path.basename(process.cwd())\n    } else {\n      projectName = path.basename(target)\n    }\n\n    const runtimeName =\n      runtimeArg ||\n      (await select({\n        message: 'Which runtime would you like to use?',\n        choices: runtimes.map(runtime => ({\n          name: `${runtime.name} (${runtime.website})`,\n          value: runtime.key\n        })),\n        default: 0\n      }))\n\n    if (!runtimeName) {\n      throw new Error('No runtime selected')\n    }\n\n    const runtime = runtimes.find(({key}) => key === runtimeName)\n\n    if (!runtime) {\n      throw new Error(`Invalid runtime selected: ${runtimeName}`)\n    }\n\n    const templateName =\n      templateArg ||\n      (await select({\n        message: 'Which template would you like to use?',\n        choices: templates\n          .filter(template => runtime.templates?.includes(template.key))\n          .map(template => ({\n            name: template.name,\n            value: template.key\n          })),\n        default: 0\n      }))\n\n    if (!templateName) {\n      throw new Error('No template selected')\n    }\n\n    if (fs.existsSync(target)) {\n      if (fs.readdirSync(target).length > 0) {\n        const response = await confirm({\n          message: 'Directory not empty. Continue?',\n          default: false\n        })\n        if (!response) {\n          process.exit(1)\n        }\n      }\n    } else {\n      mkdirp(target)\n    }\n\n    const install =\n      installArg ||\n      (await confirm({message: 'Would you like to install dependencies?'}))\n\n    await createTemplate({\n      name: projectName,\n      runtime: runtimeName,\n      template: templateName,\n      target\n    })\n\n    let packageManager = packageManagerArg\n\n    if (runtimeName === 'bun' && !packageManager) {\n      packageManager = 'bun'\n    }\n\n    if (install) {\n      await installDependencies({target, packageManager})\n    }\n\n    const client =\n      clientArg ||\n      (await confirm({\n        message:\n          'Would you like to enable client generation? (https://pylon.cronit.io/docs/integrations/gqty)',\n        default: false\n      }))\n\n    let clientRoot: string = ''\n    let clientPath: string = ''\n    let clientPort: string = ''\n\n    if (client) {\n      if (!clientPathArg) {\n        clientRoot = await input({\n          message: 'Path to the root where the client should be generated',\n          default: '.'\n        })\n\n        clientPath = await input({\n          message: 'Path to generate the client to',\n          default: path.join(clientRoot, 'gqty/index.ts'),\n          validate: value => {\n            // Check if the path starts with the client root (take care of .)\n            if (!value.startsWith(clientRoot === '.' ? '' : clientRoot)) {\n              return 'Path must start with the client root'\n            }\n\n            return true\n          }\n        })\n      }\n\n      clientPort =\n        clientPortArg ||\n        (await input({\n          message: 'Port of the pylon server to generate the client from',\n          default: '3000'\n        }))\n\n      consola.start(`Updating pylon dev script to generate client`)\n\n      const devScriptPath = path.join(target, 'package.json')\n\n      const devScript = JSON.parse(fs.readFileSync(devScriptPath, 'utf-8'))\n\n      devScript.scripts = {\n        ...devScript.scripts,\n        dev:\n          devScript.scripts.dev +\n          ` --client --client-port ${clientPort} --client-path ${clientPath}`\n      }\n\n      fs.writeFileSync(devScriptPath, JSON.stringify(devScript, null, 2))\n\n      consola.success(`Pylon dev script updated`)\n    }\n\n    const message = `\n🎉 ${chalk.green.bold('Pylon created successfully.')}\n\n💻 ${chalk.cyan.bold('Continue Developing')}\n    ${chalk.yellow('Change directories:')} cd ${chalk.blue(target)}\n    ${chalk.yellow('Start dev server:')} npm run start\n    ${chalk.yellow('Deploy:')} npm run deploy\n\n📖 ${chalk.cyan.bold('Explore Documentation')}\n    ${chalk.underline.blue('https://pylon.cronit.io/docs')}\n\n💬 ${chalk.cyan.bold('Join our Community')}\n    ${chalk.underline.blue('https://discord.gg/cbJjkVrnHe')}\n`\n\n    await telemetry.sendCreateEvent({\n      name: projectName,\n      pylonCreateVersion: version,\n      runtime: runtimeName,\n      template: templateName,\n      clientPath: clientPath || undefined,\n      clientPort: parseInt(clientPort) || undefined\n    })\n\n    consola.box(message)\n  } catch (e) {\n    consola.error(e)\n  }\n}\n\nprogram.parse()\n"
  ],
  "mappings": "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",
  "debugId": "55AF547960838BB164756E2164756E21",
  "names": []
}
|
|
337
|
+
//# debugId=38EA1869FEC6A23F64756E2164756E21
|
|
338
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts"],
  "sourcesContent": [
    "#!/usr/bin/env node\n\nimport {Option, program, type Command} from 'commander'\nimport consola from 'consola'\nimport {input, select, confirm} from '@inquirer/prompts'\nimport path from 'path'\nimport chalk from 'chalk'\nimport * as fs from 'fs'\n\nimport * as telemetry from '@getcronit/pylon-telemetry'\n\nimport {fileURLToPath} from 'url'\nimport {dirname} from 'path'\n\nconst __filename = fileURLToPath(import.meta.url)\nconst __dirname = dirname(__filename)\n\nconst version = (() => {\n  return JSON.parse(\n    fs.readFileSync(path.join(__dirname, '..', 'package.json'), 'utf-8')\n  ).version as string\n})()\n\nfunction mkdirp(dir: string) {\n  try {\n    fs.mkdirSync(dir, {recursive: true})\n  } catch (e) {\n    if (e instanceof Error) {\n      if ('code' in e && e.code === 'EEXIST') return\n    }\n    throw e\n  }\n}\n\nconst runtimes: {\n  key: string\n  name: string\n  website: string\n  templates?: string[]\n}[] = [\n  {\n    key: 'bun',\n    name: 'Bun.js',\n    website: 'https://bunjs.dev',\n    templates: ['default']\n  },\n  {\n    key: 'node',\n    name: 'Node.js',\n    website: 'https://nodejs.org',\n    templates: ['default']\n  },\n  {\n    key: 'cf-workers',\n    name: 'Cloudflare Workers',\n    website: 'https://workers.cloudflare.com',\n    templates: ['default']\n  }\n]\n\nconst templates: {\n  key: string\n  name: string\n  description: string\n}[] = [\n  {\n    key: 'default',\n    name: 'Default',\n    description: 'Default template'\n  },\n  {\n    key: 'database',\n    name: 'Database (Prisma)',\n    description: 'Template with Prisma ORM'\n  }\n]\n\nconst injectVariablesInContent = (\n  content: string,\n  variables: Record<string, string>\n) => {\n  let result = content\n\n  Object.entries(variables).forEach(([key, value]) => {\n    result = result.replaceAll(key, value)\n  })\n\n  return result\n}\nconst readdirFilesSyncRecursive = (dir: string): string[] => {\n  const run = (dir: string): string[] => {\n    const result: string[] = []\n\n    const files = fs.readdirSync(dir)\n\n    files.forEach(file => {\n      const filePath = path.join(dir, file)\n\n      if (fs.statSync(filePath).isDirectory()) {\n        result.push(...run(filePath))\n      }\n\n      // Only add files\n      if (fs.statSync(filePath).isFile()) {\n        result.push(filePath)\n      }\n    })\n\n    return result\n  }\n\n  return run(dir).map(file => {\n    return file.replace(dir, '.')\n  })\n}\n\nconst createTemplate = async (options: {\n  name: string\n  runtime: string\n  template: string\n  target: string\n}) => {\n  const {runtime, template, target} = options\n\n  const runtimeName = runtimes.find(({key}) => key === runtime)?.name\n  const templateName = templates.find(({key}) => key === template)?.name\n\n  if (!runtimeName) {\n    throw new Error(`Invalid runtime: ${runtime}`)\n  }\n\n  if (!templateName) {\n    throw new Error(`Invalid template: ${template}`)\n  }\n\n  // The templates are stored in the `templates` directory\n  const sharedTemplateDir = path.join(__dirname, '..', 'templates', 'shared')\n\n  if (!fs.existsSync(sharedTemplateDir)) {\n    throw new Error(`Shared templates not found: ${sharedTemplateDir}`)\n  }\n\n  const templateDir = path.join(__dirname, '..', 'templates', runtime, template)\n\n  if (!fs.existsSync(templateDir)) {\n    throw new Error(`Template not found: ${templateDir}`)\n  }\n\n  // The target directory is already created\n  const targetDirectoryPath = path.join(process.cwd(), target)\n\n  consola.start(`Creating pylon in ${targetDirectoryPath}`)\n\n  const inject = (content: string) => {\n    return injectVariablesInContent(content, {\n      __PYLON_NAME__: options.name\n    })\n  }\n\n  // Copy the shared template files\n  readdirFilesSyncRecursive(sharedTemplateDir).forEach(file => {\n    const source = path.join(sharedTemplateDir, file)\n    let target = path.join(targetDirectoryPath, file)\n\n    // Create folder recursively and copy file\n\n    const targetDir = path.dirname(target)\n\n    // Skip the .github/workflows directory for cf-workers runtime\n    if (\n      runtime === 'cf-workers' &&\n      source.includes('.github/workflows/publish.yaml')\n    ) {\n      return\n    }\n\n    if (!fs.existsSync(targetDir)) {\n      fs.mkdirSync(targetDir, {recursive: true})\n    }\n\n    // If the target ends with `.example`, remove the suffix.\n    // This is useful for `.gitignore.example` files because they are not published in\n    // the `create-pylon` package when named `.gitignore`.\n    if (target.endsWith('.example')) {\n      target = target.replace('.example', '')\n    }\n\n    const injectedContent = inject(fs.readFileSync(source, 'utf-8'))\n\n    fs.writeFileSync(target, injectedContent)\n  })\n\n  // Copy the runtime specific template files\n  readdirFilesSyncRecursive(templateDir).forEach(file => {\n    const source = path.join(templateDir, file)\n    let target = path.join(targetDirectoryPath, file)\n\n    // Create folder recursively and copy file\n    const targetDir = path.dirname(target)\n\n    if (!fs.existsSync(targetDir)) {\n      fs.mkdirSync(targetDir, {recursive: true})\n    }\n\n    // If the target ends with `.example`, remove the suffix.\n    // This is useful for `.gitignore.example` files because they are not published in\n    // the `create-pylon` package when named `.gitignore`.\n    if (target.endsWith('.example')) {\n      target = target.replace('.example', '')\n    }\n\n    const injectedContent = inject(fs.readFileSync(source, 'utf-8'))\n\n    fs.writeFileSync(target, injectedContent)\n  })\n\n  consola.success(`Pylon created`)\n}\n\nimport {detect} from 'detect-package-manager'\nimport {spawnSync} from 'child_process'\n\nconst installDependencies = async (args: {\n  target: string\n  packageManager?: string\n}) => {\n  const target = path.resolve(args.target)\n\n  console.log('target', target)\n\n  if (!args.packageManager) {\n    args.packageManager = await detect({\n      cwd: target,\n      includeGlobalBun: true\n    })\n  }\n\n  if (!args.packageManager) {\n    throw new Error('No package manager found')\n  }\n\n  // yarn', 'npm', or 'pnpm', 'bun'\n  const {packageManager} = args\n\n  let command = ''\n\n  switch (packageManager) {\n    case 'yarn':\n      command = 'yarn'\n      break\n    case 'npm':\n      command = 'npm install'\n      break\n    case 'pnpm':\n      command = 'pnpm install'\n      break\n    case 'bun':\n      command = 'bun install'\n      break\n    default:\n      throw new Error(`Invalid package manager: ${packageManager}`)\n  }\n\n  consola.start(`Installing dependencies using ${packageManager}`)\n\n  const proc = spawnSync(command, {\n    cwd: target,\n    shell: true,\n    stdio: 'inherit'\n  })\n\n  if (proc.status !== 0) {\n    throw new Error(`Failed to install dependencies`)\n  }\n\n  consola.success(`Dependencies installed`)\n}\n\nprogram\n  .name('create-pylon')\n  .version(version)\n  .arguments('[target]')\n  .addOption(new Option('-i, --install', 'Install dependencies'))\n  .addOption(\n    new Option('-r, --runtime <runtime>', 'Runtime').choices(\n      runtimes.map(({key}) => key)\n    )\n  )\n  .addOption(new Option('-t, --template <template>', 'Template'))\n  .addOption(\n    new Option('-pm, --package-manager <packageManager>', 'Package manager')\n  )\n  .addOption(\n    new Option(\n      '--client',\n      'Enable client generation (https://pylon.cronit.io/docs/integrations/gqty)'\n    )\n  )\n  .addOption(new Option('--client-path <clientPath>', 'Client path'))\n  .addOption(new Option('--client-port <clientPort>', 'Client port'))\n  .action(main)\n\ntype ArgOptions = {\n  install: boolean\n  runtime: string\n  template: string\n  packageManager?: string\n  client?: boolean\n  clientPath?: string\n  clientPort?: string\n}\n\nasync function main(\n  targetDir: string | undefined,\n  options: ArgOptions,\n  command: Command\n) {\n  try {\n    consola.log(`${command.name()} version ${command.version()}`)\n\n    const {\n      install: installArg,\n      runtime: runtimeArg,\n      template: templateArg,\n      packageManager: packageManagerArg,\n      client: clientArg,\n      clientPath: clientPathArg,\n      clientPort: clientPortArg\n    } = options\n\n    let target = ''\n\n    if (targetDir) {\n      target = targetDir\n\n      consola.success(`Using target directory … ${target}`)\n    } else {\n      const answer = await input({\n        message: 'Target directory',\n        default: 'my-pylon'\n      })\n      target = answer\n    }\n\n    let projectName = ''\n\n    if (target === '.') {\n      projectName = path.basename(process.cwd())\n    } else {\n      projectName = path.basename(target)\n    }\n\n    const runtimeName =\n      runtimeArg ||\n      (await select({\n        message: 'Which runtime would you like to use?',\n        choices: runtimes.map(runtime => ({\n          name: `${runtime.name} (${runtime.website})`,\n          value: runtime.key\n        })),\n        default: 0\n      }))\n\n    if (!runtimeName) {\n      throw new Error('No runtime selected')\n    }\n\n    const runtime = runtimes.find(({key}) => key === runtimeName)\n\n    if (!runtime) {\n      throw new Error(`Invalid runtime selected: ${runtimeName}`)\n    }\n\n    const templateName =\n      templateArg ||\n      (await select({\n        message: 'Which template would you like to use?',\n        choices: templates\n          .filter(template => runtime.templates?.includes(template.key))\n          .map(template => ({\n            name: template.name,\n            value: template.key\n          })),\n        default: 0\n      }))\n\n    if (!templateName) {\n      throw new Error('No template selected')\n    }\n\n    if (fs.existsSync(target)) {\n      if (fs.readdirSync(target).length > 0) {\n        const response = await confirm({\n          message: 'Directory not empty. Continue?',\n          default: false\n        })\n        if (!response) {\n          process.exit(1)\n        }\n      }\n    } else {\n      mkdirp(target)\n    }\n\n    const install =\n      installArg ||\n      (await confirm({message: 'Would you like to install dependencies?'}))\n\n    await createTemplate({\n      name: projectName,\n      runtime: runtimeName,\n      template: templateName,\n      target\n    })\n\n    let packageManager = packageManagerArg\n\n    if (runtimeName === 'bun' && !packageManager) {\n      packageManager = 'bun'\n    }\n\n    if (install) {\n      await installDependencies({target, packageManager})\n    }\n\n    const client =\n      clientArg ||\n      (await confirm({\n        message:\n          'Would you like to enable client generation? (https://pylon.cronit.io/docs/integrations/gqty)',\n        default: false\n      }))\n\n    let clientRoot: string = ''\n    let clientPath: string = ''\n    let clientPort: string = ''\n\n    if (client) {\n      if (!clientPathArg) {\n        clientRoot = await input({\n          message: 'Path to the root where the client should be generated',\n          default: '.'\n        })\n\n        clientPath = await input({\n          message: 'Path to generate the client to',\n          default: path.join(clientRoot, 'gqty/index.ts'),\n          validate: value => {\n            // Check if the path starts with the client root (take care of .)\n            if (!value.startsWith(clientRoot === '.' ? '' : clientRoot)) {\n              return 'Path must start with the client root'\n            }\n\n            return true\n          }\n        })\n      }\n\n      clientPort =\n        clientPortArg ||\n        (await input({\n          message: 'Port of the pylon server to generate the client from',\n          default: '3000'\n        }))\n\n      consola.start(`Updating pylon dev script to generate client`)\n\n      const devScriptPath = path.join(target, 'package.json')\n\n      const devScript = JSON.parse(fs.readFileSync(devScriptPath, 'utf-8'))\n\n      devScript.scripts = {\n        ...devScript.scripts,\n        dev:\n          devScript.scripts.dev +\n          ` --client --client-port ${clientPort} --client-path ${clientPath}`\n      }\n\n      fs.writeFileSync(devScriptPath, JSON.stringify(devScript, null, 2))\n\n      consola.success(`Pylon dev script updated`)\n    }\n\n    const message = `\n🎉 ${chalk.green.bold('Pylon created successfully.')}\n\n💻 ${chalk.cyan.bold('Continue Developing')}\n    ${chalk.yellow('Change directories:')} cd ${chalk.blue(target)}\n    ${chalk.yellow('Start dev server:')} npm run start\n    ${chalk.yellow('Deploy:')} npm run deploy\n\n📖 ${chalk.cyan.bold('Explore Documentation')}\n    ${chalk.underline.blue('https://pylon.cronit.io/docs')}\n\n💬 ${chalk.cyan.bold('Join our Community')}\n    ${chalk.underline.blue('https://discord.gg/cbJjkVrnHe')}\n`\n\n    await telemetry.sendCreateEvent({\n      name: projectName,\n      pylonCreateVersion: version,\n      runtime: runtimeName,\n      template: templateName,\n      clientPath: clientPath || undefined,\n      clientPort: parseInt(clientPort) || undefined\n    })\n\n    consola.box(message)\n  } catch (e) {\n    consola.error(e)\n  }\n}\n\nprogram.parse()\n"
  ],
  "mappings": "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",
  "debugId": "38EA1869FEC6A23F64756E2164756E21",
  "names": []
}
|
package/package.json
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
"type": "module",
|
|
6
6
|
"description": "Generated with `npm create pylon`",
|
|
7
7
|
"scripts": {
|
|
8
|
-
"dev": "pylon dev -c
|
|
8
|
+
"dev": "pylon dev -c \"node --enable-source-maps .pylon/index.js\"",
|
|
9
9
|
"build": "pylon build"
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|