@objectifthunes/create-sandstone 0.1.0 → 0.2.0

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 (71) hide show
  1. package/dist/generator.d.ts +3 -0
  2. package/dist/generator.d.ts.map +1 -0
  3. package/dist/generator.js +78 -0
  4. package/dist/generator.js.map +1 -0
  5. package/dist/index.d.ts +1 -0
  6. package/dist/index.d.ts.map +1 -0
  7. package/dist/index.js +106 -61
  8. package/dist/index.js.map +1 -0
  9. package/dist/presets.d.ts +25 -0
  10. package/dist/presets.d.ts.map +1 -0
  11. package/dist/presets.js +58 -0
  12. package/dist/presets.js.map +1 -0
  13. package/dist/prompts.d.ts +3 -13
  14. package/dist/prompts.d.ts.map +1 -0
  15. package/dist/prompts.js +61 -62
  16. package/dist/prompts.js.map +1 -0
  17. package/dist/templates/claude-md.d.ts +3 -0
  18. package/dist/templates/claude-md.d.ts.map +1 -0
  19. package/dist/templates/claude-md.js +385 -0
  20. package/dist/templates/claude-md.js.map +1 -0
  21. package/dist/templates/docker-compose.d.ts +3 -0
  22. package/dist/templates/docker-compose.d.ts.map +1 -0
  23. package/dist/templates/docker-compose.js +33 -0
  24. package/dist/templates/docker-compose.js.map +1 -0
  25. package/dist/templates/env-example.d.ts +3 -0
  26. package/dist/templates/env-example.d.ts.map +1 -0
  27. package/dist/templates/env-example.js +58 -0
  28. package/dist/templates/env-example.js.map +1 -0
  29. package/dist/templates/gitignore.d.ts +2 -0
  30. package/dist/templates/gitignore.d.ts.map +1 -0
  31. package/dist/templates/gitignore.js +11 -0
  32. package/dist/templates/gitignore.js.map +1 -0
  33. package/dist/templates/infrastructure.d.ts +3 -0
  34. package/dist/templates/infrastructure.d.ts.map +1 -0
  35. package/dist/templates/infrastructure.js +243 -0
  36. package/dist/templates/infrastructure.js.map +1 -0
  37. package/dist/templates/main-express.d.ts +3 -0
  38. package/dist/templates/main-express.d.ts.map +1 -0
  39. package/dist/templates/main-express.js +45 -0
  40. package/dist/templates/main-express.js.map +1 -0
  41. package/dist/templates/main-hono.d.ts +3 -0
  42. package/dist/templates/main-hono.d.ts.map +1 -0
  43. package/dist/templates/main-hono.js +47 -0
  44. package/dist/templates/main-hono.js.map +1 -0
  45. package/dist/templates/migrate-script.d.ts +2 -0
  46. package/dist/templates/migrate-script.d.ts.map +1 -0
  47. package/dist/templates/migrate-script.js +18 -0
  48. package/dist/templates/migrate-script.js.map +1 -0
  49. package/dist/templates/migration.d.ts +2 -0
  50. package/dist/templates/migration.d.ts.map +1 -0
  51. package/dist/templates/migration.js +17 -0
  52. package/dist/templates/migration.js.map +1 -0
  53. package/dist/templates/package-json.d.ts +3 -0
  54. package/dist/templates/package-json.d.ts.map +1 -0
  55. package/dist/templates/package-json.js +85 -0
  56. package/dist/templates/package-json.js.map +1 -0
  57. package/dist/templates/schema.d.ts +3 -0
  58. package/dist/templates/schema.d.ts.map +1 -0
  59. package/dist/templates/schema.js +108 -0
  60. package/dist/templates/schema.js.map +1 -0
  61. package/dist/templates/test-setup.d.ts +3 -0
  62. package/dist/templates/test-setup.d.ts.map +1 -0
  63. package/dist/templates/test-setup.js +41 -0
  64. package/dist/templates/test-setup.js.map +1 -0
  65. package/dist/templates/tsconfig.d.ts +2 -0
  66. package/dist/templates/tsconfig.d.ts.map +1 -0
  67. package/dist/templates/tsconfig.js +21 -0
  68. package/dist/templates/tsconfig.js.map +1 -0
  69. package/package.json +12 -6
  70. package/dist/generators.d.ts +0 -7
  71. package/dist/generators.js +0 -328
