* Add Cloudflare generator with Wrangler and OpenNext support This update introduces a new Cloudflare generator to streamline configuration and deployment via Wrangler and OpenNext. It registers the necessary templates, modifies project files, and adds Cloudflare-specific scripts and dependencies to the package.json. Additionally, .hbs files are updated in .prettierignore for formatting consistency. * Add GitHub username prompt and improve setup scripts Introduce a prompt for GitHub username to personalize project setup. Enhance the setup scripts by adding PNPM verification, configuring `upstream` remote, and removing the `origin` remote. Adjust health check and error handling for better reliability. * Add Dockerfile generator to turbo generators Introduced a new generator to create Dockerfile configurations for standalone Next.js applications. This includes modifying `next.config.mjs` for standalone output, updating dependencies in `package.json`, and adding a Dockerfile template. The generator is now registered in the turbo setup. * Add console-based logger implementation. This is required for edge environments such as Cloudflare. * Remove deprecated Supabase client utilities The `server-actions-client`, `route-handler-client`, and `server-component-client` utilities have been removed in favor of `getSupabaseServerClient`. This simplifies and consolidates the API, ensuring consistency across server-side usage. Version bumped to 2.9.0 to reflect breaking changes.
81 lines
1.9 KiB
TypeScript
81 lines
1.9 KiB
TypeScript
import type { PlopTypes } from '@turbo/gen';
|
|
import { execSync } from 'node:child_process';
|
|
import * as os from 'node:os';
|
|
|
|
export function createDockerGenerator(plop: PlopTypes.NodePlopAPI) {
|
|
plop.setGenerator('docker', {
|
|
description: 'Dockerfile generator',
|
|
actions: [
|
|
{
|
|
type: 'modify',
|
|
path: 'apps/web/next.config.mjs',
|
|
transform(content) {
|
|
// Check if the output is already set to standalone
|
|
if (content.includes('output: "standalone"')) {
|
|
return content;
|
|
}
|
|
|
|
return content.replace(
|
|
'const config = {',
|
|
'const config = { output: "standalone",',
|
|
);
|
|
},
|
|
},
|
|
{
|
|
type: 'modify',
|
|
path: 'apps/web/package.json',
|
|
transform(content) {
|
|
const pkg = JSON.parse(content);
|
|
const deps = getDeps();
|
|
|
|
if (deps.length === 0) {
|
|
return content;
|
|
}
|
|
|
|
for (const dep of deps) {
|
|
pkg['devDependencies'][dep] = 'latest';
|
|
}
|
|
|
|
return JSON.stringify(pkg, null, 2);
|
|
},
|
|
},
|
|
{
|
|
type: 'add',
|
|
templateFile: 'templates/docker/Dockerfile.hbs',
|
|
path: 'Dockerfile',
|
|
},
|
|
async () => {
|
|
execSync('pnpm i', {
|
|
stdio: 'inherit',
|
|
})
|
|
|
|
execSync('pnpm format:fix', {
|
|
stdio: 'inherit',
|
|
});
|
|
|
|
return 'Dockerfile generated';
|
|
},
|
|
],
|
|
prompts: [],
|
|
});
|
|
}
|
|
|
|
function getDeps() {
|
|
const arch = os.arch();
|
|
|
|
if (arch === 'arm64') {
|
|
return [
|
|
'lightningcss-linux-arm64-musl',
|
|
'@tailwindcss/oxide-linux-arm64-musl',
|
|
];
|
|
} else if (arch === 'x64') {
|
|
const isMusl = process.config?.variables?.hasOwnProperty('musl');
|
|
|
|
return isMusl
|
|
? ['lightningcss-linux-x64-musl', '@tailwindcss/oxide-linux-x64-musl']
|
|
: ['lightningcss-linux-x64-gnu', '@tailwindcss/oxide-linux-x64-gnu'];
|
|
} else {
|
|
return [];
|
|
}
|
|
}
|