@m2015agg/supabase-skill 0.6.2 → 0.7.1
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/README.md +129 -248
- package/dist/commands/context.js +10 -4
- package/dist/commands/context.js.map +1 -1
- package/dist/commands/diff.d.ts +2 -0
- package/dist/commands/diff.js +123 -0
- package/dist/commands/diff.js.map +1 -0
- package/dist/commands/docs.js +2 -0
- package/dist/commands/docs.js.map +1 -1
- package/dist/commands/doctor.d.ts +2 -0
- package/dist/commands/doctor.js +210 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/graph.d.ts +2 -0
- package/dist/commands/graph.js +49 -0
- package/dist/commands/graph.js.map +1 -0
- package/dist/commands/init.js +8 -0
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/snapshot.d.ts +41 -0
- package/dist/commands/snapshot.js +84 -13
- package/dist/commands/snapshot.js.map +1 -1
- package/dist/commands/table.js +12 -2
- package/dist/commands/table.js.map +1 -1
- package/dist/index.js +7 -1
- package/dist/index.js.map +1 -1
- package/dist/templates/walkthrough.d.ts +1 -0
- package/dist/templates/walkthrough.js +46 -0
- package/dist/templates/walkthrough.js.map +1 -0
- package/dist/util/db.d.ts +6 -0
- package/dist/util/db.js +23 -4
- package/dist/util/db.js.map +1 -1
- package/package.json +3 -2
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { existsSync } from "node:fs";
|
|
4
|
+
import { readConfig } from "../util/config.js";
|
|
5
|
+
import { hasDb, openDb, getAllTableNames, getTableColumns } from "../util/db.js";
|
|
6
|
+
import { fetchOpenAPISpec } from "./snapshot.js";
|
|
7
|
+
function write(msg) {
|
|
8
|
+
process.stdout.write(msg);
|
|
9
|
+
}
|
|
10
|
+
export function diffCommand() {
|
|
11
|
+
return new Command("diff")
|
|
12
|
+
.description("Compare live database schema against local snapshot — find added/removed tables and columns")
|
|
13
|
+
.option("--project-ref <ref>", "Supabase project ref")
|
|
14
|
+
.option("--schema <name>", "Schema name")
|
|
15
|
+
.option("--dir <dir>", "Schema directory", ".supabase-schema")
|
|
16
|
+
.action((opts) => {
|
|
17
|
+
const cwd = process.cwd();
|
|
18
|
+
const schemaDir = join(cwd, opts.dir);
|
|
19
|
+
const config = readConfig();
|
|
20
|
+
// Resolve project ref
|
|
21
|
+
let ref = opts.projectRef;
|
|
22
|
+
if (!ref && config) {
|
|
23
|
+
const stageEnv = config.environments["stage"] || config.environments[config.defaultEnv];
|
|
24
|
+
if (stageEnv)
|
|
25
|
+
ref = stageEnv.ref;
|
|
26
|
+
}
|
|
27
|
+
if (!ref) {
|
|
28
|
+
write("Error: No project ref. Use --project-ref or run `supabase-skill install`.\n");
|
|
29
|
+
process.exit(1);
|
|
30
|
+
}
|
|
31
|
+
const schema = opts.schema || config?.schema || "public";
|
|
32
|
+
if (!existsSync(schemaDir) || !hasDb(schemaDir)) {
|
|
33
|
+
write("Error: No snapshot found. Run `supabase-skill snapshot` first.\n");
|
|
34
|
+
process.exit(1);
|
|
35
|
+
}
|
|
36
|
+
write(`\n Diffing live "${schema}" (${ref}) vs local snapshot...\n\n`);
|
|
37
|
+
// Fetch fresh spec
|
|
38
|
+
write(" Fetching live schema... ");
|
|
39
|
+
let spec;
|
|
40
|
+
try {
|
|
41
|
+
spec = fetchOpenAPISpec(ref, schema);
|
|
42
|
+
}
|
|
43
|
+
catch (e) {
|
|
44
|
+
write(`FAILED\n ${e.message}\n`);
|
|
45
|
+
process.exit(1);
|
|
46
|
+
}
|
|
47
|
+
write("\u2713\n\n");
|
|
48
|
+
// Load local snapshot
|
|
49
|
+
const db = openDb(schemaDir);
|
|
50
|
+
const localTables = new Set(getAllTableNames(db));
|
|
51
|
+
const remoteTables = new Set(Object.keys(spec.definitions));
|
|
52
|
+
let changes = 0;
|
|
53
|
+
// Tables added remotely
|
|
54
|
+
const added = [...remoteTables].filter((t) => !localTables.has(t)).sort();
|
|
55
|
+
if (added.length > 0) {
|
|
56
|
+
write(` + ${added.length} table(s) added:\n`);
|
|
57
|
+
for (const t of added) {
|
|
58
|
+
const colCount = Object.keys(spec.definitions[t].properties).length;
|
|
59
|
+
write(` + ${t} (${colCount} columns)\n`);
|
|
60
|
+
}
|
|
61
|
+
write("\n");
|
|
62
|
+
changes += added.length;
|
|
63
|
+
}
|
|
64
|
+
// Tables removed remotely
|
|
65
|
+
const removed = [...localTables].filter((t) => !remoteTables.has(t)).sort();
|
|
66
|
+
if (removed.length > 0) {
|
|
67
|
+
write(` - ${removed.length} table(s) removed:\n`);
|
|
68
|
+
for (const t of removed)
|
|
69
|
+
write(` - ${t}\n`);
|
|
70
|
+
write("\n");
|
|
71
|
+
changes += removed.length;
|
|
72
|
+
}
|
|
73
|
+
// Column-level diffs for tables that exist in both
|
|
74
|
+
const common = [...localTables].filter((t) => remoteTables.has(t)).sort();
|
|
75
|
+
for (const table of common) {
|
|
76
|
+
const localCols = new Set(getTableColumns(db, table).map((c) => c.name));
|
|
77
|
+
const remoteCols = new Set(Object.keys(spec.definitions[table].properties));
|
|
78
|
+
const addedCols = [...remoteCols].filter((c) => !localCols.has(c));
|
|
79
|
+
const removedCols = [...localCols].filter((c) => !remoteCols.has(c));
|
|
80
|
+
if (addedCols.length > 0 || removedCols.length > 0) {
|
|
81
|
+
write(` ~ ${table}:\n`);
|
|
82
|
+
for (const c of addedCols) {
|
|
83
|
+
const def = spec.definitions[table].properties[c];
|
|
84
|
+
write(` + ${c} (${def.format || def.type || "unknown"})\n`);
|
|
85
|
+
}
|
|
86
|
+
for (const c of removedCols) {
|
|
87
|
+
write(` - ${c}\n`);
|
|
88
|
+
}
|
|
89
|
+
write("\n");
|
|
90
|
+
changes += addedCols.length + removedCols.length;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
// Functions diff
|
|
94
|
+
const localFuncs = new Set(db.prepare("SELECT name FROM functions ORDER BY name").all().map((r) => r.name));
|
|
95
|
+
const remoteFuncs = new Set(Object.keys(spec.paths)
|
|
96
|
+
.filter((p) => p.startsWith("/rpc/"))
|
|
97
|
+
.map((p) => p.replace("/rpc/", "")));
|
|
98
|
+
const addedFuncs = [...remoteFuncs].filter((f) => !localFuncs.has(f)).sort();
|
|
99
|
+
const removedFuncs = [...localFuncs].filter((f) => !remoteFuncs.has(f)).sort();
|
|
100
|
+
if (addedFuncs.length > 0) {
|
|
101
|
+
write(` + ${addedFuncs.length} function(s) added:\n`);
|
|
102
|
+
for (const f of addedFuncs)
|
|
103
|
+
write(` + ${f}\n`);
|
|
104
|
+
write("\n");
|
|
105
|
+
changes += addedFuncs.length;
|
|
106
|
+
}
|
|
107
|
+
if (removedFuncs.length > 0) {
|
|
108
|
+
write(` - ${removedFuncs.length} function(s) removed:\n`);
|
|
109
|
+
for (const f of removedFuncs)
|
|
110
|
+
write(` - ${f}\n`);
|
|
111
|
+
write("\n");
|
|
112
|
+
changes += removedFuncs.length;
|
|
113
|
+
}
|
|
114
|
+
db.close();
|
|
115
|
+
if (changes === 0) {
|
|
116
|
+
write(" No changes detected. Snapshot is up to date.\n\n");
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
write(` ${changes} change(s) detected. Run \`supabase-skill snapshot\` to update.\n\n`);
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=diff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../../src/commands/diff.ts"],"names":[],"mappings":"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"}
|
package/dist/commands/docs.js
CHANGED
|
@@ -214,6 +214,8 @@ If \`.supabase-schema/\` exists, ALWAYS use these commands instead of running SQ
|
|
|
214
214
|
- **After applying migrations**: Run \`supabase-skill snapshot\` to update the local schema cache
|
|
215
215
|
- **After creating/altering tables**: Run \`supabase-skill snapshot\` before continuing work
|
|
216
216
|
- **Rule of thumb**: If you ran any DDL (CREATE, ALTER, DROP) or migration commands, refresh the snapshot immediately
|
|
217
|
+
- **Freshness check**: If snapshot is >24h old, suggest refreshing before relying on schema data
|
|
218
|
+
- \`supabase-skill doctor\` shows snapshot age and overall setup health
|
|
217
219
|
|
|
218
220
|
### Safety Rules
|
|
219
221
|
- NEVER run mutations on PROD without explicit user approval
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"docs.js","sourceRoot":"","sources":["../../src/commands/docs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,UAAU,EAAoB,MAAM,mBAAmB,CAAC;AAEjE,SAAS,eAAe,CAAC,MAA0B;IACjD,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7D,OAAO;;wDAE6C,CAAC;IACvD,CAAC;IAED,MAAM,KAAK,GAAG,CAAC,kBAAkB,CAAC,CAAC;IACnC,KAAK,MAAM,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;QACvE,MAAM,OAAO,GAAG,GAAG,KAAK,MAAM,CAAC,CAAC,CAAC,wDAAwD,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/F,MAAM,KAAK,GAAG,GAAG,CAAC,WAAW,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,OAAO,KAAK,SAAS,GAAG,OAAO,IAAI,IAAI,OAAO,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED,oBAAoB;IACpB,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,6DAA6D,CAAC,CAAC;IAC1E,KAAK,MAAM,CAAC,GAAG,EAAE,EAAE,GAAG,EAAE,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;QACjE,MAAM,OAAO,GAAG,GAAG,KAAK,MAAM;YAC5B,CAAC,CAAC,8BAA8B;YAChC,CAAC,CAAC,GAAG,KAAK,OAAO;gBACf,CAAC,CAAC,uCAAuC;gBACzC,CAAC,CAAC,+BAA+B,CAAC;QACtC,KAAK,CAAC,IAAI,CAAC,KAAK,OAAO,sBAAsB,GAAG,IAAI,CAAC,CAAC;IACxD,CAAC;IAED,IAAI,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC;QAChC,KAAK,CAAC,IAAI,CAAC,6FAA6F,CAAC,CAAC;IAC5G,CAAC;IAED,iDAAiD;IACjD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,uEAAuE,CAAC,CAAC;IACpF,KAAK,CAAC,IAAI,CAAC,gEAAgE,CAAC,CAAC;IAC7E,KAAK,MAAM,CAAC,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;QACxD,MAAM,MAAM,GAAG,YAAY,GAAG,CAAC,WAAW,EAAE,EAAE,CAAC;QAC/C,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,WAAW,EAAE,QAAQ,MAAM,cAAc,MAAM,sBAAsB,MAAM,aAAa,CAAC,CAAC;IAChH,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IAElF,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,SAA6B,IAAI;IAC3D,MAAM,UAAU,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;IAE3C,OAAO;;;;;EAKP,UAAU
|
|
1
|
+
{"version":3,"file":"docs.js","sourceRoot":"","sources":["../../src/commands/docs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { existsSync, readFileSync, statSync } from "node:fs";
|
|
4
|
+
import { execSync } from "node:child_process";
|
|
5
|
+
import { isSupabaseCLIInstalled, isLoggedIn } from "../util/detect.js";
|
|
6
|
+
import { readConfig } from "../util/config.js";
|
|
7
|
+
import { hasDb } from "../util/db.js";
|
|
8
|
+
function write(msg) {
|
|
9
|
+
process.stdout.write(msg);
|
|
10
|
+
}
|
|
11
|
+
function pass(label, detail) {
|
|
12
|
+
write(` ✓ ${label}${detail ? ` — ${detail}` : ""}\n`);
|
|
13
|
+
}
|
|
14
|
+
function fail(label, detail) {
|
|
15
|
+
write(` ✗ ${label}${detail ? ` — ${detail}` : ""}\n`);
|
|
16
|
+
}
|
|
17
|
+
function warn(label, detail) {
|
|
18
|
+
write(` ⚠ ${label}${detail ? ` — ${detail}` : ""}\n`);
|
|
19
|
+
}
|
|
20
|
+
export function doctorCommand() {
|
|
21
|
+
return new Command("doctor")
|
|
22
|
+
.description("Health check — validate entire supabase-skill setup")
|
|
23
|
+
.action(() => {
|
|
24
|
+
const cwd = process.cwd();
|
|
25
|
+
let passing = 0;
|
|
26
|
+
let failing = 0;
|
|
27
|
+
let warnings = 0;
|
|
28
|
+
write("\n supabase-skill doctor\n");
|
|
29
|
+
write(" ─────────────────────\n\n");
|
|
30
|
+
// 1. Supabase CLI installed + version
|
|
31
|
+
const cli = isSupabaseCLIInstalled();
|
|
32
|
+
if (cli.installed) {
|
|
33
|
+
pass("Supabase CLI", `v${cli.version}`);
|
|
34
|
+
passing++;
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
fail("Supabase CLI", "not installed — run `npm i -g supabase`");
|
|
38
|
+
failing++;
|
|
39
|
+
}
|
|
40
|
+
// 2. Logged in
|
|
41
|
+
if (cli.installed) {
|
|
42
|
+
write(" … Checking login (may take a moment)... ");
|
|
43
|
+
const loggedIn = isLoggedIn();
|
|
44
|
+
write("\r");
|
|
45
|
+
if (loggedIn) {
|
|
46
|
+
pass("Logged in", "supabase projects list works");
|
|
47
|
+
passing++;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
fail("Logged in", "run `supabase login`");
|
|
51
|
+
failing++;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
// 3. Config exists + environments
|
|
55
|
+
const config = readConfig();
|
|
56
|
+
if (config) {
|
|
57
|
+
const envCount = Object.keys(config.environments).length;
|
|
58
|
+
if (envCount > 0) {
|
|
59
|
+
const envNames = Object.keys(config.environments).join(", ");
|
|
60
|
+
pass("Config", `${envCount} environment(s): ${envNames}`);
|
|
61
|
+
passing++;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
fail("Config", "no environments configured — run `supabase-skill install`");
|
|
65
|
+
failing++;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
fail("Config", "not found — run `supabase-skill install`");
|
|
70
|
+
failing++;
|
|
71
|
+
}
|
|
72
|
+
// 4. API keys present per env
|
|
73
|
+
if (config) {
|
|
74
|
+
for (const [env, envConfig] of Object.entries(config.environments)) {
|
|
75
|
+
if (envConfig.anonKey && envConfig.serviceKey) {
|
|
76
|
+
pass(`API keys [${env}]`, "anon + service_role present");
|
|
77
|
+
passing++;
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
const missing = [];
|
|
81
|
+
if (!envConfig.anonKey)
|
|
82
|
+
missing.push("anon");
|
|
83
|
+
if (!envConfig.serviceKey)
|
|
84
|
+
missing.push("service_role");
|
|
85
|
+
warn(`API keys [${env}]`, `missing: ${missing.join(", ")}`);
|
|
86
|
+
warnings++;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
// 5. Schema configured
|
|
91
|
+
if (config?.schema) {
|
|
92
|
+
pass("Schema", config.schema);
|
|
93
|
+
passing++;
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
warn("Schema", "not set — defaults to 'public'");
|
|
97
|
+
warnings++;
|
|
98
|
+
}
|
|
99
|
+
// 6. Project linked (check supabase/.temp/project-ref)
|
|
100
|
+
const projectRefPath = join(cwd, "supabase", ".temp", "project-ref");
|
|
101
|
+
if (existsSync(projectRefPath)) {
|
|
102
|
+
const ref = readFileSync(projectRefPath, "utf-8").trim();
|
|
103
|
+
pass("Project linked", ref);
|
|
104
|
+
passing++;
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
warn("Project linked", "no linked project in cwd — run `supabase link --project-ref <ref>`");
|
|
108
|
+
warnings++;
|
|
109
|
+
}
|
|
110
|
+
// 7. CLAUDE.md has skill doc
|
|
111
|
+
const claudeMd = join(cwd, "CLAUDE.md");
|
|
112
|
+
const dotClaudeMd = join(cwd, ".claude", "CLAUDE.md");
|
|
113
|
+
const hasClaudeMd = (existsSync(claudeMd) && readFileSync(claudeMd, "utf-8").includes("<!-- supabase-skill:start -->")) ||
|
|
114
|
+
(existsSync(dotClaudeMd) && readFileSync(dotClaudeMd, "utf-8").includes("<!-- supabase-skill:start -->"));
|
|
115
|
+
if (hasClaudeMd) {
|
|
116
|
+
pass("CLAUDE.md", "skill doc installed");
|
|
117
|
+
passing++;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
fail("CLAUDE.md", "no supabase-skill section — run `supabase-skill init`");
|
|
121
|
+
failing++;
|
|
122
|
+
}
|
|
123
|
+
// 8. .env has keys
|
|
124
|
+
const envPath = join(cwd, ".env");
|
|
125
|
+
if (existsSync(envPath)) {
|
|
126
|
+
const envContent = readFileSync(envPath, "utf-8");
|
|
127
|
+
if (envContent.includes("SUPABASE_")) {
|
|
128
|
+
pass(".env", "has Supabase keys");
|
|
129
|
+
passing++;
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
warn(".env", "exists but no SUPABASE_ keys — run `supabase-skill init`");
|
|
133
|
+
warnings++;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
warn(".env", "not found — run `supabase-skill init`");
|
|
138
|
+
warnings++;
|
|
139
|
+
}
|
|
140
|
+
// 9. Snapshot exists + age
|
|
141
|
+
const schemaDir = join(cwd, ".supabase-schema");
|
|
142
|
+
if (hasDb(schemaDir)) {
|
|
143
|
+
const dbPath = join(schemaDir, "schema.db");
|
|
144
|
+
const stats = statSync(dbPath);
|
|
145
|
+
const ageMs = Date.now() - stats.mtimeMs;
|
|
146
|
+
const ageHours = Math.floor(ageMs / (1000 * 60 * 60));
|
|
147
|
+
const ageDays = Math.floor(ageHours / 24);
|
|
148
|
+
const ageStr = ageDays > 0 ? `${ageDays}d ${ageHours % 24}h ago` : `${ageHours}h ago`;
|
|
149
|
+
if (ageDays > 7) {
|
|
150
|
+
warn("Snapshot", `exists but stale (${ageStr}) — run \`supabase-skill snapshot\``);
|
|
151
|
+
warnings++;
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
pass("Snapshot", ageStr);
|
|
155
|
+
passing++;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
else if (existsSync(schemaDir)) {
|
|
159
|
+
warn("Snapshot", "markdown only (no SQLite) — re-run `supabase-skill snapshot`");
|
|
160
|
+
warnings++;
|
|
161
|
+
}
|
|
162
|
+
else {
|
|
163
|
+
fail("Snapshot", "not found — run `supabase-skill snapshot`");
|
|
164
|
+
failing++;
|
|
165
|
+
}
|
|
166
|
+
// 10. Permissions approved
|
|
167
|
+
const settingsPath = join(cwd, ".claude", "settings.json");
|
|
168
|
+
if (existsSync(settingsPath)) {
|
|
169
|
+
const settings = readFileSync(settingsPath, "utf-8");
|
|
170
|
+
if (settings.includes("supabase-skill")) {
|
|
171
|
+
pass("Permissions", "supabase-skill approved in .claude/settings.json");
|
|
172
|
+
passing++;
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
warn("Permissions", "supabase-skill not in .claude/settings.json — run `supabase-skill approve`");
|
|
176
|
+
warnings++;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
warn("Permissions", ".claude/settings.json not found — run `supabase-skill approve`");
|
|
181
|
+
warnings++;
|
|
182
|
+
}
|
|
183
|
+
// 11. Cron active
|
|
184
|
+
try {
|
|
185
|
+
const crontab = execSync("crontab -l 2>/dev/null", { encoding: "utf-8" });
|
|
186
|
+
if (crontab.includes("supabase-skill")) {
|
|
187
|
+
pass("Cron", "supabase-skill found in crontab");
|
|
188
|
+
passing++;
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
warn("Cron", "no supabase-skill cron entry — run `supabase-skill cron`");
|
|
192
|
+
warnings++;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
catch {
|
|
196
|
+
warn("Cron", "no crontab — run `supabase-skill cron`");
|
|
197
|
+
warnings++;
|
|
198
|
+
}
|
|
199
|
+
// Summary
|
|
200
|
+
write("\n ─────────────────────\n");
|
|
201
|
+
write(` ${passing} passed, ${failing} failed, ${warnings} warnings\n`);
|
|
202
|
+
if (failing === 0) {
|
|
203
|
+
write(" Setup looks good!\n\n");
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
write(" Fix the failures above and re-run `supabase-skill doctor`\n\n");
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
//# sourceMappingURL=doctor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"doctor.js","sourceRoot":"","sources":["../../src/commands/doctor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,sBAAsB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC,SAAS,KAAK,CAAC,GAAW;IACxB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;AAC5B,CAAC;AAED,SAAS,IAAI,CAAC,KAAa,EAAE,MAAe;IAC1C,KAAK,CAAC,OAAO,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;AACzD,CAAC;AAED,SAAS,IAAI,CAAC,KAAa,EAAE,MAAe;IAC1C,KAAK,CAAC,OAAO,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;AACzD,CAAC;AAED,SAAS,IAAI,CAAC,KAAa,EAAE,MAAe;IAC1C,KAAK,CAAC,OAAO,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC;SACzB,WAAW,CAAC,qDAAqD,CAAC;SAClE,MAAM,CAAC,GAAG,EAAE;QACX,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,IAAI,QAAQ,GAAG,CAAC,CAAC;QAEjB,KAAK,CAAC,6BAA6B,CAAC,CAAC;QACrC,KAAK,CAAC,6BAA6B,CAAC,CAAC;QAErC,sCAAsC;QACtC,MAAM,GAAG,GAAG,sBAAsB,EAAE,CAAC;QACrC,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;YAClB,IAAI,CAAC,cAAc,EAAE,IAAI,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;YACxC,OAAO,EAAE,CAAC;QACZ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,cAAc,EAAE,yCAAyC,CAAC,CAAC;YAChE,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,eAAe;QACf,IAAI,GAAG,CAAC,SAAS,EAAE,CAAC;YAClB,KAAK,CAAC,4CAA4C,CAAC,CAAC;YACpD,MAAM,QAAQ,GAAG,UAAU,EAAE,CAAC;YAC9B,KAAK,CAAC,IAAI,CAAC,CAAC;YACZ,IAAI,QAAQ,EAAE,CAAC;gBACb,IAAI,CAAC,WAAW,EAAE,8BAA8B,CAAC,CAAC;gBAClD,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,WAAW,EAAE,sBAAsB,CAAC,CAAC;gBAC1C,OAAO,EAAE,CAAC;YACZ,CAAC;QACH,CAAC;QAED,kCAAkC;QAClC,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;QAC5B,IAAI,MAAM,EAAE,CAAC;YACX,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC;YACzD,IAAI,QAAQ,GAAG,CAAC,EAAE,CAAC;gBACjB,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC7D,IAAI,CAAC,QAAQ,EAAE,GAAG,QAAQ,oBAAoB,QAAQ,EAAE,CAAC,CAAC;gBAC1D,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,QAAQ,EAAE,2DAA2D,CAAC,CAAC;gBAC5E,OAAO,EAAE,CAAC;YACZ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,EAAE,0CAA0C,CAAC,CAAC;YAC3D,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,8BAA8B;QAC9B,IAAI,MAAM,EAAE,CAAC;YACX,KAAK,MAAM,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;gBACnE,IAAI,SAAS,CAAC,OAAO,IAAI,SAAS,CAAC,UAAU,EAAE,CAAC;oBAC9C,IAAI,CAAC,aAAa,GAAG,GAAG,EAAE,6BAA6B,CAAC,CAAC;oBACzD,OAAO,EAAE,CAAC;gBACZ,CAAC;qBAAM,CAAC;oBACN,MAAM,OAAO,GAAG,EAAE,CAAC;oBACnB,IAAI,CAAC,SAAS,CAAC,OAAO;wBAAE,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBAC7C,IAAI,CAAC,SAAS,CAAC,UAAU;wBAAE,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;oBACxD,IAAI,CAAC,aAAa,GAAG,GAAG,EAAE,YAAY,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC5D,QAAQ,EAAE,CAAC;gBACb,CAAC;YACH,CAAC;QACH,CAAC;QAED,uBAAuB;QACvB,IAAI,MAAM,EAAE,MAAM,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YAC9B,OAAO,EAAE,CAAC;QACZ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,EAAE,gCAAgC,CAAC,CAAC;YACjD,QAAQ,EAAE,CAAC;QACb,CAAC;QAED,uDAAuD;QACvD,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,UAAU,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC;QACrE,IAAI,UAAU,CAAC,cAAc,CAAC,EAAE,CAAC;YAC/B,MAAM,GAAG,GAAG,YAAY,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;YACzD,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;YAC5B,OAAO,EAAE,CAAC;QACZ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,gBAAgB,EAAE,oEAAoE,CAAC,CAAC;YAC7F,QAAQ,EAAE,CAAC;QACb,CAAC;QAED,6BAA6B;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC;QACxC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QACtD,MAAM,WAAW,GACf,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,+BAA+B,CAAC,CAAC;YACnG,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,+BAA+B,CAAC,CAAC,CAAC;QAC5G,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC,WAAW,EAAE,qBAAqB,CAAC,CAAC;YACzC,OAAO,EAAE,CAAC;QACZ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,EAAE,uDAAuD,CAAC,CAAC;YAC3E,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,mBAAmB;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAClC,IAAI,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YACxB,MAAM,UAAU,GAAG,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAClD,IAAI,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;gBACrC,IAAI,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAC;gBAClC,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,EAAE,0DAA0D,CAAC,CAAC;gBACzE,QAAQ,EAAE,CAAC;YACb,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,MAAM,EAAE,uCAAuC,CAAC,CAAC;YACtD,QAAQ,EAAE,CAAC;QACb,CAAC;QAED,2BAA2B;QAC3B,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,kBAAkB,CAAC,CAAC;QAChD,IAAI,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC;YACrB,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;YAC5C,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC/B,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,OAAO,CAAC;YACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,IAAI,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;YACtD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;YAC1C,MAAM,MAAM,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,KAAK,QAAQ,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,QAAQ,OAAO,CAAC;YACtF,IAAI,OAAO,GAAG,CAAC,EAAE,CAAC;gBAChB,IAAI,CAAC,UAAU,EAAE,qBAAqB,MAAM,qCAAqC,CAAC,CAAC;gBACnF,QAAQ,EAAE,CAAC;YACb,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;gBACzB,OAAO,EAAE,CAAC;YACZ,CAAC;QACH,CAAC;aAAM,IAAI,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,UAAU,EAAE,8DAA8D,CAAC,CAAC;YACjF,QAAQ,EAAE,CAAC;QACb,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,2CAA2C,CAAC,CAAC;YAC9D,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,2BAA2B;QAC3B,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,SAAS,EAAE,eAAe,CAAC,CAAC;QAC3D,IAAI,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;YAC7B,MAAM,QAAQ,GAAG,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YACrD,IAAI,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;gBACxC,IAAI,CAAC,aAAa,EAAE,kDAAkD,CAAC,CAAC;gBACxE,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,aAAa,EAAE,4EAA4E,CAAC,CAAC;gBAClG,QAAQ,EAAE,CAAC;YACb,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,EAAE,gEAAgE,CAAC,CAAC;YACtF,QAAQ,EAAE,CAAC;QACb,CAAC;QAED,kBAAkB;QAClB,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,QAAQ,CAAC,wBAAwB,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;YAC1E,IAAI,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;gBACvC,IAAI,CAAC,MAAM,EAAE,iCAAiC,CAAC,CAAC;gBAChD,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,EAAE,0DAA0D,CAAC,CAAC;gBACzE,QAAQ,EAAE,CAAC;YACb,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC,MAAM,EAAE,wCAAwC,CAAC,CAAC;YACvD,QAAQ,EAAE,CAAC;QACb,CAAC;QAED,UAAU;QACV,KAAK,CAAC,6BAA6B,CAAC,CAAC;QACrC,KAAK,CAAC,KAAK,OAAO,YAAY,OAAO,YAAY,QAAQ,aAAa,CAAC,CAAC;QACxE,IAAI,OAAO,KAAK,CAAC,EAAE,CAAC;YAClB,KAAK,CAAC,yBAAyB,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,iEAAiE,CAAC,CAAC;QAC3E,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Command } from "commander";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
import { existsSync, readFileSync } from "node:fs";
|
|
4
|
+
import { hasDb, openDb } from "../util/db.js";
|
|
5
|
+
function write(msg) {
|
|
6
|
+
process.stdout.write(msg);
|
|
7
|
+
}
|
|
8
|
+
function generateFromDb(schemaDir) {
|
|
9
|
+
const db = openDb(schemaDir);
|
|
10
|
+
const rels = db.prepare("SELECT from_table, from_column, to_table, to_column FROM relationships ORDER BY from_table, to_table").all();
|
|
11
|
+
write("erDiagram\n");
|
|
12
|
+
for (const r of rels) {
|
|
13
|
+
write(` ${r.from_table} }o--|| ${r.to_table} : "${r.from_column} -> ${r.to_column}"\n`);
|
|
14
|
+
}
|
|
15
|
+
db.close();
|
|
16
|
+
}
|
|
17
|
+
function generateFromJson(schemaDir) {
|
|
18
|
+
const relsFile = join(schemaDir, "relationships.json");
|
|
19
|
+
if (!existsSync(relsFile)) {
|
|
20
|
+
write("Error: No relationships data found.\n");
|
|
21
|
+
process.exit(1);
|
|
22
|
+
}
|
|
23
|
+
const rels = JSON.parse(readFileSync(relsFile, "utf-8"));
|
|
24
|
+
write("erDiagram\n");
|
|
25
|
+
for (const [from, to] of Object.entries(rels)) {
|
|
26
|
+
const [fromTable, fromCol] = from.split(".");
|
|
27
|
+
const [toTable, toCol] = to.split(".");
|
|
28
|
+
write(` ${fromTable} }o--|| ${toTable} : "${fromCol} -> ${toCol}"\n`);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export function graphCommand() {
|
|
32
|
+
return new Command("graph")
|
|
33
|
+
.description("Output mermaid erDiagram of table relationships from snapshot")
|
|
34
|
+
.option("--dir <dir>", "Schema directory", ".supabase-schema")
|
|
35
|
+
.action((opts) => {
|
|
36
|
+
const schemaDir = join(process.cwd(), opts.dir);
|
|
37
|
+
if (!existsSync(schemaDir)) {
|
|
38
|
+
write("Error: No schema snapshot found. Run `supabase-skill snapshot` first.\n");
|
|
39
|
+
process.exit(1);
|
|
40
|
+
}
|
|
41
|
+
if (hasDb(schemaDir)) {
|
|
42
|
+
generateFromDb(schemaDir);
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
generateFromJson(schemaDir);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=graph.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph.js","sourceRoot":"","sources":["../../src/commands/graph.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE9C,SAAS,KAAK,CAAC,GAAW;IACxB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;AAC5B,CAAC;AASD,SAAS,cAAc,CAAC,SAAiB;IACvC,MAAM,EAAE,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IAC7B,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CACrB,sGAAsG,CACvG,CAAC,GAAG,EAAc,CAAC;IAEpB,KAAK,CAAC,aAAa,CAAC,CAAC;IACrB,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QACrB,KAAK,CAAC,KAAK,CAAC,CAAC,UAAU,WAAW,CAAC,CAAC,QAAQ,OAAO,CAAC,CAAC,WAAW,OAAO,CAAC,CAAC,SAAS,KAAK,CAAC,CAAC;IAC3F,CAAC;IAED,EAAE,CAAC,KAAK,EAAE,CAAC;AACb,CAAC;AAED,SAAS,gBAAgB,CAAC,SAAiB;IACzC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,oBAAoB,CAAC,CAAC;IACvD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,KAAK,CAAC,uCAAuC,CAAC,CAAC;QAC/C,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAED,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAA2B,CAAC;IAEnF,KAAK,CAAC,aAAa,CAAC,CAAC;IACrB,KAAK,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;QAC9C,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7C,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACvC,KAAK,CAAC,KAAK,SAAS,WAAW,OAAO,OAAO,OAAO,OAAO,KAAK,KAAK,CAAC,CAAC;IACzE,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY;IAC1B,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC;SACxB,WAAW,CAAC,+DAA+D,CAAC;SAC5E,MAAM,CAAC,aAAa,EAAE,kBAAkB,EAAE,kBAAkB,CAAC;SAC7D,MAAM,CAAC,CAAC,IAAqB,EAAE,EAAE;QAChC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QAEhD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC3B,KAAK,CAAC,yEAAyE,CAAC,CAAC;YACjF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,IAAI,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC;YACrB,cAAc,CAAC,SAAS,CAAC,CAAC;QAC5B,CAAC;aAAM,CAAC;YACN,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
package/dist/commands/init.js
CHANGED
|
@@ -5,6 +5,7 @@ import { execSync } from "node:child_process";
|
|
|
5
5
|
import { upsertSection } from "../util/claude-md.js";
|
|
6
6
|
import { readConfig } from "../util/config.js";
|
|
7
7
|
import { getSkillDoc } from "./docs.js";
|
|
8
|
+
import { walkthroughTemplate } from "../templates/walkthrough.js";
|
|
8
9
|
function write(msg) {
|
|
9
10
|
process.stdout.write(msg);
|
|
10
11
|
}
|
|
@@ -36,6 +37,13 @@ export function initCommand() {
|
|
|
36
37
|
const dotClaudeMd = join(dotClaudeDir, "CLAUDE.md");
|
|
37
38
|
const dotResult = upsertSection(dotClaudeMd, skillDoc);
|
|
38
39
|
write(` .claude/CLAUDE.md: ${dotResult}\n`);
|
|
40
|
+
// Write walkthrough skill
|
|
41
|
+
const skillsDir = join(dotClaudeDir, "skills");
|
|
42
|
+
if (!existsSync(skillsDir))
|
|
43
|
+
mkdirSync(skillsDir, { recursive: true });
|
|
44
|
+
const walkthroughPath = join(skillsDir, "supabase-walkthrough.md");
|
|
45
|
+
writeFileSync(walkthroughPath, walkthroughTemplate);
|
|
46
|
+
write(` .claude/skills/supabase-walkthrough.md: written\n`);
|
|
39
47
|
// ─── 2. .env (secrets) ───
|
|
40
48
|
write("\n 2/5 Writing .env with API keys...\n");
|
|
41
49
|
const envPath = join(cwd, ".env");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC7F,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,43 @@
|
|
|
1
1
|
import { Command } from "commander";
|
|
2
|
+
interface ColumnDef {
|
|
3
|
+
description?: string;
|
|
4
|
+
format?: string;
|
|
5
|
+
type?: string;
|
|
6
|
+
default?: string;
|
|
7
|
+
maxLength?: number;
|
|
8
|
+
enum?: string[];
|
|
9
|
+
items?: {
|
|
10
|
+
type?: string;
|
|
11
|
+
format?: string;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
interface TableDef {
|
|
15
|
+
required?: string[];
|
|
16
|
+
properties: Record<string, ColumnDef>;
|
|
17
|
+
type: string;
|
|
18
|
+
}
|
|
19
|
+
interface RpcParam {
|
|
20
|
+
name: string;
|
|
21
|
+
in: string;
|
|
22
|
+
required?: boolean;
|
|
23
|
+
schema?: {
|
|
24
|
+
type?: string;
|
|
25
|
+
format?: string;
|
|
26
|
+
properties?: Record<string, unknown>;
|
|
27
|
+
};
|
|
28
|
+
type?: string;
|
|
29
|
+
format?: string;
|
|
30
|
+
}
|
|
31
|
+
interface RpcEndpoint {
|
|
32
|
+
post?: {
|
|
33
|
+
parameters?: RpcParam[];
|
|
34
|
+
description?: string;
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
interface OpenAPISpec {
|
|
38
|
+
definitions: Record<string, TableDef>;
|
|
39
|
+
paths: Record<string, RpcEndpoint>;
|
|
40
|
+
}
|
|
41
|
+
export declare function fetchOpenAPISpec(projectRef: string, schema: string): OpenAPISpec;
|
|
2
42
|
export declare function snapshotCommand(): Command;
|
|
43
|
+
export {};
|