@@ -0,0 +1,3 @@
1
+ import type { ProjectConfig } from './presets.js';
2
+ export declare function generateProject(targetDir: string, config: ProjectConfig): Promise<string[]>;
3
+ //# sourceMappingURL=generator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generator.d.ts","sourceRoot":"","sources":["../src/generator.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAoBlD,wBAAsB,eAAe,CACnC,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,aAAa,GACpB,OAAO,CAAC,MAAM,EAAE,CAAC,CAqEnB"}
@@ -0,0 +1,78 @@
1
+ import { writeFile, mkdir } from 'node:fs/promises';
2
+ import { join } from 'node:path';
3
+ import { packageJsonTemplate } from './templates/package-json.js';
4
+ import { tsconfigTemplate } from './templates/tsconfig.js';
5
+ import { gitignoreTemplate } from './templates/gitignore.js';
6
+ import { envExampleTemplate } from './templates/env-example.js';
7
+ import { dockerComposeTemplate } from './templates/docker-compose.js';
8
+ import { infrastructureTemplate } from './templates/infrastructure.js';
9
+ import { mainExpressTemplate } from './templates/main-express.js';
10
+ import { mainHonoTemplate } from './templates/main-hono.js';
11
+ import { schemaTemplate } from './templates/schema.js';
12
+ import { testSetupTemplate } from './templates/test-setup.js';
13
+ import { migrationTemplate } from './templates/migration.js';
14
+ import { migrateScriptTemplate } from './templates/migrate-script.js';
15
+ import { claudeMdTemplate } from './templates/claude-md.js';
16
+ export async function generateProject(targetDir, config) {
17
+ const files = [];
18
+ // Root config files
19
+ files.push({ path: 'package.json', content: packageJsonTemplate(config) });
20
+ files.push({ path: 'tsconfig.json', content: tsconfigTemplate() });
21
+ files.push({ path: '.gitignore', content: gitignoreTemplate() });
22
+ files.push({ path: '.env.example', content: envExampleTemplate(config) });
23
+ if (!config.devMode) {
24
+ files.push({
25
+ path: 'docker-compose.yml',
26
+ content: dockerComposeTemplate(config),
27
+ });
28
+ }
29
+ files.push({ path: 'CLAUDE.md', content: claudeMdTemplate(config) });
30
+ // Source files
31
+ files.push({
32
+ path: 'src/infrastructure.ts',
33
+ content: infrastructureTemplate(config),
34
+ });
35
+ if (config.framework === 'express') {
36
+ files.push({
37
+ path: 'src/main.ts',
38
+ content: mainExpressTemplate(config),
39
+ });
40
+ }
41
+ else {
42
+ files.push({
43
+ path: 'src/main.ts',
44
+ content: mainHonoTemplate(config),
45
+ });
46
+ }
47
+ if (config.graphql) {
48
+ files.push({ path: 'src/schema.ts', content: schemaTemplate(config) });
49
+ }
50
+ // Migrations
51
+ files.push({
52
+ path: 'migrations/001_notes.up.sql',
53
+ content: migrationTemplate(),
54
+ });
55
+ // Scripts
56
+ files.push({
57
+ path: 'scripts/migrate.ts',
58
+ content: migrateScriptTemplate(),
59
+ });
60
+ // Tests
61
+ if (config.tests) {
62
+ files.push({
63
+ path: 'tests/setup.ts',
64
+ content: testSetupTemplate(config),
65
+ });
66
+ }
67
+ // Ensure all directories exist, then write files
68
+ const createdFiles = [];
69
+ for (const file of files) {
70
+ const fullPath = join(targetDir, file.path);
71
+ const dir = join(fullPath, '..');
72
+ await mkdir(dir, { recursive: true });
73
+ await writeFile(fullPath, file.content, 'utf-8');
74
+ createdFiles.push(file.path);
75
+ }
76
+ return createdFiles;
77
+ }
78
+ //# sourceMappingURL=generator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generator.js","sourceRoot":"","sources":["../src/generator.ts"],"names":[],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,2 +1,3 @@
1
1
  #!/usr/bin/env node
2
2
  export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
package/dist/index.js CHANGED
@@ -1,70 +1,115 @@
1
1
  #!/usr/bin/env node
