Skip to main content
Glama

Prisma MCP Server

Official
by prisma
Apache 2.0
4
44,192
  • Linux
  • Apple
bin.ts3.57 kB
#!/usr/bin/env tsx import { loadConfigFromFile } from '@prisma/config' import Debug from '@prisma/debug' import { enginesVersion } from '@prisma/engines-version' import { arg, handlePanic, HelpError, isError } from '@prisma/internals' import { bold, red } from 'kleur/colors' import { version as packageVersion } from '../package.json' import { CLI } from './CLI' import { DbCommand } from './commands/DbCommand' import { DbExecute } from './commands/DbExecute' import { DbPull } from './commands/DbPull' import { DbPush } from './commands/DbPush' // import { DbDrop } from './commands/DbDrop' import { DbSeed } from './commands/DbSeed' import { MigrateCommand } from './commands/MigrateCommand' import { MigrateDeploy } from './commands/MigrateDeploy' import { MigrateDev } from './commands/MigrateDev' import { MigrateDiff } from './commands/MigrateDiff' import { MigrateReset } from './commands/MigrateReset' import { MigrateResolve } from './commands/MigrateResolve' import { MigrateStatus } from './commands/MigrateStatus' import { getDatabaseVersionSafe } from './utils/getDatabaseVersionSafe' process.on('uncaughtException', (e) => { console.log(e) }) process.on('unhandledRejection', (e, promise) => { console.log(String(e), String(promise)) }) // Listen to Ctr + C and exit process.once('SIGINT', () => { process.exit(130) }) const commandArray = process.argv.slice(2) const args = arg( commandArray, { '--config': String, }, false, true, ) /** * Main function */ async function main(): Promise<number> { // create a new CLI with our subcommands const cli = CLI.new({ migrate: MigrateCommand.new({ dev: MigrateDev.new(), status: MigrateStatus.new(), resolve: MigrateResolve.new(), reset: MigrateReset.new(), deploy: MigrateDeploy.new(), diff: MigrateDiff.new(), }), db: DbCommand.new({ execute: DbExecute.new(), pull: DbPull.new(), push: DbPush.new(), // drop: DbDrop.new(), seed: DbSeed.new(), }), }) const { config, error } = await loadConfigFromFile({ configFile: args['--config'] }) if (error) { console.error(`Failed to load config file: ${error._tag}`) return 1 } // Execute the command const result = await cli.parse(commandArray, config) // Did it error? if (result instanceof HelpError) { console.error(result) // TODO: We could do like Bash (and other) // = return an exit status of 2 to indicate incorrect usage like invalid options or missing arguments. // https://tldp.org/LDP/abs/html/exitcodes.html return 1 } else if (isError(result)) { console.error(result) return 1 } // Success console.log(result) return 0 } /** * Run our program */ main() .then((code) => { if (code !== 0) { process.exit(code) } }) .catch((error) => { if (error.rustStack) { handlePanic({ error, cliVersion: packageVersion, enginesVersion, command: commandArray.join(' '), getDatabaseVersionSafe, }) .catch((e) => { if (Debug.enabled('migrate')) { console.error(red(bold('Error: ')) + e.stack) } else { console.error(red(bold('Error: ')) + e.message) } }) .finally(() => { process.exit(1) }) } else { if (Debug.enabled('migrate')) { console.error(red(bold('Error: ')) + error.stack) } else { console.error(red(bold('Error: ')) + error.message) } process.exit(1) } })

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/prisma/prisma'

If you have feedback or need assistance with the MCP directory API, please join our Discord server