Skip to main content
Glama

Prisma MCP Server

Official
by prisma
Apache 2.0
4
44,192
  • Linux
  • Apple
generateInFolder.ts3.91 kB
import fs from 'node:fs' import path from 'node:path' import { generateClient } from '@prisma/client-generator-js' import Debug from '@prisma/debug' import { getEnginesPath } from '@prisma/engines' import { getBinaryTargetForCurrentPlatform, getNodeAPIName } from '@prisma/get-platform' import { type GetSchemaResult, getSchemaWithPath, mergeSchemas } from '@prisma/internals' import { ClientEngineType, extractPreviewFeatures, getClientEngineType, getConfig, getDMMF, getPackedPackage, } from '@prisma/internals' import copy from '@timsuchanek/copy' import { performance } from 'perf_hooks' import { ensureTestClientQueryEngine } from './ensureTestClientQueryEngine' const debug = Debug('prisma:generateInFolder') export interface GenerateInFolderOptions { projectDir: string packageSource?: string overrideEngineType?: ClientEngineType } export async function generateInFolder({ projectDir, packageSource, overrideEngineType, }: GenerateInFolderOptions): Promise<number> { const before = performance.now() if (!projectDir) { throw new Error(`Project dir missing. Usage: ts-node examples/generate.ts examples/accounts`) } if (!fs.existsSync(projectDir)) { throw new Error(`Path ${projectDir} does not exist`) } let schemaPathResult: GetSchemaResult | null = null const schemaNotFoundError = new Error(`Could not find any schema.prisma in ${projectDir} or sub directories.`) try { schemaPathResult = await getSchemaWithPath(undefined, undefined, { cwd: projectDir }) } catch (e) { debug('Error in getSchemaPath', e) } if (!schemaPathResult) { throw schemaNotFoundError } const { schemas, schemaPath } = schemaPathResult if (overrideEngineType) { process.env.PRISMA_CLIENT_ENGINE_TYPE = overrideEngineType } const config = await getConfig({ datamodel: schemas, ignoreEnvVarErrors: true }) const previewFeatures = extractPreviewFeatures(config.generators) const clientEngineType = getClientEngineType(config.generators[0]) const outputDir = path.join(projectDir, 'node_modules/@prisma/client') await fs.promises.rm(outputDir, { force: true, recursive: true }) if (packageSource) { await copy({ from: packageSource, // when using yarn pack and extracting it, it includes a folder called "package" to: outputDir, recursive: true, parallelJobs: 20, overwrite: true, }) } else { await getPackedPackage('@prisma/client', outputDir) } const binaryTarget = await getBinaryTargetForCurrentPlatform() const enginesPath = getEnginesPath() const queryEngineLibraryPath = process.env.PRISMA_QUERY_ENGINE_LIBRARY ?? path.join(enginesPath, getNodeAPIName(binaryTarget, 'fs')) const queryEngineBinaryPath = process.env.PRISMA_QUERY_ENGINE_BINARY ?? path.join(enginesPath, `query-engine-${binaryTarget}${binaryTarget === 'windows' ? '.exe' : ''}`) await ensureTestClientQueryEngine(clientEngineType, binaryTarget) const binaryPaths = clientEngineType === ClientEngineType.Library ? { libqueryEngine: { [binaryTarget]: queryEngineLibraryPath, }, } : { queryEngine: { [binaryTarget]: queryEngineBinaryPath, }, } // TODO: use engine.getDmmf() const dmmf = await getDMMF({ datamodel: schemas, previewFeatures, }) const schema = mergeSchemas({ schemas }) await generateClient({ binaryPaths, datamodel: schema, dmmf, ...config, outputDir, schemaPath, testMode: true, copyRuntime: false, runtimeSourcePath: path.join(__dirname, '../../runtime'), generator: config.generators[0], clientVersion: 'local', engineVersion: 'local', activeProvider: config.datasources[0].activeProvider, }) const time = performance.now() - before debug(`Done generating client in ${time}`) return time }

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