2
- import { mkdir, writeFile } from 'node:fs/promises';
3
- import { join } from 'node:path';
2
+ import { resolve } from 'node:path';
3
+ import { existsSync } from 'node:fs';
4
+ import { mkdir } from 'node:fs/promises';
4
5
  import { runPrompts } from './prompts.js';
5
- import { generatePackageJson, generateTsConfig, generateEnvExample, generateGitignore, generateDockerCompose, generateMainTs, } from './generators.js';
6
- async function write(dir, name, content) {
7
- const path = join(dir, name);
8
- await writeFile(path, content, 'utf-8');
9
- console.log(` created ${name}`);
6
+ import { generateProject } from './generator.js';
7
+ import { PRESETS, isPresetName } from './presets.js';
8
+ function printHelp() {
9
+ console.log(`
10
+ Usage: create-sandstone [project-name] [options]
11
+
12
+ Options:
13
+ --yes, -y Non-interactive mode (use defaults or preset)
14
+ --template, -t Use a preset template (saas, api, minimal)
15
+ --help, -h Show this help message
16
+
17
+ Examples:
18
+ npx @objectifthunes/create-sandstone my-backend
19
+ npx @objectifthunes/create-sandstone my-api --yes --template api
20
+ npx @objectifthunes/create-sandstone my-saas -y -t saas
21
+ `);
22
+ }
23
+ function parseArgs(args) {
24
+ let name = null;
25
+ let yes = false;
26
+ let template = null;
27
+ let help = false;
28
+ for (let i = 0; i < args.length; i++) {
29
+ const arg = args[i];
30
+ if (arg === '--yes' || arg === '-y') {
31
+ yes = true;
32
+ }
33
+ else if (arg === '--help' || arg === '-h') {
34
+ help = true;
35
+ }
36
+ else if (arg === '--template' || arg === '-t') {
37
+ template = args[++i] ?? null;
38
+ }
39
+ else if (arg.startsWith('--template=')) {
40
+ template = arg.split('=')[1] ?? null;
41
+ }
42
+ else if (!arg.startsWith('-')) {
43
+ name = arg;
44
+ }
45
+ }
46
+ return { name, yes, template, help };
10
47
  }
11
48
  async function main() {
12
- console.log('\n @objectifthunes/create-sandstone\n');
13
- const config = await runPrompts();
14
- const dir = join(process.cwd(), config.name);
15
- console.log(`\n Scaffolding ${config.name}...\n`);
16
- await mkdir(dir, { recursive: true });
17
- await mkdir(join(dir, 'src'), { recursive: true });
18
- await mkdir(join(dir, 'migrations'), { recursive: true });
19
- await mkdir(join(dir, 'tests', 'unit'), { recursive: true });
20
- await write(dir, 'package.json', generatePackageJson(config));
21
- await write(dir, 'tsconfig.json', generateTsConfig(config));
22
- await write(dir, '.env.example', generateEnvExample(config));
23
- await write(dir, '.gitignore', generateGitignore());
24
- await write(dir, 'src/main.ts', generateMainTs(config));
25
- if (config.docker) {
26
- await write(dir, 'docker-compose.yml', generateDockerCompose());
49
+ const args = parseArgs(process.argv.slice(2));
50
+ if (args.help) {
51
+ printHelp();
52
+ process.exit(0);
27
53
  }
28
- // Sample migration
29
- await write(dir, 'migrations/001_sample.sql', `CREATE TABLE IF NOT EXISTS items (
30
- id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
31
- user_id UUID NOT NULL REFERENCES auth_users(id) ON DELETE CASCADE,
32
- title TEXT NOT NULL,
33
- created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
34
- );
35
- `);
36
- // Sample test
37
- await write(dir, 'tests/unit/sample.test.ts', `import { describe, it, expect } from 'vitest';
38
- import { createInMemoryDatabase } from '@objectifthunes/sandstone-sdk/testing';
39
-
40
- describe('sample', () => {
41
- it('in-memory database works', async () => {
42
- const db = createInMemoryDatabase();
43
- await db.query('CREATE TABLE test (id TEXT)');
44
- await db.query('INSERT INTO "test" ("id") VALUES ($1) RETURNING *', ['1']);
45
- const result = await db.query('SELECT * FROM "test"');
46
- expect(result.rows.length).toBe(1);
47
- });
48
- });
49
- `);
50
- // Vitest config
51
- await write(dir, 'vitest.config.ts', `import { defineConfig } from 'vitest/config';
52
-
53
- export default defineConfig({
54
- test: {
55
- globals: true,
56
- include: ['tests/unit/**/*.test.ts'],
57
- },
58
- });
59
- `);
60
- console.log('\n Done! Next steps:\n');
61
- console.log(` cd ${config.name}`);
62
- console.log(' cp .env.example .env');
63
- console.log(' pnpm install');
64
- console.log(' pnpm test');
65
- console.log('');
54
+ const projectName = args.name ?? 'my-sandstone-app';
55
+ const targetDir = resolve(process.cwd(), projectName);
56
+ console.log();
57
+ console.log(` Creating a new Sandstone project in ${targetDir}`);
58
+ console.log();
59
+ let config;
60
+ if (args.yes) {
61
+ // Non-interactive mode
62
+ if (args.template) {
63
+ if (!isPresetName(args.template)) {
64
+ console.error(` Error: Unknown template "${args.template}". Available: saas, api, minimal`);
65
+ process.exit(1);
66
+ }
67
+ config = { name: projectName, ...PRESETS[args.template] };
68
+ console.log(` Using preset: ${args.template}`);
69
+ }
70
+ else {
71
+ config = { name: projectName, ...PRESETS.minimal };
72
+ console.log(` Using default preset: minimal`);
73
+ }
74
+ console.log();
75
+ }
76
+ else {
77
+ // Interactive mode
78
+ const result = await runPrompts(projectName);
79
+ if (!result) {
80
+ console.log(' Cancelled.');
81
+ process.exit(0);
82
+ }
83
+ config = result;
84
+ console.log();
85
+ }
86
+ // Create target directory
87
+ if (existsSync(targetDir)) {
88
+ console.error(` Error: Directory "${projectName}" already exists.`);
89
+ process.exit(1);
90
+ }
91
+ await mkdir(targetDir, { recursive: true });
92
+ // Generate project files
93
+ const files = await generateProject(targetDir, config);
94
+ // Print summary
95
+ console.log(` Scaffolded ${files.length} files:`);
96
+ console.log();
97
+ for (const file of files) {
98
+ console.log(` ${file}`);
99
+ }
100
+ console.log();
101
+ console.log(` Next steps:`);
102
+ console.log();
103
+ console.log(` cd ${projectName}`);
104
+ console.log(` cp .env.example .env`);
105
+ console.log(` npm install`);
106
+ console.log(` docker compose up -d`);
107
+ console.log(` npm run db:migrate`);
108
+ console.log(` npm run dev`);
109
+ console.log();
66
110
  }
67
111
  main().catch((err) => {
68
- console.error(err);
112
+ console.error('Error:', err instanceof Error ? err.message : String(err));
69
113
  process.exit(1);
70
114
  });
115
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,25 @@
1
+ export type Framework = 'express' | 'hono';
2
+ export type Database = 'pg';
3
+ export type AuthStrategy = 'otp' | 'password+otp' | 'oauth+otp' | 'all' | null;
4
+ export type EmailProvider = 'resend' | 'nodemailer' | null;
5
+ export type PaymentProvider = 'stripe' | 'revenuecat' | 'paddle' | 'lemonsqueezy' | null;
6
+ export type StorageProvider = 's3' | 'r2' | 'local' | null;
7
+ export type CacheProvider = 'upstash' | null;
8
+ export interface ProjectConfig {
9
+ name: string;
10
+ framework: Framework;
11
+ database: Database;
12
+ auth: AuthStrategy;
13
+ email: EmailProvider;
14
+ payments: PaymentProvider;
15
+ storage: StorageProvider;
16
+ cache: CacheProvider;
17
+ graphql: boolean;
18
+ tests: boolean;
19
+ e2e: boolean;
20
+ devMode?: boolean;
21
+ }
22
+ export type PresetName = 'saas' | 'api' | 'minimal' | 'prototype';
23
+ export declare const PRESETS: Record<PresetName, Omit<ProjectConfig, 'name'>>;
24
+ export declare function isPresetName(value: string): value is PresetName;
25
+ //# sourceMappingURL=presets.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"presets.d.ts","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GAAG,SAAS,GAAG,MAAM,CAAC;AAC3C,MAAM,MAAM,QAAQ,GAAG,IAAI,CAAC;AAC5B,MAAM,MAAM,YAAY,GAAG,KAAK,GAAG,cAAc,GAAG,WAAW,GAAG,KAAK,GAAG,IAAI,CAAC;AAC/E,MAAM,MAAM,aAAa,GAAG,QAAQ,GAAG,YAAY,GAAG,IAAI,CAAC;AAC3D,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,YAAY,GAAG,QAAQ,GAAG,cAAc,GAAG,IAAI,CAAC;AACzF,MAAM,MAAM,eAAe,GAAG,IAAI,GAAG,IAAI,GAAG,OAAO,GAAG,IAAI,CAAC;AAC3D,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,IAAI,CAAC;AAE7C,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,SAAS,CAAC;IACrB,QAAQ,EAAE,QAAQ,CAAC;IACnB,IAAI,EAAE,YAAY,CAAC;IACnB,KAAK,EAAE,aAAa,CAAC;IACrB,QAAQ,EAAE,eAAe,CAAC;IAC1B,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,EAAE,aAAa,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,OAAO,CAAC;IACf,GAAG,EAAE,OAAO,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,MAAM,MAAM,UAAU,GAAG,MAAM,GAAG,KAAK,GAAG,SAAS,GAAG,WAAW,CAAC;AAElE,eAAO,MAAM,OAAO,EAAE,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,CAqDnE,CAAC;AAEF,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,UAAU,CAE/D"}
@@ -0,0 +1,58 @@
1
+ export const PRESETS = {
2
+ saas: {
3
+ framework: 'express',
4
+ database: 'pg',
5
+ auth: 'all',
6
+ email: 'resend',
7
+ payments: 'stripe',
8
+ storage: 's3',
9
+ cache: 'upstash',
10
+ graphql: true,
11
+ tests: true,
12
+ e2e: true,
13
+ devMode: false,
14
+ },
15
+ api: {
16
+ framework: 'hono',
17
+ database: 'pg',
18
+ auth: 'otp',
19
+ email: 'resend',
20
+ payments: null,
21
+ storage: null,
22
+ cache: null,
23
+ graphql: true,
24
+ tests: true,
25
+ e2e: false,
26
+ devMode: false,
27
+ },
28
+ minimal: {
29
+ framework: 'express',
30
+ database: 'pg',
31
+ auth: 'otp',
32
+ email: 'nodemailer',
33
+ payments: null,
34
+ storage: null,
35
+ cache: null,
36
+ graphql: true,
37
+ tests: true,
38
+ e2e: false,
39
+ devMode: false,
40
+ },
41
+ prototype: {
42
+ framework: 'express',
43
+ database: 'pg',
44
+ auth: 'otp',
45
+ email: 'nodemailer',
46
+ payments: null,
47
+ storage: null,
48
+ cache: null,
49
+ graphql: true,
50
+ tests: true,
51
+ e2e: false,
52
+ devMode: true,
53
+ },
54
+ };
55
+ export function isPresetName(value) {
56
+ return value in PRESETS;
57
+ }
58
+ //# sourceMappingURL=presets.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"presets.js","sourceRoot":"","sources":["../src/presets.ts"],"names":[],"mappings":"AAyBA,MAAM,CAAC,MAAM,OAAO,GAAoD;IACtE,IAAI,EAAE;QACJ,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,KAAK;QACX,KAAK,EAAE,QAAQ;QACf,QAAQ,EAAE,QAAQ;QAClB,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,SAAS;QAChB,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,GAAG,EAAE,IAAI;QACT,OAAO,EAAE,KAAK;KACf;IACD,GAAG,EAAE;QACH,SAAS,EAAE,MAAM;QACjB,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,KAAK;QACX,KAAK,EAAE,QAAQ;QACf,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,GAAG,EAAE,KAAK;QACV,OAAO,EAAE,KAAK;KACf;IACD,OAAO,EAAE;QACP,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,KAAK;QACX,KAAK,EAAE,YAAY;QACnB,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,GAAG,EAAE,KAAK;QACV,OAAO,EAAE,KAAK;KACf;IACD,SAAS,EAAE;QACT,SAAS,EAAE,SAAS;QACpB,QAAQ,EAAE,IAAI;QACd,IAAI,EAAE,KAAK;QACX,KAAK,EAAE,YAAY;QACnB,QAAQ,EAAE,IAAI;QACd,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;QACb,KAAK,EAAE,IAAI;QACX,GAAG,EAAE,KAAK;QACV,OAAO,EAAE,IAAI;KACd;CACF,CAAC;AAEF,MAAM,UAAU,YAAY,CAAC,KAAa;IACxC,OAAO,KAAK,IAAI,OAAO,CAAC;AAC1B,CAAC"}
package/dist/prompts.d.ts CHANGED
@@ -1,13 +1,3 @@
1
- export interface ProjectConfig {
2
- name: string;
3
- framework: 'express' | 'fastify' | 'hono' | 'nestjs' | 'none';
4
- database: 'supabase' | 'neon' | 'pg';
5
- authStrategies: ('otp' | 'password' | 'oauth')[];
6
- oauthProviders: ('google' | 'github' | 'apple' | 'discord')[];
7
- email: 'resend' | 'nodemailer' | 'none';
8
- payments: 'stripe' | 'revenuecat' | 'none';
9
- storage: 'r2' | 's3' | 'local' | 'none';
10
- cache: 'upstash' | 'none';
11
- docker: boolean;
12
- }
13
- export declare function runPrompts(): Promise<ProjectConfig>;
1
+ import type { ProjectConfig } from './presets.js';
2
+ export declare function runPrompts(name: string): Promise<ProjectConfig | null>;
3
+ //# sourceMappingURL=prompts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../src/prompts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,aAAa,EAOd,MAAM,cAAc,CAAC;AAEtB,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAiH5E"}
package/dist/prompts.js CHANGED
@@ -1,113 +1,112 @@
1
1
  import prompts from 'prompts';
2
- export async function runPrompts() {
2
+ export async function runPrompts(name) {
3
3
  const response = await prompts([
4
- {
5
- type: 'text',
6
- name: 'name',
7
- message: 'Project name',
8
- initial: 'my-backend',
9
- },
10
4
  {
11
5
  type: 'select',
12
6
  name: 'framework',
13
- message: 'HTTP framework',
7
+ message: 'Which HTTP framework?',
14
8
  choices: [
15
9
  { title: 'Express', value: 'express' },
16
- { title: 'Fastify', value: 'fastify' },
17
10
  { title: 'Hono', value: 'hono' },
18
- { title: 'NestJS', value: 'nestjs' },
19
- { title: 'None (raw Node.js)', value: 'none' },
20
11
  ],
12
+ initial: 0,
21
13
  },
22
14
  {
23
15
  type: 'select',
24
- name: 'database',
25
- message: 'Database',
26
- choices: [
27
- { title: 'Supabase PostgreSQL', value: 'supabase' },
28
- { title: 'Raw PostgreSQL (pg)', value: 'pg' },
29
- ],
30
- },
31
- {
32
- type: 'multiselect',
33
- name: 'authStrategies',
34
- message: 'Auth strategies',
35
- choices: [
36
- { title: 'Email OTP (6-digit code)', value: 'otp', selected: true },
37
- { title: 'Password (argon2)', value: 'password' },
38
- { title: 'OAuth', value: 'oauth' },
39
- ],
40
- min: 1,
41
- },
42
- {
43
- type: (prev) => prev.includes('oauth') ? 'multiselect' : null,
44
- name: 'oauthProviders',
45
- message: 'OAuth providers',
16
+ name: 'auth',
17
+ message: 'Authentication strategy?',
46
18
  choices: [
47
- { title: 'Google', value: 'google', selected: true },
48
- { title: 'GitHub', value: 'github' },
49
- { title: 'Apple', value: 'apple' },
50
- { title: 'Discord', value: 'discord' },
19
+ { title: 'OTP only (email codes)', value: 'otp' },
20
+ { title: 'Password + OTP', value: 'password+otp' },
21
+ { title: 'OAuth + OTP (Google, GitHub, etc.)', value: 'oauth+otp' },
22
+ { title: 'All (Password + OAuth + OTP)', value: 'all' },
23
+ { title: 'None', value: null },
51
24
  ],
52
- min: 1,
25
+ initial: 0,
53
26
  },
54
27
  {
55
- type: 'select',
28
+ type: (prev) => (prev !== null ? 'select' : null),
56
29
  name: 'email',
57
- message: 'Email provider',
30
+ message: 'Email provider?',
58
31
  choices: [
59
- { title: 'Resend', value: 'resend' },
32
+ { title: 'Resend (API-based)', value: 'resend' },
60
33
  { title: 'Nodemailer (SMTP)', value: 'nodemailer' },
61
- { title: 'None', value: 'none' },
62
34
  ],
35
+ initial: 0,
63
36
  },
64
37
  {
65
38
  type: 'select',
66
39
  name: 'payments',
67
- message: 'Payments',
40
+ message: 'Payment provider?',
68
41
  choices: [
42
+ { title: 'None', value: null },
69
43
  { title: 'Stripe', value: 'stripe' },
70
44
  { title: 'RevenueCat', value: 'revenuecat' },
71
- { title: 'None', value: 'none' },
45
+ { title: 'Paddle', value: 'paddle' },
46
+ { title: 'Lemon Squeezy', value: 'lemonsqueezy' },
72
47
  ],
48
+ initial: 0,
73
49
  },
74
50
  {
75
51
  type: 'select',
76
52
  name: 'storage',
77
- message: 'Storage',
53
+ message: 'File storage?',
78
54
  choices: [
79
- { title: 'Cloudflare R2', value: 'r2' },
80
- { title: 'AWS S3', value: 's3' },
55
+ { title: 'None', value: null },
56
+ { title: 'S3 (AWS)', value: 's3' },
57
+ { title: 'R2 (Cloudflare)', value: 'r2' },
81
58
  { title: 'Local filesystem', value: 'local' },
82
- { title: 'None', value: 'none' },
83
59
  ],
60
+ initial: 0,
84
61
  },
85
62
  {
86
63
  type: 'select',
87
64
  name: 'cache',
88
- message: 'Cache',
65
+ message: 'Cache provider?',
89
66
  choices: [
67
+ { title: 'None', value: null },
90
68
  { title: 'Upstash Redis', value: 'upstash' },
91
- { title: 'None', value: 'none' },
92
69
  ],
70
+ initial: 0,
93
71
  },
94
72
  {
95
73
  type: 'confirm',
96
- name: 'docker',
97
- message: 'Include docker-compose for local dev/testing?',
74
+ name: 'graphql',
75
+ message: 'Include GraphQL schema?',
98
76
  initial: true,
99
77
  },
100
- ], { onCancel: () => process.exit(0) });
78
+ {
79
+ type: 'confirm',
80
+ name: 'tests',
81
+ message: 'Include test scaffolding?',
82
+ initial: true,
83
+ },
84
+ {
85
+ type: (prev) => (prev ? 'confirm' : null),
86
+ name: 'e2e',
87
+ message: 'Include e2e tests (with docker-compose)?',
88
+ initial: false,
89
+ },
90
+ ], {
91
+ onCancel: () => {
92
+ process.exit(0);
93
+ },
94
+ });
95
+ // If user cancelled mid-way, some keys may be missing
96
+ if (!response.framework)
97
+ return null;
101
98
  return {
102
- name: response.name,
99
+ name,
103
100
  framework: response.framework,
104
- database: response.database,
105
- authStrategies: response.authStrategies ?? ['otp'],
106
- oauthProviders: response.oauthProviders ?? [],
107
- email: response.email,
108
- payments: response.payments,
109
- storage: response.storage,
110
- cache: response.cache,
111
- docker: response.docker,
101
+ database: 'pg',
102
+ auth: (response.auth ?? null),
103
+ email: (response.email ?? null),
104
+ payments: (response.payments ?? null),
105
+ storage: (response.storage ?? null),
106
+ cache: (response.cache ?? null),
107
+ graphql: response.graphql ?? true,
108
+ tests: response.tests ?? true,
109
+ e2e: response.e2e ?? false,
112
110
  };
113
111
  }
112
+ //# sourceMappingURL=prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompts.js","sourceRoot":"","sources":["../src/prompts.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { ProjectConfig } from '../presets.js';
2
+ export declare function claudeMdTemplate(config: ProjectConfig): string;
3
+ //# sourceMappingURL=claude-md.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claude-md.d.ts","sourceRoot":"","sources":["../../src/templates/claude-md.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAEnD,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,aAAa,GAAG,MAAM,CAuc9D"}