support setting for writing supabase migration files (#427)
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
import fs from "node:fs";
|
||||
import { promises as fsPromises } from "node:fs";
|
||||
import path from "node:path";
|
||||
import fsExtra from "fs-extra";
|
||||
import { generateCuteAppName } from "../../lib/utils";
|
||||
|
||||
/**
|
||||
* Recursively gets all files in a directory, excluding node_modules and .git
|
||||
@@ -57,3 +59,36 @@ export async function copyDirectoryRecursive(
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export async function writeMigrationFile(
|
||||
appPath: string,
|
||||
queryContent: string,
|
||||
queryDescription?: string,
|
||||
) {
|
||||
const migrationsDir = path.join(appPath, "supabase", "migrations");
|
||||
await fsExtra.ensureDir(migrationsDir);
|
||||
|
||||
const files = await fsExtra.readdir(migrationsDir);
|
||||
const migrationNumbers = files
|
||||
.map((file) => {
|
||||
const match = file.match(/^(\d{4})_/);
|
||||
return match ? parseInt(match[1], 10) : -1;
|
||||
})
|
||||
.filter((num) => num !== -1);
|
||||
|
||||
const nextMigrationNumber =
|
||||
migrationNumbers.length > 0 ? Math.max(...migrationNumbers) + 1 : 0;
|
||||
const paddedNumber = String(nextMigrationNumber).padStart(4, "0");
|
||||
|
||||
let description = "migration";
|
||||
if (queryDescription) {
|
||||
description = queryDescription.toLowerCase().replace(/[\s\W-]+/g, "_");
|
||||
} else {
|
||||
description = generateCuteAppName().replace(/-/g, "_");
|
||||
}
|
||||
|
||||
const migrationFileName = `${paddedNumber}_${description}.sql`;
|
||||
const migrationFilePath = path.join(migrationsDir, migrationFileName);
|
||||
|
||||
await fsExtra.writeFile(migrationFilePath, queryContent);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user