@makerkit/cli 1.3.18 → 2.0.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.
- package/README.md +156 -54
- package/dist/index.js +1590 -703
- package/dist/index.js.map +1 -1
- package/dist/mcp.js +1508 -0
- package/dist/mcp.js.map +1 -0
- package/package.json +22 -18
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/commands/i18n/i18n-service.ts","../src/utils/openai-client.ts","../src/utils/workspace.ts","../src/plugins-model.ts","../src/kits-model.ts","../src/commands/i18n/translate/translate.command.ts","../src/commands/i18n/verify/verify.command.ts","../src/commands/i18n/i18n.command.ts","../src/commands/license/activate/activate-license.command.ts","../src/commands/license/license.command.ts","../src/commands/new/new.command.ts","../src/commands/plugins/plugins-service.ts","../src/commands/plugins/install/install-plugin.command.ts","../src/commands/plugins/list/list-plugins.command.ts","../src/commands/plugins/update/update-plugin.command.ts","../src/commands/plugins/plugins.command.ts","../src/index.ts"],"sourcesContent":["import { join } from 'path';\nimport getOpenAIClient from '@/src/utils/openai-client';\nimport { Workspace } from '@/src/utils/workspace';\nimport chalk from 'chalk';\nimport fs from 'fs-extra';\nimport OpenAI from 'openai';\n\ntype NestedKey = Record<string, string | Record<string, string>>;\n\nexport class I18nService {\n /**\n * @name verify\n * @description Verifies if the locale files are in sync\n */\n static async verify(base = 'en') {\n const kit = await Workspace.getKitMeta();\n\n const allLocales = fs.readdirSync(kit.localePath).filter((locale) => {\n return locale !== base;\n });\n\n const baseLocaleFolderPath = `${kit.localePath}/${base}`;\n\n const localeFiles = fs.readdirSync(baseLocaleFolderPath).filter((file) => {\n return file.endsWith('.json');\n });\n\n for (const localeFile of localeFiles) {\n for (const locale of allLocales) {\n const baseLocaleFilePath = `${baseLocaleFolderPath}/${localeFile}`;\n const targetLocaleFilePath = `${kit.localePath}/${locale}/${localeFile}`;\n\n const baseLocaleFile = fs.readJSONSync(baseLocaleFilePath);\n const file = fs.readJSONSync(targetLocaleFilePath);\n\n const missingKeys = collectMissingKeys([baseLocaleFile, file]);\n\n if (!missingKeys.length) {\n console.log(\n chalk.green(`Locale ${locale}/${localeFile} is in sync!`)\n );\n\n continue;\n }\n\n console.log(\n chalk.yellow(\n `Locale ${locale}/${localeFile} is missing the following keys: ${missingKeys.join(\n ', '\n )}`\n )\n );\n }\n }\n }\n\n /**\n * @name translate\n * @description Translates the locale files from source to target\n * @param source\n * @param target\n */\n static async translate(source: string, target: string) {\n const kit = await Workspace.getKitMeta();\n const client = getOpenAIClient();\n\n const targetJsonPath = `${kit.localePath}/${target}`;\n const sourceLocalePath = `${kit.localePath}/${source}`;\n\n const sourceLocale = await fs.exists(sourceLocalePath);\n\n if (!sourceLocale) {\n throw new Error(`Source locale at ${sourceLocalePath} not found`);\n }\n\n const files = fs.readdirSync(sourceLocalePath).filter((file) => {\n return file.endsWith('.json');\n });\n\n console.log(`Found the following files: ${files.join(', ')}`);\n\n for (const file of files) {\n const data: Record<string, string | Record<string, string | NestedKey>> =\n {};\n\n const localeFile = fs.readJSONSync(join(sourceLocalePath, file));\n\n console.log(\n chalk.cyan(`Translating \"${file}\". This can take a while...`)\n );\n\n for (const key in localeFile) {\n data[key] = await translateKey(source, target, localeFile[key], client);\n }\n\n console.log(chalk.green(`File \"${file}\" successfully translated!`));\n console.log(chalk.cyan(`Writing file \"${file}\" to ${targetJsonPath}`));\n\n // check if targetJsonPath exists, if not, create it\n (await fs.exists(targetJsonPath)) || (await fs.mkdir(targetJsonPath));\n\n // write file to targetJsonPath\n await fs.writeJSON(join(targetJsonPath, file), data, {});\n\n console.log(chalk.green(`File \"${file}\" successfully written!`));\n }\n }\n}\n\nasync function translateKey(\n source: string,\n target: string,\n key: string | NestedKey,\n client: OpenAI\n) {\n if (typeof key === 'string') {\n return translateString(source, target, key, client);\n }\n\n const data: Record<string, string | NestedKey> = {};\n\n for (const k in key) {\n data[k] = (await translateKey(source, target, key[k], client)) as NestedKey;\n }\n\n return data;\n}\n\nasync function translateString(\n source: string,\n target: string,\n key: string,\n client: OpenAI\n) {\n // skip empty or short keys\n if (!key.trim() || key.length <= 1) {\n return '';\n }\n\n const response = await client.chat.completions.create({\n model: 'gpt-3.5-turbo',\n max_tokens: target.split(' ').length + 50,\n temperature: 0.3,\n messages: [\n {\n role: 'user',\n content: `Translate the text from locale ${source} to ${target}. Text: ${key}. Translation:`,\n },\n ],\n });\n\n return response.choices[0].message.content ?? '';\n}\n\ntype JSONObject = { [key: string]: any };\n\nfunction collectMissingKeys(objects: JSONObject[]): string[] {\n const allKeys: string[] = [];\n\n objects.forEach((obj) => {\n Object.keys(obj).forEach((key) => {\n if (!allKeys.includes(key)) {\n allKeys.push(key);\n }\n });\n });\n\n const missingKeys: string[] = [];\n\n objects.forEach((obj) => {\n allKeys.forEach((key) => {\n if (!Object.keys(obj).includes(key)) {\n missingKeys.push(key);\n }\n });\n });\n\n return missingKeys;\n}\n","import OpenAI from 'openai';\n\nfunction getOpenAIClient() {\n const apiKey = process.env.OPENAI_API_KEY;\n\n if (!apiKey) {\n throw new Error(\n 'OPENAI_API_KEY env variable is not set. Please set it in' +\n ' your .env.local file of your Makerkit workspace.'\n );\n }\n\n return new OpenAI({ apiKey });\n}\n\nexport default getOpenAIClient;\n","import { join } from 'path';\nimport { KitsModel } from '@/src/kits-model';\nimport chalk from 'chalk';\nimport fs from 'fs-extra';\n\nexport class Workspace {\n static async getKitMeta() {\n const packageJson = await getPackageJson();\n const kit = await detectKitVersion();\n\n return {\n ...kit,\n version: packageJson.version ?? 'unknown',\n };\n }\n\n static async logWorkspaceInfo() {\n const meta = await Workspace.getKitMeta();\n\n console.log(\n `Makerkit version: ${chalk.cyan(meta.name)} - ${chalk.cyan(\n meta.version ?? 'unknown'\n )}.\\n`\n );\n }\n}\n\nasync function detectKitVersion() {\n let packageJson = await getPackageJson();\n\n if (!packageJson) {\n throw new Error(\n 'No package.json found. Please run this command in a Makerkit workspace.'\n );\n }\n\n let deps = Object.keys(packageJson.dependencies ?? []);\n\n if (deps.length === 0) {\n deps = Object.keys(packageJson.devDependencies ?? []);\n }\n\n if (deps.includes('turbo')) {\n // locate apps/web\n packageJson = await fs.readJSON(\n join(process.cwd(), 'apps/web/package.json')\n );\n\n deps = Object.keys(packageJson.dependencies ?? []);\n\n if (deps.includes('next')) {\n return KitsModel.NextJsSupabaseTurbo;\n }\n\n if (deps.includes('@remix-run/react')) {\n return KitsModel.RemixSupabaseTurbo;\n }\n }\n\n if (deps.includes('next') && deps.includes('firebase')) {\n return KitsModel.NextJsFirebase;\n }\n\n if (deps.includes('next') && deps.includes('@supabase/supabase-js')) {\n return KitsModel.NextJsSupabase;\n }\n\n if (\n deps.includes('@remix-run/react') &&\n deps.includes('@supabase/supabase-js')\n ) {\n return KitsModel.RemixSupabase;\n }\n\n throw new Error(\n 'Could not detect Makerkit workspace. Please run this command in a Makerkit workspace.'\n );\n}\n\nasync function getPackageJson(): Promise<Record<string, unknown>> {\n return fs\n .readJSON(join(process.cwd(), 'package.json'))\n .catch(() => undefined);\n}\n","import invariant from 'tiny-invariant';\n\nexport const PluginsModel = {\n CookieBanner: {\n name: `Cookie Banner`,\n id: `cookie-banner`,\n branch: `cookie-banner`,\n description: `Add a cookie banner to your site.`,\n folder: `plugins/cookie-banner`,\n },\n AiChatBot: {\n name: `AI Chatbot`,\n id: `chatbot-v1`,\n branch: `chatbot`,\n description: `Add an AI Chatbot to your site.`,\n folder: `plugins/chatbot`,\n },\n FeedbackPopup: {\n name: `Feedback Popup`,\n id: `feedback-popup-v1`,\n branch: `feedback-popup`,\n description: `Add a feedback popup to your site.`,\n folder: `plugins/feedback-popup`,\n },\n AiTextEditor: {\n name: `AI Text Editor`,\n id: `text-editor-v1`,\n branch: `text-editor`,\n description: `Add an AI Text Editor to your site.`,\n folder: `plugins/text-editor`,\n },\n AiTextEditorTurbo: {\n name: `AI Text Editor`,\n id: `text-editor`,\n branch: `text-editor`,\n description: `Add an AI Text Editor to your site.`,\n folder: `packages/plugins/text-editor`,\n },\n Waitlist: {\n name: `Waitlist`,\n id: `waitlist`,\n branch: `waitlist`,\n description: `Add a waitlist to your site.`,\n folder: `packages/plugins/waitlist`,\n },\n FeedbackPopupTurbo: {\n name: `Feedback Popup`,\n id: `feedback`,\n branch: `feedback`,\n description: `Add a feedback popup to your site.`,\n folder: `packages/plugins/feedback`,\n },\n AiChatBotTurbo: {\n name: `AI Chatbot`,\n id: `chatbot`,\n branch: `chatbot`,\n description: `Add an AI Chatbot to your site.`,\n folder: `packages/plugins/chatbot`,\n },\n Testimonial: {\n name: `Testimonial`,\n id: `testimonial`,\n branch: `testimonial`,\n description: `Add a testimonial to your site.`,\n folder: `packages/plugins/testimonial`,\n },\n Roadmap: {\n name: `Roadmap`,\n id: `roadmap`,\n branch: `roadmap`,\n description: `Add a Roadmap to your site.`,\n folder: `packages/plugins/roadmap`,\n },\n Kanban: {\n name: `Kanban`,\n id: `kanban`,\n branch: `kanban`,\n description: `Add a Kanban component to your site.`,\n folder: `packages/plugins/kanban`,\n },\n GoogleAnalytics: {\n name: `Google Analytics`,\n id: `google-analytics`,\n branch: `google-analytics`,\n description: `Add Google Analytics to your site.`,\n folder: `packages/plugins/analytics/google-analytics`,\n },\n Posthog: {\n name: `Posthog`,\n id: `posthog`,\n branch: `posthog`,\n description: `Add Posthog Analytics to your site.`,\n folder: `packages/plugins/analytics/posthog`,\n },\n Umami: {\n name: `Umami`,\n id: `umami`,\n branch: `umami`,\n description: `Add Umami Analytics to your site.`,\n folder: `packages/plugins/analytics/umami`,\n },\n Signoz: {\n name: `Signoz`,\n id: `signoz`,\n branch: `signoz`,\n description: `Add Signoz Monitoring to your app.`,\n folder: `packages/plugins/signoz`,\n },\n Paddle: {\n name: `Paddle`,\n id: `paddle`,\n branch: `paddle`,\n description: `Add Paddle Billing to your app.`,\n folder: `packages/plugins/paddle`,\n },\n SupabaseCMS: {\n name: `Supabase CMS`,\n id: `supabase-cms`,\n branch: `supabase-cms`,\n description: `Add Supabase CMS provider to your app.`,\n folder: `packages/plugins/supabase-cms`,\n }\n};\n\nexport function getPluginById(id: string) {\n return Object.values(PluginsModel).find((plugin) => plugin.id === id);\n}\n\nexport function validatePlugin(pluginId: string) {\n const plugin = getPluginById(pluginId);\n\n invariant(plugin, `Plugin ${pluginId} not found`);\n\n return plugin;\n}\n","import { PluginsModel } from '@/src/plugins-model';\nimport invariant from 'tiny-invariant';\n\nexport const KitsModel = {\n NextJsFirebase: {\n name: `Next.js Firebase`,\n id: `next-firebase`,\n repository: `git@github.com:makerkit/next-firebase-saas-kit`,\n blogPath: `_posts`,\n localePath: `public/locales`,\n plugins: [\n PluginsModel.CookieBanner.id,\n PluginsModel.AiChatBot.id,\n PluginsModel.FeedbackPopup.id,\n ],\n },\n NextJsSupabase: {\n name: `Next.js Supabase`,\n id: `next-supabase`,\n localePath: `public/locales`,\n blogPath: `src/content/posts`,\n repository: `git@github.com:makerkit/next-supabase-saas-kit`,\n plugins: [\n PluginsModel.AiChatBot.id,\n PluginsModel.FeedbackPopup.id,\n PluginsModel.CookieBanner.id,\n PluginsModel.AiTextEditor.id,\n ],\n },\n NextJsSupabaseTurbo: {\n name: `Next.js Supabase Turbo`,\n id: `next-supabase-turbo`,\n localePath: `apps/web/public/locales`,\n blogPath: `apps/web/content/posts`,\n repository: `git@github.com:makerkit/next-supabase-saas-kit-turbo`,\n plugins: [\n PluginsModel.Waitlist.id,\n PluginsModel.Testimonial.id,\n PluginsModel.Roadmap.id,\n PluginsModel.Kanban.id,\n PluginsModel.AiChatBotTurbo.id,\n PluginsModel.FeedbackPopupTurbo.id,\n PluginsModel.AiTextEditorTurbo.id,\n PluginsModel.GoogleAnalytics.id,\n PluginsModel.Posthog.id,\n PluginsModel.Umami.id,\n PluginsModel.Signoz.id,\n PluginsModel.Paddle.id,\n PluginsModel.SupabaseCMS.id\n ],\n },\n RemixSupabaseTurbo: {\n name: `Remix Supabase Turbo`,\n id: `remix-supabase-turbo`,\n localePath: `apps/web/public/locales`,\n blogPath: `apps/web/content/posts`,\n repository: `git@github.com:makerkit/remix-supabase-saas-kit-turbo`,\n plugins: [\n PluginsModel.Waitlist.id,\n PluginsModel.Testimonial.id,\n PluginsModel.AiChatBotTurbo.id,\n PluginsModel.FeedbackPopupTurbo.id,\n PluginsModel.AiTextEditorTurbo.id,\n PluginsModel.GoogleAnalytics.id,\n PluginsModel.Posthog.id,\n PluginsModel.Umami.id,\n ],\n },\n NextJsSupabaseLite: {\n name: `Next.js Supabase Lite`,\n id: `next-supabase-lite`,\n localePath: `public/locales`,\n blogPath: `src/content/posts`,\n repository: `git@github.com:makerkit/next-supabase-saas-kit-lite`,\n plugins: [],\n },\n RemixFirebase: {\n name: `Remix Firebase`,\n id: `remix-firebase`,\n localePath: `public/locales`,\n blogPath: '',\n repository: `git@github.com:makerkit/remix-firebase-saas-kit`,\n plugins: [],\n },\n RemixSupabase: {\n name: `Remix Supabase`,\n id: `remix-supabase`,\n localePath: `public/locales`,\n blogPath: `app/content/posts`,\n repository: `git@github.com:makerkit/remix-supabase-saas-kit`,\n plugins: [\n PluginsModel.AiChatBot.id,\n PluginsModel.FeedbackPopup.id,\n PluginsModel.CookieBanner.id,\n PluginsModel.AiTextEditor.id,\n ],\n },\n};\n\nexport function getKitById(id: string) {\n return Object.values(KitsModel).find((kit) => kit.id === id);\n}\n\nexport function validateKit(kitId: string) {\n const kit = getKitById(kitId);\n\n invariant(kit, `Kit ${kitId} not found`);\n\n return kit;\n}\n","import { I18nService } from '@/src/commands/i18n/i18n-service';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport prompts from 'prompts';\n\nexport function createTranslateI18nCommand(parentCommand: Command) {\n return parentCommand\n .command('translate')\n .argument('[source-locale]', 'Source Locale')\n .argument('[target-locale]', 'Target Locale')\n .description('Translate i18n files from source locale to target locale')\n .action(async (sourceLocale, targetLocale) => {\n const locales = await promptLocales(sourceLocale, targetLocale);\n\n await I18nService.translate(locales.sourceLocale, locales.targetLocale);\n });\n}\n\nasync function promptLocales(maybeSource?: string, maybeTarget?: string) {\n const hint = 'e.g. en, fr, es, etc.';\n\n const sourceLocale =\n maybeSource ||\n (\n await prompts([\n {\n type: 'text',\n name: 'locale',\n message: `Enter your ${chalk.cyan('Source Locale')}. ${hint}`,\n hint,\n },\n ])\n ).locale;\n\n const targetLocale =\n maybeTarget ||\n (\n await prompts([\n {\n type: 'text',\n name: 'locale',\n message: `Enter your ${chalk.cyan('Target Locale')}. ${hint}`,\n hint,\n },\n ])\n ).locale;\n\n return {\n sourceLocale,\n targetLocale,\n };\n}\n","import { I18nService } from '@/src/commands/i18n/i18n-service';\nimport { Command } from 'commander';\n\nexport function createVerifyI18nCommand(parentCommand: Command) {\n return parentCommand\n .command('verify')\n .argument('[base-locale]', 'Base Locale')\n .description(\n 'Verify i18n files have no missing keys compared to base locale'\n )\n .action(async (baseLocale = 'en') => {\n await I18nService.verify(baseLocale);\n });\n}\n","import { createTranslateI18nCommand } from '@/src/commands/i18n/translate/translate.command';\nimport { createVerifyI18nCommand } from '@/src/commands/i18n/verify/verify.command';\nimport { Workspace } from '@/src/utils/workspace';\nimport { Command } from 'commander';\n\nexport const i18nCommand = new Command()\n .name('i18n')\n .description('Manage and translate your i18n files')\n .hook('preAction', () => {\n return Workspace.logWorkspaceInfo();\n });\n\n// set children commands\ncreateTranslateI18nCommand(i18nCommand);\ncreateVerifyI18nCommand(i18nCommand);\n","import chalk from 'chalk';\nimport { Command } from 'commander';\nimport ora from 'ora';\nimport prompts from 'prompts';\nimport { z } from 'zod';\n\nconst schema = z.object({\n licenseKey: z.string().min(1).max(32),\n githubUsername: z.string().min(1).max(64),\n});\n\nexport function createActivateLicenseCommand(parentCommand: Command) {\n return parentCommand\n .command('activate')\n .description('Activate your license key for MakerKit')\n .action(async () => {\n const params = await prompts([\n {\n type: 'text',\n name: 'licenseKey',\n message: `Enter your ${chalk.cyan('License Key')}.`,\n validate: (value) => {\n if (value.length < 1) {\n return `Please enter a valid license key`;\n }\n\n return true;\n },\n },\n {\n type: 'text',\n name: 'githubUsername',\n message: `Enter your ${chalk.cyan('Github username')}.`,\n validate: (value) => {\n if (value.length < 1) {\n return `Please enter a valid username`;\n }\n\n return true;\n },\n },\n ]);\n\n const spinner = ora(`Activating license...`).start();\n\n const onError = () => {\n spinner.fail(`Failed to activate license`);\n process.exit(1);\n };\n\n try {\n const response = await activateLicense(schema.parse(params));\n\n if (!response.ok) {\n return onError();\n }\n\n spinner.succeed(`License activated successfully`);\n } catch (e) {\n onError();\n }\n });\n}\n\nasync function activateLicense(params: {\n licenseKey: string;\n githubUsername: string;\n}) {\n return fetch(`https://makerkit.dev/api/ls/license/activate`, {\n method: 'POST',\n body: JSON.stringify(params),\n });\n}\n","import { createActivateLicenseCommand } from '@/src/commands/license/activate/activate-license.command';\nimport { Command } from 'commander';\n\nexport const licenseCommand = new Command()\n .name('license')\n .description('Manage Licenses');\n\ncreateActivateLicenseCommand(licenseCommand);\n","import { join } from 'path';\nimport { KitsModel, validateKit } from '@/src/kits-model';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport { execa } from 'execa';\nimport ora from 'ora';\nimport prompts from 'prompts';\n\nexport const newCommand = new Command()\n .name('new')\n .description('Initialize a new Makerkit project')\n .action(async () => {\n const choices = Object.values(KitsModel).map((kit) => {\n return {\n title: kit.name,\n value: kit.id,\n };\n });\n\n const { kit, name: projectName } = await prompts([\n {\n type: 'select',\n name: 'kit',\n message: `Select the ${chalk.cyan(`SaaS Kit`)} you want to clone`,\n choices,\n },\n {\n type: 'text',\n name: 'name',\n message: `Enter your ${chalk.cyan('Project Name')}.`,\n },\n ]);\n\n const { repository, name: kitName } = validateKit(kit);\n\n const { confirm } = await prompts([\n {\n type: 'confirm',\n name: 'confirm',\n message: `Are you sure you want to clone ${chalk.cyan(\n kitName\n )} to ${chalk.cyan(projectName)}?`,\n },\n ]);\n\n if (!confirm) {\n console.log('Aborting...');\n process.exit(0);\n }\n\n // pull repository from github\n await pullFromGithub(repository, kitName, projectName);\n\n // install dependencies\n await installDependencies(projectName);\n });\n\nasync function pullFromGithub(\n repository: string,\n kit: string,\n projectName: string\n) {\n const spinner = ora(`Cloning ${kit}...`).start();\n\n try {\n await execa('git', ['clone', repository, projectName]);\n\n spinner.succeed(`Cloned ${kit} to ${projectName}...`);\n } catch (e) {\n console.error(e);\n spinner.fail(`Failed to clone ${kit}`);\n\n return Promise.reject(`Failed to clone ${kit}`);\n }\n}\n\nasync function installDependencies(projectName: string) {\n const cwd = join(process.cwd(), projectName);\n const spinner = ora(`Installing dependencies. Please wait...`).start();\n\n try {\n await execa('npm', ['install'], { cwd });\n\n spinner.succeed(`Dependencies successfully installed!`);\n\n console.log(\n `🎉 You can now get started. Open the project in your IDE and read the README.md file for more information.`\n );\n } catch (e) {\n console.error(e);\n spinner.fail(`Failed to install dependencies`);\n\n return Promise.reject(`Failed to install dependencies`);\n }\n}\n","import { validateKit } from '@/src/kits-model';\nimport { PluginsModel, validatePlugin } from '@/src/plugins-model';\nimport { Workspace } from '@/src/utils/workspace';\nimport chalk from 'chalk';\nimport { execaCommand } from 'execa';\nimport ora from 'ora';\nimport prompts from 'prompts';\n\nenum PluginAction {\n Add = 'add',\n Pull = 'pull',\n}\n\nexport class PluginsService {\n static async install(pluginId?: string) {\n const action = PluginAction.Add;\n const plugin = pluginId || (await getPluginFromPrompts(action));\n\n await initPluginCommand(plugin, action);\n }\n\n static async pull(pluginId?: string) {\n const action = PluginAction.Pull;\n const plugin = pluginId || (await getPluginFromPrompts(action));\n\n await initPluginCommand(plugin, action);\n }\n}\n\nasync function initPluginCommand(pluginId: string, action: PluginAction) {\n const { id: kitId } = await Workspace.getKitMeta();\n\n const plugin = validatePlugin(pluginId);\n const kit = validateKit(kitId);\n\n if (!(kit.plugins as string[]).includes(plugin.id)) {\n throw new Error(\n `Plugin ${plugin.name} is not compatible with kit ${kit.name}`\n );\n }\n\n const repository = buildPluginRepositoryName(kit.repository);\n const verb = action === PluginAction.Add ? 'Installing' : 'Updating';\n\n console.log(\n `${verb} ${chalk.cyan(plugin.name)} to kit ${chalk.cyan(\n kit.name\n )} using repo: ${repository} ...`\n );\n\n return executePluginCommand({\n action,\n repository,\n branch: plugin.branch,\n folder: plugin.folder,\n });\n}\n\nasync function getPluginFromPrompts(action: PluginAction) {\n const kit = await Workspace.getKitMeta();\n\n const choices = Object.values(PluginsModel)\n .filter((plugin) => {\n return kit.plugins.includes(plugin.id);\n })\n .map((plugin) => {\n return {\n title: plugin.name,\n value: plugin.id,\n };\n });\n\n const verb = action === PluginAction.Add ? 'install' : 'update';\n\n const { plugin } = await prompts([\n {\n type: 'select',\n name: 'plugin',\n message: `Which ${chalk.cyan('Plugin')} would you like to ${verb}?`,\n choices,\n },\n ]);\n\n return plugin;\n}\n\n// the plugin repository name is the kit repository name + `-plugins`\nfunction buildPluginRepositoryName(repository: string) {\n return repository + `-plugins.git`;\n}\n\nasync function executePluginCommand({\n action,\n repository,\n branch,\n folder,\n}: {\n action: PluginAction;\n repository: string;\n branch: string;\n folder: string;\n}) {\n const verb = action === PluginAction.Add ? 'Installing' : 'Updating';\n const spinner = ora(`${verb} plugin...`).start();\n const commandString = `git subtree ${action} --prefix ${folder} ${repository} ${branch} --squash`;\n\n try {\n await execaCommand(commandString);\n\n const verb = action === PluginAction.Add ? 'installed' : 'updated';\n spinner.succeed(`Plugin ${verb} at ${folder}`);\n } catch (e) {\n console.error(e);\n\n const verb = action === PluginAction.Add ? 'installation' : 'update';\n spinner.fail(`Plugin ${verb} failed`);\n }\n}\n","import { PluginsService } from '@/src/commands/plugins/plugins-service';\nimport { Command } from 'commander';\n\nexport function createInstallPluginCommand(parentCommand: Command) {\n return parentCommand\n .command('install')\n .argument('[plugin-id]', 'Plugin id')\n .description('Install plugin')\n .action(async (maybePluginId) => {\n await PluginsService.install(maybePluginId);\n });\n}\n","import { KitsModel } from '@/src/kits-model';\nimport { validatePlugin } from '@/src/plugins-model';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\n\nexport function createListPluginsCommand(parentCommand: Command) {\n return parentCommand\n .command('list')\n .description('List available plugins.')\n .action(() => {\n const kits = Object.values(KitsModel);\n\n console.log(chalk.white('Makerkit available plugins...'));\n console.log(\n `[${chalk.green('Plugin Name')} (${chalk.gray('plugin-id')})]\\n`\n );\n\n for (const kit of kits) {\n console.log(`${chalk.cyan(kit.name)}`);\n\n if (!kit.plugins.length) {\n console.log(chalk.yellow(`- No plugins available`) + '\\n');\n\n continue;\n }\n\n for (const plugin of kit.plugins) {\n const { name, id } = validatePlugin(plugin);\n console.log(`- ${chalk.green(name)} (${chalk.gray(id)})`);\n }\n\n console.log('');\n }\n });\n}\n","import { PluginsService } from '@/src/commands/plugins/plugins-service';\nimport { Command } from 'commander';\n\nexport function createUpdatePluginCommand(parentCommand: Command) {\n return parentCommand\n .command('update')\n .argument('[plugin-id]', 'Plugin id')\n .description('Update plugin to the latest version')\n .action(async (maybePluginId) => {\n await PluginsService.pull(maybePluginId);\n });\n}\n","import { createInstallPluginCommand } from '@/src/commands/plugins/install/install-plugin.command';\nimport { createListPluginsCommand } from '@/src/commands/plugins/list/list-plugins.command';\nimport { createUpdatePluginCommand } from '@/src/commands/plugins/update/update-plugin.command';\nimport { Workspace } from '@/src/utils/workspace';\nimport { Command } from 'commander';\n\nexport const pluginsCommand = new Command()\n .name('plugins')\n .description('List and install plugins.')\n .hook('preAction', () => {\n return Workspace.logWorkspaceInfo();\n });\n\n// set children commands\ncreateListPluginsCommand(pluginsCommand);\ncreateInstallPluginCommand(pluginsCommand);\ncreateUpdatePluginCommand(pluginsCommand);\n","#!/usr/bin/env node\nimport { i18nCommand } from '@/src/commands/i18n/i18n.command';\nimport { licenseCommand } from '@/src/commands/license/license.command';\nimport { newCommand } from '@/src/commands/new/new.command';\nimport { pluginsCommand } from '@/src/commands/plugins/plugins.command';\nimport { Command } from 'commander';\nimport { config } from 'dotenv';\n\nconfig({\n path: '.env.local',\n});\n\nprocess.on('SIGINT', () => process.exit(0));\nprocess.on('SIGTERM', () => process.exit(0));\n\nasync function main() {\n const program = new Command()\n .name('makerkit')\n .description(\n 'Your SaaS Kit companion. Add plugins, manage migrations, and more.'\n )\n .version('-v, --version', 'display the version number');\n\n program\n .addCommand(newCommand)\n .addCommand(pluginsCommand)\n .addCommand(i18nCommand)\n .addCommand(licenseCommand);\n\n program.parse();\n}\n\nvoid main();\n"],"mappings":"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","names":["join","invariant","chalk","fs","join","chalk","chalk","prompts","Command","join","chalk","Command","ora","prompts","kit","join","chalk","ora","prompts","chalk","plugin","prompts","ora","verb","chalk","Command","Command"]}
|
|
1
|
+
{"version":3,"sources":["../src/commands/new/new.command.ts","../src/utils/create-project.ts","../src/utils/marker-file.ts","../src/version.ts","../src/utils/upstream.ts","../src/utils/list-variants.ts","../src/plugins-model.ts","../src/utils/plugins-cache.ts","../src/utils/base-store.ts","../src/utils/git.ts","../src/utils/install-registry-files.ts","../src/utils/run-codemod.ts","../src/utils/username-cache.ts","../src/utils/workspace.ts","../src/utils/add-plugin.ts","../src/utils/list-plugins.ts","../src/commands/plugins/add/add.command.ts","../src/commands/plugins/diff/diff.command.ts","../src/utils/init-registry.ts","../src/commands/plugins/init/init.command.ts","../src/commands/plugins/list/list-plugins.command.ts","../src/commands/plugins/outdated/outdated.command.ts","../src/commands/plugins/update/update.command.ts","../src/commands/plugins/plugins.command.ts","../src/utils/project-pull.ts","../src/commands/project/update/update.command.ts","../src/commands/project/project.command.ts","../src/index.ts"],"sourcesContent":["import chalk from 'chalk';\nimport { Command } from 'commander';\nimport ora from 'ora';\nimport prompts from 'prompts';\n\nimport { createProject } from '@/src/utils/create-project';\nimport { VARIANT_CATALOG } from '@/src/utils/list-variants';\n\nexport const newCommand = new Command()\n .name('new')\n .description('Initialize a new Makerkit project')\n .action(async () => {\n const choices = VARIANT_CATALOG.map((v) => ({\n title: v.name,\n value: v.id,\n }));\n\n const { kit, name: projectName } = await prompts([\n {\n type: 'select',\n name: 'kit',\n message: `Select the ${chalk.cyan(`SaaS Kit`)} you want to clone`,\n choices,\n },\n {\n type: 'text',\n name: 'name',\n message: `Enter your ${chalk.cyan('Project Name')}.`,\n },\n ]);\n\n const selected = VARIANT_CATALOG.find((v) => v.id === kit);\n\n if (!selected) {\n console.log('Invalid kit selection. Aborting...');\n process.exit(1);\n }\n\n const { confirm } = await prompts([\n {\n type: 'confirm',\n name: 'confirm',\n message: `Are you sure you want to clone ${chalk.cyan(\n selected.name\n )} to ${chalk.cyan(projectName)}?`,\n },\n ]);\n\n if (!confirm) {\n console.log('Aborting...');\n process.exit(0);\n }\n\n const spinner = ora(`Cloning ${selected.name}...`).start();\n\n try {\n const result = await createProject({\n variant: selected.id,\n name: projectName,\n directory: process.cwd(),\n });\n\n spinner.succeed(`${result.message}`);\n\n console.log(\n `You can now get started. Open the project in your IDE and read the README.md file for more information.`\n );\n } catch (e) {\n console.error(e);\n spinner.fail(`Failed to create project`);\n process.exit(1);\n }\n });\n","import { join } from 'path';\n\nimport { execa } from 'execa';\nimport fs from 'fs-extra';\n\nimport { writeMarkerFile } from '@/src/utils/marker-file';\nimport { VARIANT_REPO_MAP, hasSshAccess } from '@/src/utils/upstream';\nimport type { Variant } from '@/src/utils/workspace';\n\nexport interface CreateProjectOptions {\n variant: Variant;\n name: string;\n directory: string;\n githubToken?: string;\n}\n\nexport interface CreateProjectResult {\n success: boolean;\n projectPath: string;\n variant: Variant;\n kitRepo: string;\n message: string;\n}\n\nexport async function createProject(\n options: CreateProjectOptions,\n): Promise<CreateProjectResult> {\n const { variant, name, directory, githubToken } = options;\n const projectPath = join(directory, name);\n const repo = VARIANT_REPO_MAP[variant];\n\n // 1. Validate target dir doesn't already exist\n if (await fs.pathExists(projectPath)) {\n throw new Error(\n `Target directory \"${projectPath}\" already exists. Choose a different name or remove it first.`,\n );\n }\n\n // 2. Validate parent dir exists\n if (!(await fs.pathExists(directory))) {\n throw new Error(\n `Parent directory \"${directory}\" does not exist.`,\n );\n }\n\n // 3. Resolve clone URL\n let cloneUrl: string;\n\n if (githubToken) {\n cloneUrl = `https://${githubToken}@github.com/${repo}`;\n } else {\n const useSsh = await hasSshAccess();\n cloneUrl = useSsh\n ? `git@github.com:${repo}`\n : `https://github.com/${repo}`;\n }\n\n // 4. Clone\n await execa('git', ['clone', cloneUrl, name], { cwd: directory });\n\n // 5. Strip token from remote if needed\n if (githubToken) {\n await execa(\n 'git',\n ['remote', 'set-url', 'origin', `https://github.com/${repo}`],\n { cwd: projectPath },\n );\n }\n\n // 6. Install dependencies\n await execa('pnpm', ['install'], { cwd: projectPath });\n\n // 7. Write marker file\n await writeMarkerFile(projectPath, variant, repo);\n\n return {\n success: true,\n projectPath,\n variant,\n kitRepo: repo,\n message: `Project \"${name}\" created successfully with variant \"${variant}\".`,\n };\n}\n","import { join } from 'path';\n\nimport fs from 'fs-extra';\n\nimport { CLI_VERSION } from '@/src/version';\n\nexport interface MakerkitProjectConfig {\n version: number;\n variant: string;\n kit_repo: string;\n created_at: string;\n cli_version: string;\n}\n\nexport async function writeMarkerFile(\n projectPath: string,\n variant: string,\n kitRepo: string,\n): Promise<void> {\n const dir = join(projectPath, '.makerkit');\n\n await fs.ensureDir(dir);\n\n const config: MakerkitProjectConfig = {\n version: 1,\n variant,\n kit_repo: kitRepo,\n created_at: new Date().toISOString(),\n cli_version: CLI_VERSION,\n };\n\n await fs.writeJson(join(dir, 'config.json'), config, { spaces: 2 });\n}\n\nexport async function readMarkerFile(\n projectPath: string,\n): Promise<MakerkitProjectConfig | null> {\n const filePath = join(projectPath, '.makerkit', 'config.json');\n\n if (!(await fs.pathExists(filePath))) {\n return null;\n }\n\n return fs.readJson(filePath);\n}\n","export const CLI_VERSION = '2.0.0-beta.1';\n","import type { Variant } from '@/src/utils/workspace';\n\nimport { execaCommand } from 'execa';\n\nexport const VARIANT_REPO_MAP: Record<Variant, string> = {\n 'next-supabase': 'makerkit/next-supabase-saas-kit-turbo',\n 'next-drizzle': 'makerkit/next-drizzle-saas-kit-turbo',\n 'next-prisma': 'makerkit/next-prisma-saas-kit-turbo',\n 'react-router-supabase': 'makerkit/react-router-supabase-saas-kit-turbo',\n};\n\nfunction sshUrl(repo: string): string {\n return `git@github.com:${repo}`;\n}\n\nfunction httpsUrl(repo: string): string {\n return `https://github.com/${repo}`;\n}\n\nexport async function hasSshAccess(): Promise<boolean> {\n try {\n await execaCommand('ssh -T git@github.com -o StrictHostKeyChecking=no', {\n timeout: 10_000,\n });\n\n return true;\n } catch (error) {\n // ssh -T git@github.com exits with code 1 even on success,\n // but prints \"successfully authenticated\" in stderr\n const stderr =\n error instanceof Error && 'stderr' in error\n ? String((error as { stderr: unknown }).stderr)\n : '';\n\n return stderr.includes('successfully authenticated');\n }\n}\n\nexport function getUpstreamUrl(variant: Variant, useSsh: boolean): string {\n const repo = VARIANT_REPO_MAP[variant];\n\n return useSsh ? sshUrl(repo) : httpsUrl(repo);\n}\n\n/**\n * Check if a remote URL points to the correct repo for the given variant,\n * regardless of whether it uses SSH or HTTPS.\n * Handles trailing `.git` and `/` in URLs.\n */\nexport function isUpstreamUrlValid(\n url: string,\n variant: Variant,\n): boolean {\n const normalized = url.replace(/\\/+$/, '').replace(/\\.git$/, '');\n const repo = VARIANT_REPO_MAP[variant];\n\n return normalized === sshUrl(repo) || normalized === httpsUrl(repo);\n}\n\nexport async function getUpstreamRemoteUrl(): Promise<string | undefined> {\n try {\n const { stdout } = await execaCommand('git remote get-url upstream');\n return stdout.trim() || undefined;\n } catch {\n return undefined;\n }\n}\n\nexport async function setUpstreamRemote(url: string): Promise<void> {\n const currentUrl = await getUpstreamRemoteUrl();\n\n if (currentUrl) {\n await execaCommand(`git remote set-url upstream ${url}`);\n } else {\n await execaCommand(`git remote add upstream ${url}`);\n }\n}\n","import { VARIANT_REPO_MAP } from '@/src/utils/upstream';\nimport type { Variant } from '@/src/utils/workspace';\n\nexport interface VariantInfo {\n id: Variant;\n name: string;\n description: string;\n repo: string;\n tech: string[];\n database: string;\n auth: string;\n status: 'stable' | 'beta' | 'deprecated';\n}\n\nexport const VARIANT_CATALOG: VariantInfo[] = [\n {\n id: 'next-supabase',\n name: 'Next.js + Supabase',\n description: 'Full-stack SaaS kit with Next.js App Router and Supabase',\n repo: VARIANT_REPO_MAP['next-supabase'],\n tech: ['Next.js', 'Supabase', 'Tailwind CSS', 'shadcn/ui'],\n database: 'PostgreSQL (Supabase)',\n auth: 'Supabase Auth',\n status: 'stable',\n },\n {\n id: 'next-drizzle',\n name: 'Next.js + Drizzle',\n description: 'Full-stack SaaS kit with Next.js and Drizzle ORM',\n repo: VARIANT_REPO_MAP['next-drizzle'],\n tech: ['Next.js', 'Drizzle', 'Tailwind CSS', 'shadcn/ui'],\n database: 'PostgreSQL',\n auth: 'Better Auth',\n status: 'stable',\n },\n {\n id: 'next-prisma',\n name: 'Next.js + Prisma',\n description: 'Full-stack SaaS kit with Next.js and Prisma ORM',\n repo: VARIANT_REPO_MAP['next-prisma'],\n tech: ['Next.js', 'Prisma', 'Tailwind CSS', 'shadcn/ui'],\n database: 'PostgreSQL',\n auth: 'Better Auth',\n status: 'stable',\n },\n {\n id: 'react-router-supabase',\n name: 'React Router + Supabase',\n description: 'Full-stack SaaS kit with React Router and Supabase',\n repo: VARIANT_REPO_MAP['react-router-supabase'],\n tech: ['React Router', 'Supabase', 'Tailwind CSS', 'shadcn/ui'],\n database: 'PostgreSQL (Supabase)',\n auth: 'Supabase Auth',\n status: 'stable',\n },\n];\n\nexport interface ListVariantsResult {\n variants: VariantInfo[];\n}\n\nexport function listVariants(): ListVariantsResult {\n return { variants: VARIANT_CATALOG };\n}\n","import { join } from 'path';\n\nimport fs from 'fs-extra';\nimport invariant from 'tiny-invariant';\n\nimport { fetchPluginRegistry } from '@/src/utils/plugins-cache';\nimport type { Variant } from '@/src/utils/workspace';\n\nexport interface EnvVar {\n key: string;\n description: string;\n defaultValue?: string;\n}\n\nexport interface VariantConfig {\n envVars: EnvVar[];\n path?: string;\n}\n\nexport interface PluginDefinition {\n name: string;\n id: string;\n description: string;\n variants: Partial<Record<Variant, VariantConfig>>;\n postInstallMessage?: string;\n}\n\nconst DEFAULT_PLUGINS: Record<string, PluginDefinition> = {\n feedback: {\n name: 'Feedback',\n id: 'feedback',\n description: 'Add a feedback popup to your site.',\n postInstallMessage: 'Run database migrations: pnpm db:migrate',\n variants: {\n 'next-supabase': {\n envVars: [],\n path: 'packages/plugins/feedback',\n },\n },\n },\n waitlist: {\n name: 'Waitlist',\n id: 'waitlist',\n description: 'Add a waitlist to your site.',\n postInstallMessage: 'Run database migrations: pnpm db:migrate',\n variants: {\n 'next-supabase': {\n envVars: [],\n path: 'packages/plugins/waitlist',\n },\n },\n },\n testimonial: {\n name: 'Testimonial',\n id: 'testimonial',\n description: 'Add a testimonial widget to your site.',\n postInstallMessage: 'Run database migrations: pnpm db:migrate',\n variants: {\n 'next-supabase': {\n envVars: [],\n path: 'packages/plugins/testimonial',\n },\n },\n },\n roadmap: {\n name: 'Roadmap',\n id: 'roadmap',\n description: 'Add a roadmap to your site.',\n postInstallMessage: 'Run database migrations: pnpm db:migrate',\n variants: {\n 'next-supabase': {\n envVars: [],\n path: 'packages/plugins/roadmap',\n },\n },\n },\n 'google-analytics': {\n name: 'Google Analytics',\n id: 'google-analytics',\n description: 'Add Google Analytics to your site.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_GOOGLE_ANALYTICS_ID',\n description: 'Google Analytics Measurement ID',\n },\n ],\n path: 'packages/plugins/analytics/google-analytics',\n },\n 'next-drizzle': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_GOOGLE_ANALYTICS_ID',\n description: 'Google Analytics Measurement ID',\n },\n ],\n path: 'packages/plugins/analytics/google-analytics',\n },\n 'next-prisma': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_GOOGLE_ANALYTICS_ID',\n description: 'Google Analytics Measurement ID',\n },\n ],\n path: 'packages/plugins/analytics/google-analytics',\n }\n },\n },\n honeybadger: {\n name: 'Honeybadger',\n id: 'honeybadger',\n description: 'Add Honeybadger Error Tracking to your site.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'HONEYBADGER_API_KEY',\n description: 'Honeybadger private API key',\n },\n {\n key: 'NEXT_PUBLIC_HONEYBADGER_ENVIRONMENT',\n description: 'Honeybadger environment',\n },\n {\n key: 'NEXT_PUBLIC_HONEYBADGER_REVISION',\n description: 'Honeybadger log revision',\n }\n ],\n path: 'packages/plugins/honeybadger',\n },\n }\n },\n posthog: {\n name: 'PostHog',\n id: 'posthog',\n description: 'Add PostHog Analytics to your site.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_POSTHOG_KEY',\n description: 'PostHog project API key',\n },\n {\n key: 'NEXT_PUBLIC_POSTHOG_HOST',\n description: 'PostHog host URL',\n defaultValue: 'https://app.posthog.com',\n },\n ],\n path: 'packages/plugins/analytics/posthog',\n },\n 'next-drizzle': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_POSTHOG_KEY',\n description: 'PostHog project API key',\n },\n {\n key: 'NEXT_PUBLIC_POSTHOG_HOST',\n description: 'PostHog host URL',\n defaultValue: 'https://app.posthog.com',\n },\n ],\n path: 'packages/plugins/analytics/posthog',\n },\n 'next-prisma': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_POSTHOG_KEY',\n description: 'PostHog project API key',\n },\n {\n key: 'NEXT_PUBLIC_POSTHOG_HOST',\n description: 'PostHog host URL',\n defaultValue: 'https://app.posthog.com',\n },\n ],\n path: 'packages/plugins/analytics/posthog',\n },\n },\n },\n umami: {\n name: 'Umami',\n id: 'umami',\n description: 'Add Umami Analytics to your site.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_UMAMI_WEBSITE_ID',\n description: 'Umami website ID',\n },\n {\n key: 'NEXT_PUBLIC_UMAMI_HOST',\n description: 'Umami host URL',\n },\n ],\n path: 'packages/plugins/analytics/umami',\n },\n 'next-drizzle': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_UMAMI_WEBSITE_ID',\n description: 'Umami website ID',\n },\n {\n key: 'NEXT_PUBLIC_UMAMI_HOST',\n description: 'Umami host URL',\n },\n ],\n path: 'packages/plugins/analytics/umami',\n },\n 'next-prisma': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_UMAMI_WEBSITE_ID',\n description: 'Umami website ID',\n },\n {\n key: 'NEXT_PUBLIC_UMAMI_HOST',\n description: 'Umami host URL',\n },\n ],\n path: 'packages/plugins/analytics/umami',\n },\n },\n },\n signoz: {\n name: 'SigNoz',\n id: 'signoz',\n description: 'Add SigNoz Monitoring to your app.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'OTEL_EXPORTER_OTLP_ENDPOINT',\n description: 'SigNoz OTLP endpoint URL',\n },\n ],\n path: 'packages/plugins/signoz',\n },\n 'next-drizzle': {\n envVars: [\n {\n key: 'OTEL_EXPORTER_OTLP_ENDPOINT',\n description: 'SigNoz OTLP endpoint URL',\n },\n ],\n path: 'packages/plugins/signoz',\n },\n 'next-prisma': {\n envVars: [\n {\n key: 'OTEL_EXPORTER_OTLP_ENDPOINT',\n description: 'SigNoz OTLP endpoint URL',\n },\n ],\n path: 'packages/plugins/signoz',\n },\n },\n },\n paddle: {\n name: 'Paddle',\n id: 'paddle',\n description: 'Add Paddle Billing to your app.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_PADDLE_CLIENT_TOKEN',\n description: 'Paddle client-side token',\n },\n {\n key: 'PADDLE_API_KEY',\n description: 'Paddle API key',\n },\n {\n key: 'PADDLE_WEBHOOK_SECRET',\n description: 'Paddle webhook secret',\n },\n ],\n path: 'packages/plugins/paddle',\n },\n },\n },\n 'supabase-cms': {\n name: 'Supabase CMS',\n id: 'supabase-cms',\n description: 'Add Supabase CMS provider to your app.',\n postInstallMessage: 'Run database migrations: pnpm db:migrate',\n variants: {\n 'next-supabase': {\n envVars: [],\n path: 'packages/plugins/supabase-cms',\n },\n },\n },\n 'meshes-analytics': {\n name: 'Meshes Analytics',\n id: 'meshes-analytics',\n description: 'Add Meshes Analytics to your app.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_MESHES_PUBLISHABLE_KEY',\n description: 'The Meshes publishable key'\n }\n ],\n path: 'packages/plugins/meshes-analytics',\n },\n },\n },\n directus: {\n name: 'Directus CMS',\n id: 'directus-cms',\n description: 'Add Directus as your CMS.',\n variants: {\n 'next-supabase': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_DIRECTUS_URL',\n description: 'The Directus URL'\n },\n {\n key: 'DIRECTUS_ACCESS_TOKEN',\n description: 'The Directus access token'\n }\n ],\n path: 'packages/plugins/directus',\n },\n 'next-drizzle': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_DIRECTUS_URL',\n description: 'The Directus URL'\n },\n {\n key: 'DIRECTUS_ACCESS_TOKEN',\n description: 'The Directus access token'\n }\n ],\n path: 'packages/plugins/directus',\n },\n 'next-prisma': {\n envVars: [\n {\n key: 'NEXT_PUBLIC_DIRECTUS_URL',\n description: 'The Directus URL'\n },\n {\n key: 'DIRECTUS_ACCESS_TOKEN',\n description: 'The Directus access token'\n }\n ],\n path: 'packages/plugins/directus',\n },\n },\n }\n};\n\nexport class PluginRegistry {\n private constructor(\n private plugins: Record<string, PluginDefinition>,\n ) {}\n\n static async load(): Promise<PluginRegistry> {\n const registryUrl = process.env.MAKERKIT_PLUGINS_REGISTRY_URL;\n const plugins = await fetchPluginRegistry(registryUrl, DEFAULT_PLUGINS);\n\n return new PluginRegistry(plugins);\n }\n\n getPluginById(id: string): PluginDefinition | undefined {\n return this.plugins[id];\n }\n\n getPluginsForVariant(variant: Variant): PluginDefinition[] {\n return Object.values(this.plugins).filter((p) => variant in p.variants);\n }\n\n validatePlugin(pluginId: string, variant: Variant): PluginDefinition {\n const plugin = this.getPluginById(pluginId);\n\n invariant(plugin, `Plugin \"${pluginId}\" not found`);\n\n invariant(\n plugin.variants[variant],\n `Plugin \"${pluginId}\" is not available for the ${variant} variant`,\n );\n\n return plugin;\n }\n}\n\nexport function getEnvVars(\n plugin: PluginDefinition,\n variant: Variant,\n): EnvVar[] {\n return plugin.variants[variant]?.envVars ?? [];\n}\n\nexport function getPath(\n plugin: PluginDefinition,\n variant: Variant,\n): string | undefined {\n return plugin.variants[variant]?.path;\n}\n\nexport async function isInstalled(\n plugin: PluginDefinition,\n variant: Variant,\n): Promise<boolean> {\n const pluginPath = getPath(plugin, variant);\n\n if (!pluginPath) {\n return false;\n }\n\n const pkgJsonPath = join(process.cwd(), pluginPath, 'package.json');\n\n if (!(await fs.pathExists(pkgJsonPath))) {\n return false;\n }\n\n try {\n const pkg = await fs.readJson(pkgJsonPath);\n\n return !!pkg.name && !!pkg.exports;\n } catch {\n return false;\n }\n}\n","import { join } from 'path';\nimport { homedir } from 'os';\n\nimport fs from 'fs-extra';\n\nimport type { PluginDefinition } from '@/src/plugins-model';\n\nconst CACHE_DIR = join(homedir(), '.makerkit');\nconst CACHE_FILE = join(CACHE_DIR, 'plugins.json');\nconst CACHE_TTL_MS = 60 * 60 * 1000; // 1 hour\n\ninterface CacheEntry {\n fetchedAt: number;\n plugins: Record<string, PluginDefinition>;\n}\n\nasync function readCache(): Promise<CacheEntry | null> {\n try {\n if (!(await fs.pathExists(CACHE_FILE))) {\n return null;\n }\n\n return await fs.readJson(CACHE_FILE);\n } catch {\n return null;\n }\n}\n\nasync function writeCache(\n plugins: Record<string, PluginDefinition>,\n): Promise<void> {\n try {\n await fs.ensureDir(CACHE_DIR);\n\n await fs.writeJson(\n CACHE_FILE,\n { fetchedAt: Date.now(), plugins },\n { spaces: 2 },\n );\n } catch {\n // Ignore cache write failures\n }\n}\n\nexport async function fetchPluginRegistry(\n registryUrl: string | undefined,\n fallback: Record<string, PluginDefinition>,\n): Promise<Record<string, PluginDefinition>> {\n if (!registryUrl) {\n return fallback;\n }\n\n // Check cache first\n const cached = await readCache();\n\n if (cached && Date.now() - cached.fetchedAt < CACHE_TTL_MS) {\n return cached.plugins;\n }\n\n // Fetch from remote\n try {\n const response = await fetch(registryUrl);\n\n if (response.ok) {\n const data = await response.json();\n const plugins = data.plugins as Record<string, PluginDefinition>;\n\n await writeCache(plugins);\n\n return plugins;\n }\n } catch {\n // Network error — fall through\n }\n\n // Return stale cache if available, otherwise bundled fallback\n return cached?.plugins ?? fallback;\n}\n","import { dirname, join } from 'path';\n\nimport fs from 'fs-extra';\n\nimport type { RegistryFile } from '@/src/utils/install-registry-files';\n\nexport type FileStatus =\n | 'unchanged'\n | 'updated'\n | 'conflict'\n | 'added'\n | 'deleted_locally'\n | 'no_base';\n\nfunction basesDir(pluginId: string): string {\n return join(process.cwd(), 'node_modules', '.cache', 'makerkit', 'bases', pluginId);\n}\n\nexport async function saveBaseVersions(\n pluginId: string,\n files: RegistryFile[],\n): Promise<void> {\n const dir = basesDir(pluginId);\n\n for (const file of files) {\n const targetPath = join(dir, file.target);\n\n await fs.ensureDir(dirname(targetPath));\n await fs.writeFile(targetPath, file.content);\n }\n}\n\nexport async function readBaseVersion(\n pluginId: string,\n fileTarget: string,\n): Promise<string | undefined> {\n const filePath = join(basesDir(pluginId), fileTarget);\n\n try {\n return await fs.readFile(filePath, 'utf-8');\n } catch {\n return undefined;\n }\n}\n\nexport async function hasBaseVersions(pluginId: string): Promise<boolean> {\n return fs.pathExists(basesDir(pluginId));\n}\n\nexport function computeFileStatus(params: {\n base?: string;\n local?: string;\n remote: string;\n}): FileStatus {\n const { base, local, remote } = params;\n\n // Local matches remote — nothing to do regardless of base\n if (local !== undefined && local === remote) {\n return 'unchanged';\n }\n\n // No base version (legacy install or new file)\n if (base === undefined) {\n if (local === undefined) {\n return 'added';\n }\n\n return 'no_base';\n }\n\n // Has base version\n if (local === undefined) {\n return 'deleted_locally';\n }\n\n if (base === local) {\n // User hasn't touched the file — safe auto-apply\n return 'updated';\n }\n\n if (base === remote) {\n // Remote hasn't changed — local edits are fine\n return 'unchanged';\n }\n\n // Both sides changed\n return 'conflict';\n}\n","import { execaCommand } from 'execa';\n\nexport function getErrorOutput(error: unknown): string {\n if (error instanceof Error && 'stderr' in error) {\n const stderr = String((error as { stderr: unknown }).stderr);\n\n if (stderr) return stderr;\n }\n\n if (error instanceof Error && 'stdout' in error) {\n const stdout = String((error as { stdout: unknown }).stdout);\n\n if (stdout) return stdout;\n }\n\n return error instanceof Error ? error.message : String(error);\n}\n\nexport async function isGitClean(): Promise<boolean> {\n const { stdout } = await execaCommand('git status --porcelain');\n\n return stdout.trim() === '';\n}\n\nexport async function getGitRoot(): Promise<string> {\n const { stdout } = await execaCommand('git rev-parse --show-toplevel');\n\n return stdout.trim();\n}\n\nexport async function getGitUsername(): Promise<string | undefined> {\n try {\n const { stdout } = await execaCommand('git config --get user.username');\n const username = stdout.trim();\n\n return username.length > 0 ? username : undefined;\n } catch {\n return undefined;\n }\n}\n","import { dirname, join } from 'path';\nimport fs from 'fs-extra';\n\nexport interface RegistryFile {\n path: string;\n content: string;\n type: string;\n target: string;\n}\n\nexport interface RegistryItem {\n name: string;\n files: RegistryFile[];\n dependencies?: Record<string, string>;\n}\n\nexport async function fetchRegistryItem(\n variant: string,\n pluginId: string,\n username: string,\n): Promise<RegistryItem> {\n const url = `https://makerkit.dev/r/${variant}/${pluginId}.json?username=${username}`;\n\n const response = await fetch(url);\n\n if (!response.ok) {\n throw new Error(\n `Failed to fetch plugin registry for \"${pluginId}\" (${response.status}): ${response.statusText}`,\n );\n }\n\n const item: RegistryItem = await response.json();\n\n if (!item.files || item.files.length === 0) {\n throw new Error(`Plugin \"${pluginId}\" has no files in the registry.`);\n }\n\n return item;\n}\n\nexport async function installRegistryFiles(\n variant: string,\n pluginId: string,\n username: string,\n): Promise<RegistryItem> {\n const item = await fetchRegistryItem(variant, pluginId, username);\n const cwd = process.cwd();\n\n for (const file of item.files) {\n const targetPath = join(cwd, file.target);\n\n await fs.ensureDir(dirname(targetPath));\n await fs.writeFile(targetPath, file.content);\n }\n\n return item;\n}\n","import { execaCommand } from 'execa';\n\nconst CODEMOD_TIMEOUT_MS = 5 * 60 * 1000; // 5 minutes\n\nexport async function runCodemod(\n variant: string,\n pluginId: string,\n options?: { captureOutput?: boolean },\n): Promise<{ success: boolean; output: string }> {\n try {\n const localPath = process.env.MAKERKIT_CODEMODS_PATH;\n const runner = process.env.MAKERKIT_PACKAGE_RUNNER ?? 'npx --yes';\n\n const command = localPath\n ? `${runner} codemod workflow run --allow-dirty -w ${localPath}/codemods/${variant}/${pluginId}`\n : `${runner} codemod --allow-dirty @makerkit/${variant}-${pluginId}`;\n\n const { stdout, stderr } = await execaCommand(command, {\n stdio: options?.captureOutput ? 'pipe' : 'inherit',\n timeout: CODEMOD_TIMEOUT_MS,\n });\n\n return {\n success: true,\n output: stdout || stderr || '',\n };\n } catch (error) {\n let message = 'Unknown error during codemod';\n\n if (error instanceof Error) {\n message = error.message;\n\n if ('stderr' in error && error.stderr) {\n message += `\\n${error.stderr}`;\n }\n\n if ('timedOut' in error && error.timedOut) {\n message = `Codemod timed out after ${CODEMOD_TIMEOUT_MS / 1000}s (the workflow engine may have stalled after an error)`;\n }\n }\n\n return {\n success: false,\n output: message,\n };\n }\n}\n","import { join } from 'path';\nimport { tmpdir } from 'os';\n\nimport fs from 'fs-extra';\nimport prompts from 'prompts';\n\nimport { getGitUsername } from '@/src/utils/git';\n\nconst USERNAME_FILE = join(tmpdir(), 'makerkit-username');\n\nexport function getCachedUsername(): string | undefined {\n try {\n const username = fs.readFileSync(USERNAME_FILE, 'utf-8').trim();\n\n return username.length > 0 ? username : undefined;\n } catch {\n return undefined;\n }\n}\n\nexport function cacheUsername(username: string): void {\n fs.writeFileSync(USERNAME_FILE, username, 'utf-8');\n}\n\nexport function clearCachedUsername(): void {\n try {\n fs.removeSync(USERNAME_FILE);\n } catch {\n // ignore\n }\n}\n\nexport async function promptForUsername(): Promise<string> {\n const gitUsername = await getGitUsername();\n\n const response = await prompts({\n type: 'text',\n name: 'githubUsername',\n message:\n 'Enter the GitHub username registered with your Makerkit account',\n initial: gitUsername,\n validate: (value) => {\n return value.trim().length > 0 ? true : 'GitHub username is required';\n },\n });\n\n const username = (response.githubUsername as string | undefined)?.trim();\n\n if (!username) {\n throw new Error('Setup cancelled. GitHub username is required.');\n }\n\n cacheUsername(username);\n\n return username;\n}\n\nexport async function getOrPromptUsername(\n providedUsername?: string,\n): Promise<string> {\n if (providedUsername?.trim()) {\n const username = providedUsername.trim();\n\n cacheUsername(username);\n\n return username;\n }\n\n const cached = getCachedUsername();\n\n if (cached) {\n return cached;\n }\n\n return promptForUsername();\n}\n","import { join } from 'path';\n\nimport fs from 'fs-extra';\n\nexport type Variant =\n | 'next-supabase'\n | 'next-drizzle'\n | 'next-prisma'\n | 'react-router-supabase';\n\nasync function readDeps(\n pkgPath: string,\n): Promise<Record<string, string>> {\n if (!(await fs.pathExists(pkgPath))) {\n return {};\n }\n\n const pkg = await fs.readJson(pkgPath);\n\n return {\n ...pkg.dependencies,\n ...pkg.devDependencies,\n };\n}\n\nexport async function detectVariant(): Promise<Variant> {\n const cwd = process.cwd();\n\n const rootPkgPath = join(cwd, 'package.json');\n\n if (!(await fs.pathExists(rootPkgPath))) {\n throw new Error(\n 'No package.json found. Please run this command from a MakerKit project root.',\n );\n }\n\n const rootDeps = await readDeps(rootPkgPath);\n\n if (!rootDeps['turbo']) {\n throw new Error(\n 'This does not appear to be a MakerKit Turbo monorepo. The \"turbo\" dependency was not found in package.json.',\n );\n }\n\n const webDeps = await readDeps(join(cwd, 'apps', 'web', 'package.json'));\n const dbDeps = await readDeps(\n join(cwd, 'packages', 'database', 'package.json'),\n );\n\n const hasSupabase = !!webDeps['@supabase/supabase-js'];\n const hasReactRouter = !!webDeps['@react-router/node'];\n const hasDrizzle = !!webDeps['drizzle-orm'] || !!dbDeps['drizzle-orm'];\n const hasPrisma = !!webDeps['@prisma/client'] || !!dbDeps['@prisma/client'];\n\n if (hasReactRouter && hasSupabase) {\n return 'react-router-supabase';\n }\n\n if (hasSupabase) {\n return 'next-supabase';\n }\n\n if (hasDrizzle) {\n return 'next-drizzle';\n }\n\n if (hasPrisma) {\n return 'next-prisma';\n }\n\n throw new Error(\n 'Unrecognized MakerKit project. Could not detect variant from dependencies.',\n );\n}\n\nexport async function validateProject(): Promise<{\n variant: Variant;\n version: string;\n}> {\n const variant = await detectVariant();\n const rootPkg = await fs.readJson(join(process.cwd(), 'package.json'));\n\n return {\n variant,\n version: rootPkg.version ?? 'unknown',\n };\n}\n","import {\n PluginRegistry,\n getEnvVars,\n isInstalled,\n} from '@/src/plugins-model';\nimport { saveBaseVersions } from '@/src/utils/base-store';\nimport { isGitClean } from '@/src/utils/git';\nimport { installRegistryFiles } from '@/src/utils/install-registry-files';\nimport { runCodemod } from '@/src/utils/run-codemod';\nimport {\n cacheUsername,\n getCachedUsername,\n} from '@/src/utils/username-cache';\nimport { validateProject } from '@/src/utils/workspace';\n\nexport interface AddPluginOptions {\n projectPath: string;\n pluginId: string;\n githubUsername?: string;\n skipGitCheck?: boolean;\n captureCodemodOutput?: boolean;\n}\n\nexport type AddPluginResult =\n | {\n success: true;\n pluginName: string;\n pluginId: string;\n variant: string;\n envVars: { key: string; description: string }[];\n postInstallMessage: string | null;\n codemodOutput: string;\n codemodWarning?: string;\n }\n | { success: false; reason: string };\n\nexport async function addPlugin(\n options: AddPluginOptions,\n): Promise<AddPluginResult> {\n if (!options.skipGitCheck) {\n const gitClean = await isGitClean();\n\n if (!gitClean) {\n return {\n success: false,\n reason:\n 'Git working directory has uncommitted changes. Please commit or stash them before adding a plugin.',\n };\n }\n }\n\n const { variant } = await validateProject();\n\n const username = options.githubUsername?.trim() || getCachedUsername();\n\n if (!username) {\n return {\n success: false,\n reason:\n 'No GitHub username cached and none provided. Call makerkit_init_registry first or pass githubUsername.',\n };\n }\n\n cacheUsername(username);\n\n const registry = await PluginRegistry.load();\n const plugin = registry.validatePlugin(options.pluginId, variant);\n\n if (await isInstalled(plugin, variant)) {\n return {\n success: false,\n reason: `Plugin \"${plugin.name}\" is already installed.`,\n };\n }\n\n const item = await installRegistryFiles(variant, options.pluginId, username);\n await saveBaseVersions(options.pluginId, item.files);\n\n const codemodResult = await runCodemod(variant, options.pluginId, {\n captureOutput: options.captureCodemodOutput ?? true,\n });\n\n const envVars = getEnvVars(plugin, variant);\n\n return {\n success: true,\n pluginName: plugin.name,\n pluginId: plugin.id,\n variant,\n envVars: envVars.map((e) => ({ key: e.key, description: e.description })),\n postInstallMessage: plugin.postInstallMessage ?? null,\n codemodOutput: codemodResult.output,\n codemodWarning: codemodResult.success\n ? undefined\n : `The automated codemod did not complete successfully. Plugin files were installed but some wiring steps may have failed.\\n${codemodResult.output}`,\n };\n}\n","import {\n PluginRegistry,\n getEnvVars,\n isInstalled,\n} from '@/src/plugins-model';\nimport { detectVariant } from '@/src/utils/workspace';\n\nexport interface ListPluginsOptions {\n projectPath: string;\n}\n\nexport interface ListPluginsResult {\n variant: string;\n plugins: {\n id: string;\n name: string;\n description: string;\n installed: boolean;\n envVars: string[];\n postInstallMessage: string | null;\n }[];\n}\n\nexport async function listPlugins(\n options: ListPluginsOptions,\n): Promise<ListPluginsResult> {\n const variant = await detectVariant();\n const registry = await PluginRegistry.load();\n const plugins = registry.getPluginsForVariant(variant);\n\n const pluginList = await Promise.all(\n plugins.map(async (p) => ({\n id: p.id,\n name: p.name,\n description: p.description,\n installed: await isInstalled(p, variant),\n envVars: getEnvVars(p, variant).map((e) => e.key),\n postInstallMessage: p.postInstallMessage ?? null,\n })),\n );\n\n return { variant, plugins: pluginList };\n}\n","import { addPlugin } from '@/src/utils/add-plugin';\nimport { isGitClean } from '@/src/utils/git';\nimport { listPlugins } from '@/src/utils/list-plugins';\nimport {\n clearCachedUsername,\n getOrPromptUsername,\n} from '@/src/utils/username-cache';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport ora from 'ora';\nimport prompts from 'prompts';\n\nexport function createAddCommand(parentCommand: Command) {\n return parentCommand\n .command('add')\n .argument('[plugin-id...]', 'Plugins to install (e.g. feedback waitlist)')\n .description('Install one or more MakerKit plugins.')\n .action(async (pluginIds: string[]) => {\n try {\n // 1. Validate git is clean once upfront\n const gitClean = await isGitClean();\n\n if (!gitClean) {\n console.error(\n chalk.red(\n 'Your git working directory has uncommitted changes. Please commit or stash them before adding a plugin.',\n ),\n );\n\n process.exit(1);\n }\n\n // 2. If no plugin IDs provided, show interactive selection\n if (!pluginIds || pluginIds.length === 0) {\n const pluginsResult = await listPlugins({ projectPath: process.cwd() });\n const available = pluginsResult.plugins.filter((p) => !p.installed);\n\n if (available.length === 0) {\n console.log(chalk.green('All plugins are already installed.'));\n return;\n }\n\n const response = await prompts({\n type: 'multiselect',\n name: 'pluginIds',\n message: 'Select plugins to install',\n choices: available.map((p) => ({\n title: `${p.name} ${chalk.gray(`(${p.id})`)}`,\n value: p.id,\n })),\n });\n\n pluginIds = response.pluginIds as string[] | undefined ?? [];\n\n if (pluginIds.length === 0) {\n return;\n }\n }\n\n // 3. Prompt for username once\n let username = await getOrPromptUsername();\n\n // 4. Install each plugin\n for (const pluginId of pluginIds) {\n console.log(\n `\\nInstalling ${chalk.cyan(pluginId)}...\\n`,\n );\n\n const filesSpinner = ora('Installing plugin...').start();\n\n let result;\n\n try {\n result = await addPlugin({\n projectPath: process.cwd(),\n pluginId,\n githubUsername: username,\n skipGitCheck: true,\n captureCodemodOutput: false,\n });\n } catch (error) {\n // Auth failure — clear username, re-prompt, retry once\n filesSpinner.fail('Failed to install plugin.');\n\n clearCachedUsername();\n\n console.log(\n chalk.yellow('\\nRetrying with a different username...\\n'),\n );\n\n username = await getOrPromptUsername();\n\n const retrySpinner = ora('Installing plugin...').start();\n\n try {\n result = await addPlugin({\n projectPath: process.cwd(),\n pluginId,\n githubUsername: username,\n skipGitCheck: true,\n captureCodemodOutput: false,\n });\n } catch (retryError) {\n retrySpinner.fail('Failed to install plugin.');\n\n const message =\n retryError instanceof Error ? retryError.message : 'Unknown error';\n\n console.error(chalk.red(`\\nError installing \"${pluginId}\": ${message}`));\n console.log(\n chalk.yellow(\n '\\nTo revert changes, run: git checkout . && git clean -fd',\n ),\n );\n\n process.exit(1);\n }\n\n if (result.success) {\n retrySpinner.succeed('Plugin installed.');\n } else {\n retrySpinner.stop();\n }\n }\n\n if (!result.success) {\n if (result.reason.includes('already installed')) {\n filesSpinner.warn(result.reason + ' Skipping.');\n continue;\n }\n\n filesSpinner.fail('Failed to install plugin.');\n console.error(chalk.red(`\\n${result.reason}`));\n console.log(\n chalk.yellow(\n '\\nTo revert changes, run: git checkout . && git clean -fd',\n ),\n );\n\n process.exit(1);\n }\n\n if (result.codemodWarning) {\n filesSpinner.warn(\n `${result.pluginName} installed with warnings — some automated steps may not have completed.`,\n );\n console.log(chalk.yellow(`\\n${result.codemodWarning}`));\n console.log(\n chalk.yellow(\n '\\nPlugin files were written successfully. Review the changes with `git diff` and complete any missing steps manually.',\n ),\n );\n } else if (filesSpinner.isSpinning) {\n filesSpinner.succeed(`${result.pluginName} installed successfully!`);\n }\n\n if (result.envVars.length > 0) {\n console.log(chalk.white('\\nEnvironment variables to configure:'));\n\n for (const envVar of result.envVars) {\n console.log(\n ` ${chalk.cyan(envVar.key)} - ${envVar.description}`,\n );\n }\n }\n\n if (result.postInstallMessage) {\n console.log(chalk.white('\\nNext steps:'));\n console.log(` ${chalk.cyan(result.postInstallMessage)}`);\n }\n }\n\n // 5. Post-install warnings\n console.log('');\n console.log(chalk.yellow('Important:'));\n console.log(\n chalk.yellow(\n ' This plugin was installed using an automated migration.',\n ),\n );\n console.log(\n chalk.yellow(\n ' Please review the changes manually and test thoroughly before committing.',\n ),\n );\n console.log('');\n console.log(chalk.white('Tips:'));\n console.log(\n ` ${chalk.gray('-')} Run ${chalk.cyan('git diff')} to review all changes made by the migration.`,\n );\n console.log(\n ` ${chalk.gray('-')} Use an AI assistant (e.g. Claude) as a first pass to review the diff for issues.`,\n );\n console.log(\n ` ${chalk.gray('-')} Run your test suite and verify the app builds before committing.`,\n );\n console.log(\n ` ${chalk.gray('-')} To undo all changes: ${chalk.cyan('git checkout . && git clean -fd')}`,\n );\n console.log('');\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown error';\n\n console.error(chalk.red(`Error: ${message}`));\n console.log(\n chalk.yellow(\n '\\nTo revert changes, run: git checkout . && git clean -fd',\n ),\n );\n\n process.exit(1);\n }\n });\n}\n","import { dirname, join } from 'path';\nimport { tmpdir } from 'os';\n\nimport {\n PluginRegistry,\n isInstalled,\n} from '@/src/plugins-model';\nimport { getOrPromptUsername } from '@/src/utils/username-cache';\nimport { fetchRegistryItem } from '@/src/utils/install-registry-files';\nimport { validateProject } from '@/src/utils/workspace';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport { execa } from 'execa';\nimport fs from 'fs-extra';\nimport ora from 'ora';\nimport prompts from 'prompts';\n\nexport function createDiffCommand(parentCommand: Command) {\n return parentCommand\n .command('diff')\n .argument('[plugin-id]', 'Plugin to diff (e.g. feedback, waitlist)')\n .description('Show differences between installed plugin files and the latest registry version.')\n .action(async (pluginId?: string) => {\n try {\n const { variant } = await validateProject();\n const registry = await PluginRegistry.load();\n\n if (!pluginId) {\n const plugins = registry.getPluginsForVariant(variant);\n\n const installed = [];\n\n for (const p of plugins) {\n if (await isInstalled(p, variant)) {\n installed.push(p);\n }\n }\n\n if (installed.length === 0) {\n console.log(chalk.yellow('No plugins installed.'));\n return;\n }\n\n const response = await prompts({\n type: 'select',\n name: 'pluginId',\n message: 'Select a plugin to diff',\n choices: installed.map((p) => ({\n title: `${p.name} ${chalk.gray(`(${p.id})`)}`,\n value: p.id,\n })),\n });\n\n pluginId = response.pluginId as string | undefined;\n\n if (!pluginId) {\n return;\n }\n }\n\n const plugin = registry.validatePlugin(pluginId, variant);\n\n if (!(await isInstalled(plugin, variant))) {\n console.error(\n chalk.yellow(`Plugin \"${plugin.name}\" is not installed.`),\n );\n\n return;\n }\n\n const username = await getOrPromptUsername();\n\n const spinner = ora('Fetching latest plugin files...').start();\n const item = await fetchRegistryItem(variant, pluginId, username);\n spinner.succeed('Fetched latest plugin files.');\n\n const tempDir = join(tmpdir(), `makerkit-diff-${pluginId}`);\n await fs.ensureDir(tempDir);\n\n try {\n const cwd = process.cwd();\n let hasDiff = false;\n\n for (const file of item.files) {\n const localPath = join(cwd, file.target);\n const remotePath = join(tempDir, file.target);\n\n await fs.ensureDir(dirname(join(tempDir, file.target)));\n await fs.writeFile(remotePath, file.content);\n\n if (!(await fs.pathExists(localPath))) {\n console.log(chalk.green(`\\nNew file: ${file.target}`));\n hasDiff = true;\n\n continue;\n }\n\n const localContent = await fs.readFile(localPath, 'utf-8');\n\n if (localContent !== file.content) {\n hasDiff = true;\n\n console.log(chalk.white(`\\n--- ${file.target}`));\n\n await execa('git', ['diff', '--no-index', '--color', '--', localPath, remotePath], {\n stdio: 'inherit',\n reject: false,\n });\n }\n }\n\n if (!hasDiff) {\n console.log(\n chalk.green(`\\n${plugin.name} is up to date.`),\n );\n }\n } finally {\n await fs.remove(tempDir);\n }\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown error';\n\n console.error(chalk.red(`Error: ${message}`));\n process.exit(1);\n }\n });\n}\n","import { cacheUsername } from '@/src/utils/username-cache';\nimport { detectVariant } from '@/src/utils/workspace';\n\nexport interface InitRegistryOptions {\n projectPath: string;\n githubUsername: string;\n}\n\nexport interface InitRegistryResult {\n success: true;\n variant: string;\n username: string;\n}\n\nexport async function initRegistry(\n options: InitRegistryOptions,\n): Promise<InitRegistryResult> {\n const variant = await detectVariant();\n\n cacheUsername(options.githubUsername);\n\n return {\n success: true,\n variant,\n username: options.githubUsername,\n };\n}\n","import { initRegistry } from '@/src/utils/init-registry';\nimport { listPlugins } from '@/src/utils/list-plugins';\nimport { getOrPromptUsername } from '@/src/utils/username-cache';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\n\nexport function createInitCommand(parentCommand: Command) {\n return parentCommand\n .command('init')\n .description(\n 'Initialize MakerKit plugin registry in your project (one-time setup).',\n )\n .action(async () => {\n try {\n const username = await getOrPromptUsername();\n\n const initResult = await initRegistry({\n projectPath: process.cwd(),\n githubUsername: username,\n });\n\n console.log(\n `Detected project variant: ${chalk.cyan(initResult.variant)}\\n`,\n );\n\n console.log(chalk.green('Registry configured.\\n'));\n\n const pluginsResult = await listPlugins({ projectPath: process.cwd() });\n\n console.log(chalk.white('Available plugins:\\n'));\n\n for (const plugin of pluginsResult.plugins) {\n console.log(\n ` ${chalk.green(plugin.name)} ${chalk.gray(`(${plugin.id})`)}`,\n );\n }\n\n console.log(\n `\\nRun ${chalk.cyan('makerkit plugins add <plugin-id>')} to install a plugin.`,\n );\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown error';\n\n console.error(chalk.red(`Error: ${message}`));\n process.exit(1);\n }\n });\n}\n","import { listPlugins } from '@/src/utils/list-plugins';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\n\nexport function createListPluginsCommand(parentCommand: Command) {\n return parentCommand\n .command('list')\n .description('List available and installed plugins.')\n .action(async () => {\n const result = await listPlugins({ projectPath: process.cwd() });\n\n console.log(\n chalk.white(`MakerKit Plugins ${chalk.gray(`(${result.variant})`)}\\n`),\n );\n\n console.log(\n ` ${chalk.green('Plugin Name')} ${chalk.gray('(plugin-id)')} — Status\\n`,\n );\n\n let installedCount = 0;\n\n for (const plugin of result.plugins) {\n if (plugin.installed) {\n installedCount++;\n }\n\n const status = plugin.installed\n ? chalk.green('installed')\n : chalk.gray('available');\n\n console.log(\n ` ${chalk.cyan(plugin.name)} ${chalk.gray(`(${plugin.id})`)} — ${status}`,\n );\n }\n\n console.log(\n `\\n ${chalk.white(`${installedCount} installed`)} / ${chalk.gray(`${result.plugins.length} available`)}\\n`,\n );\n\n if (installedCount === 0) {\n console.log(\n `Run ${chalk.cyan('makerkit plugins init')} to set up the registry, then ${chalk.cyan('makerkit plugins add <plugin-id>')} to install.`,\n );\n }\n });\n}\n","import { join } from 'path';\n\nimport {\n PluginRegistry,\n type PluginDefinition,\n getPath,\n isInstalled,\n} from '@/src/plugins-model';\nimport { getOrPromptUsername } from '@/src/utils/username-cache';\nimport { fetchRegistryItem } from '@/src/utils/install-registry-files';\nimport { type Variant, validateProject } from '@/src/utils/workspace';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport fs from 'fs-extra';\nimport ora from 'ora';\n\nasync function isOutdated(\n plugin: PluginDefinition,\n variant: Variant,\n username: string,\n): Promise<boolean> {\n const item = await fetchRegistryItem(variant, plugin.id, username);\n const cwd = process.cwd();\n\n for (const file of item.files) {\n const localPath = join(cwd, file.target);\n\n if (!(await fs.pathExists(localPath))) {\n return true;\n }\n\n const localContent = await fs.readFile(localPath, 'utf-8');\n\n if (localContent !== file.content) {\n return true;\n }\n }\n\n return false;\n}\n\nexport function createOutdatedCommand(parentCommand: Command) {\n return parentCommand\n .command('outdated')\n .description('Check installed plugins for updates.')\n .action(async () => {\n try {\n const { variant } = await validateProject();\n const registry = await PluginRegistry.load();\n const plugins = registry.getPluginsForVariant(variant);\n\n const installed = [];\n\n for (const p of plugins) {\n if (await isInstalled(p, variant)) {\n installed.push(p);\n }\n }\n\n if (installed.length === 0) {\n console.log(chalk.yellow('No plugins installed.'));\n return;\n }\n\n const username = await getOrPromptUsername();\n\n const spinner = ora(\n `Checking ${installed.length} plugin${installed.length > 1 ? 's' : ''} for updates...`,\n ).start();\n\n const outdated: PluginDefinition[] = [];\n\n for (const plugin of installed) {\n try {\n if (await isOutdated(plugin, variant, username)) {\n outdated.push(plugin);\n }\n } catch {\n // skip plugins that fail to fetch\n }\n }\n\n spinner.stop();\n\n if (outdated.length === 0) {\n console.log(chalk.green('All plugins are up to date.'));\n return;\n }\n\n console.log(\n chalk.yellow(\n `\\n${outdated.length} plugin${outdated.length > 1 ? 's have' : ' has'} updates available:\\n`,\n ),\n );\n\n for (const plugin of outdated) {\n const pluginPath = getPath(plugin, variant);\n\n console.log(\n ` ${chalk.cyan(plugin.name)} ${chalk.gray(`(${plugin.id})`)}${pluginPath ? chalk.gray(` — ${pluginPath}`) : ''}`,\n );\n }\n\n console.log(\n `\\nRun ${chalk.cyan('makerkit plugins diff <plugin-id>')} to see what changed.`,\n );\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown error';\n\n console.error(chalk.red(`Error: ${message}`));\n process.exit(1);\n }\n });\n}\n","import { dirname, join } from 'path';\n\nimport {\n PluginRegistry,\n isInstalled,\n} from '@/src/plugins-model';\nimport { saveBaseVersions } from '@/src/utils/base-store';\nimport { getOrPromptUsername } from '@/src/utils/username-cache';\nimport { fetchRegistryItem } from '@/src/utils/install-registry-files';\nimport { validateProject } from '@/src/utils/workspace';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport fs from 'fs-extra';\nimport ora from 'ora';\nimport prompts from 'prompts';\n\nexport function createUpdateCommand(parentCommand: Command) {\n return parentCommand\n .command('update')\n .argument('[plugin-id...]', 'Plugins to update (e.g. feedback waitlist)')\n .description('Update installed plugins to the latest registry version.')\n .action(async (pluginIds?: string[]) => {\n try {\n const { variant } = await validateProject();\n const registry = await PluginRegistry.load();\n\n if (!pluginIds || pluginIds.length === 0) {\n const plugins = registry.getPluginsForVariant(variant);\n\n const installed = [];\n\n for (const p of plugins) {\n if (await isInstalled(p, variant)) {\n installed.push(p);\n }\n }\n\n if (installed.length === 0) {\n console.log(chalk.yellow('No plugins installed.'));\n return;\n }\n\n const response = await prompts({\n type: 'multiselect',\n name: 'pluginIds',\n message: 'Select plugins to update',\n choices: installed.map((p) => ({\n title: `${p.name} ${chalk.gray(`(${p.id})`)}`,\n value: p.id,\n })),\n });\n\n pluginIds = response.pluginIds as string[] | undefined ?? [];\n\n if (pluginIds.length === 0) {\n return;\n }\n }\n\n const username = await getOrPromptUsername();\n\n for (const pluginId of pluginIds) {\n const plugin = registry.validatePlugin(pluginId, variant);\n\n if (!(await isInstalled(plugin, variant))) {\n console.log(\n chalk.yellow(\n `Plugin \"${plugin.name}\" is not installed. Use \"plugins add ${pluginId}\" to install it.`,\n ),\n );\n\n continue;\n }\n\n const spinner = ora(`Fetching latest ${plugin.name} files...`).start();\n const item = await fetchRegistryItem(variant, pluginId, username);\n spinner.succeed(`Fetched latest ${plugin.name} files.`);\n\n const cwd = process.cwd();\n const modifiedFiles: string[] = [];\n\n for (const file of item.files) {\n const localPath = join(cwd, file.target);\n\n if (await fs.pathExists(localPath)) {\n const localContent = await fs.readFile(localPath, 'utf-8');\n\n if (localContent !== file.content) {\n modifiedFiles.push(file.target);\n }\n }\n }\n\n if (modifiedFiles.length === 0) {\n console.log(chalk.green(`${plugin.name} is already up to date.`));\n continue;\n }\n\n console.log(\n chalk.yellow(\n `\\n${modifiedFiles.length} file${modifiedFiles.length > 1 ? 's' : ''} will be overwritten:`,\n ),\n );\n\n for (const file of modifiedFiles) {\n console.log(` ${chalk.gray(file)}`);\n }\n\n const { confirm } = await prompts({\n type: 'confirm',\n name: 'confirm',\n message: `Update ${plugin.name}? Local changes will be lost.`,\n initial: false,\n });\n\n if (!confirm) {\n console.log(chalk.gray(`Skipped ${plugin.name}.`));\n continue;\n }\n\n const writeSpinner = ora(`Updating ${plugin.name}...`).start();\n\n for (const file of item.files) {\n const targetPath = join(cwd, file.target);\n\n await fs.ensureDir(dirname(targetPath));\n await fs.writeFile(targetPath, file.content);\n }\n\n await saveBaseVersions(pluginId, item.files);\n\n writeSpinner.succeed(`${plugin.name} updated.`);\n }\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown error';\n\n console.error(chalk.red(`Error: ${message}`));\n process.exit(1);\n }\n });\n}\n","import { createAddCommand } from '@/src/commands/plugins/add/add.command';\nimport { createDiffCommand } from '@/src/commands/plugins/diff/diff.command';\nimport { createInitCommand } from '@/src/commands/plugins/init/init.command';\nimport { createListPluginsCommand } from '@/src/commands/plugins/list/list-plugins.command';\nimport { createOutdatedCommand } from '@/src/commands/plugins/outdated/outdated.command';\nimport { createUpdateCommand } from '@/src/commands/plugins/update/update.command';\nimport { Command } from 'commander';\n\nexport const pluginsCommand = new Command()\n .name('plugins')\n .description('Manage MakerKit plugins.');\n\ncreateInitCommand(pluginsCommand);\ncreateAddCommand(pluginsCommand);\ncreateUpdateCommand(pluginsCommand);\ncreateDiffCommand(pluginsCommand);\ncreateOutdatedCommand(pluginsCommand);\ncreateListPluginsCommand(pluginsCommand);\n","import { join } from 'path';\n\nimport { execa, execaCommand } from 'execa';\nimport fs from 'fs-extra';\n\nimport { getErrorOutput, isGitClean } from '@/src/utils/git';\nimport {\n getUpstreamRemoteUrl,\n getUpstreamUrl,\n hasSshAccess,\n isUpstreamUrlValid,\n setUpstreamRemote,\n} from '@/src/utils/upstream';\nimport { validateProject } from '@/src/utils/workspace';\n\nexport interface ProjectPullOptions {\n projectPath: string;\n}\n\nexport type ProjectPullResult =\n | {\n success: true;\n variant: string;\n upstreamUrl: string;\n alreadyUpToDate: boolean;\n message: string;\n }\n | {\n success: false;\n variant: string;\n upstreamUrl: string;\n hasConflicts: true;\n conflictCount: number;\n conflicts: {\n path: string;\n conflicted?: string;\n base?: string;\n ours?: string;\n theirs?: string;\n }[];\n instructions: string;\n }\n | { success: false; reason: string };\n\nexport async function projectPull(\n options: ProjectPullOptions,\n): Promise<ProjectPullResult> {\n const { variant } = await validateProject();\n\n const gitClean = await isGitClean();\n\n if (!gitClean) {\n return {\n success: false,\n reason:\n 'Git working directory has uncommitted changes. Please commit or stash them before pulling upstream updates.',\n };\n }\n\n let currentUrl = await getUpstreamRemoteUrl();\n\n if (!currentUrl) {\n const useSsh = await hasSshAccess();\n const url = getUpstreamUrl(variant, useSsh);\n\n await setUpstreamRemote(url);\n currentUrl = url;\n } else if (!isUpstreamUrlValid(currentUrl, variant)) {\n const useSsh = currentUrl.startsWith('git@');\n const expectedUrl = getUpstreamUrl(variant, useSsh);\n\n return {\n success: false,\n reason:\n `Upstream remote points to \"${currentUrl}\" but expected \"${expectedUrl}\" for variant \"${variant}\". ` +\n 'Please ask the user whether to update the upstream URL, then run: git remote set-url upstream <correct-url>',\n };\n }\n\n await execaCommand('git fetch upstream');\n\n try {\n const { stdout } = await execaCommand(\n 'git merge upstream/main --no-edit',\n );\n\n const alreadyUpToDate = stdout.includes('Already up to date');\n\n return {\n success: true,\n variant,\n upstreamUrl: currentUrl,\n alreadyUpToDate,\n message: alreadyUpToDate\n ? 'Already up to date.'\n : 'Successfully merged upstream changes.',\n };\n } catch (mergeError) {\n const output = getErrorOutput(mergeError);\n const isConflict =\n output.includes('CONFLICT') ||\n output.includes('Automatic merge failed');\n\n if (!isConflict) {\n throw new Error(`Merge failed: ${output}`);\n }\n\n const { stdout: statusOutput } = await execaCommand(\n 'git diff --name-only --diff-filter=U',\n );\n\n const conflictPaths = statusOutput\n .trim()\n .split('\\n')\n .filter(Boolean);\n\n const cwd = process.cwd();\n\n const conflicts = await Promise.all(\n conflictPaths.map(async (filePath) => {\n let conflicted: string | undefined;\n\n try {\n conflicted = await fs.readFile(join(cwd, filePath), 'utf-8');\n } catch {\n conflicted = undefined;\n }\n\n let base: string | undefined;\n let ours: string | undefined;\n let theirs: string | undefined;\n\n try {\n const { stdout: b } = await execa('git', [\n 'show',\n `:1:${filePath}`,\n ]);\n base = b;\n } catch {\n base = undefined;\n }\n\n try {\n const { stdout: o } = await execa('git', [\n 'show',\n `:2:${filePath}`,\n ]);\n ours = o;\n } catch {\n ours = undefined;\n }\n\n try {\n const { stdout: t } = await execa('git', [\n 'show',\n `:3:${filePath}`,\n ]);\n theirs = t;\n } catch {\n theirs = undefined;\n }\n\n return { path: filePath, conflicted, base, ours, theirs };\n }),\n );\n\n return {\n success: false,\n variant,\n upstreamUrl: currentUrl,\n hasConflicts: true,\n conflictCount: conflicts.length,\n conflicts,\n instructions:\n 'Merge conflicts detected. For each conflict: review base, ours (local), and theirs (upstream) versions. ' +\n 'Produce resolved content and call makerkit_project_resolve_conflicts. ' +\n 'Ask the user for guidance when the intent behind local changes is unclear.',\n };\n }\n}\n","import { VARIANT_CATALOG } from '@/src/utils/list-variants';\nimport { projectPull } from '@/src/utils/project-pull';\nimport chalk from 'chalk';\nimport { Command } from 'commander';\nimport ora from 'ora';\n\nexport function createProjectUpdateCommand(parentCommand: Command) {\n return parentCommand\n .command('update')\n .description(\n 'Pull the latest changes from the upstream MakerKit repository.',\n )\n .action(async () => {\n try {\n const spinner = ora('Pulling latest changes from upstream...').start();\n\n const result = await projectPull({ projectPath: process.cwd() });\n\n if (result.success) {\n const displayName =\n VARIANT_CATALOG.find((v) => v.id === result.variant)?.name ??\n result.variant;\n\n if (result.alreadyUpToDate) {\n spinner.succeed(\n `Already up to date. (${chalk.cyan(displayName)})`,\n );\n } else {\n spinner.succeed(\n `Successfully pulled latest changes from upstream. (${chalk.cyan(displayName)})`,\n );\n }\n } else if ('hasConflicts' in result) {\n spinner.fail('Merge conflicts detected.');\n\n console.log(\n chalk.yellow(\n `\\n${result.conflictCount} conflicting file(s):`,\n ),\n );\n\n for (const conflict of result.conflicts) {\n console.log(` ${chalk.gray('-')} ${conflict.path}`);\n }\n\n console.log(\n chalk.yellow('\\nPlease resolve them manually:'),\n );\n\n console.log(chalk.gray(' 1. Fix the conflicting files'));\n console.log(chalk.gray(' 2. Run: git add .'));\n console.log(chalk.gray(' 3. Run: git commit'));\n\n process.exit(1);\n } else {\n spinner.fail('Failed to pull from upstream.');\n console.error(chalk.red(`\\n${result.reason}`));\n process.exit(1);\n }\n } catch (error) {\n const message =\n error instanceof Error ? error.message : 'Unknown error';\n\n console.error(chalk.red(`Error: ${message}`));\n process.exit(1);\n }\n });\n}\n","import { createProjectUpdateCommand } from '@/src/commands/project/update/update.command';\nimport { Command } from 'commander';\n\nexport const projectCommand = new Command()\n .name('project')\n .description('Manage your MakerKit project.');\n\ncreateProjectUpdateCommand(projectCommand);\n","#!/usr/bin/env node\nimport { newCommand } from '@/src/commands/new/new.command';\nimport { pluginsCommand } from '@/src/commands/plugins/plugins.command';\nimport { projectCommand } from '@/src/commands/project/project.command';\nimport { Command } from 'commander';\nimport { config } from 'dotenv';\n\nimport { CLI_VERSION } from '@/src/version';\n\nconfig({\n path: '.env.local',\n});\n\nprocess.on('SIGINT', () => process.exit(0));\nprocess.on('SIGTERM', () => process.exit(0));\n\nasync function main() {\n const program = new Command()\n .name('makerkit')\n .description(\n 'Your SaaS Kit companion. Add plugins, manage migrations, and more.'\n )\n .version(CLI_VERSION, '-v, --version', 'display the version number');\n\n program.addCommand(newCommand).addCommand(pluginsCommand).addCommand(projectCommand);\n\n program.parse();\n}\n\nvoid main();\n"],"mappings":"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","names":["join","fs","config","join","fs","join","fs","join","fs","join","fs","join","fs","execaCommand","execaCommand","dirname","join","fs","execaCommand","join","fs","prompts","join","fs","prompts","join","fs","chalk","ora","prompts","dirname","join","tmpdir","chalk","execa","fs","ora","prompts","join","tmpdir","dirname","chalk","chalk","join","chalk","fs","ora","join","dirname","join","chalk","fs","ora","prompts","join","dirname","Command","join","execa","execaCommand","fs","execaCommand","fs","join","execa","chalk","ora","Command","Command","Command"]}
|