.agents/skills/prisma-postgres-setup/SKILL.md
Set up a new Prisma Postgres database and connect it to a local project using the Management API. Use when asked to "set up a database", "create a Prisma Postgres project", "get a connection string", "connect my app to Prisma Postgres", or "provision a database".
npx skillsauth add Mohamedghaly140/sg-shop-web prisma-postgres-setupInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Procedural skill that guides you through provisioning a new Prisma Postgres database via the Management API and connecting it to a local project.
Use this skill when:
Do not use this skill when:
prisma-postgres-cicdprisma-postgres-integratorreferences/auth.md)When presenting choices to the user (region selection, project deletion, etc.), use your platform's interactive selection mechanism (e.g., ask tool in Claude Code, structured prompts in other agents). Do not print static tables and ask the user to type a value — present selectable options so the user can pick with minimal effort.
Follow these steps in order. Each step includes the API call to make and how to handle the response.
You need a service token. Try these methods in order:
1a. Token in the user's prompt
Check if the user included a service token in their initial message (e.g., "Set up Prisma Postgres with token eyJ..."). If so, use it exactly as provided — do not truncate, re-encode, or round-trip it through a file. Store it in a shell variable for subsequent calls.
1b. Token in the environment
Check for PRISMA_SERVICE_TOKEN in the environment or .env file.
1c. Ask the user to create one
If no token is available, instruct the user:
Create a service token in Prisma Console → Workspace Settings → Service Tokens. Copy the token and paste it here.
Read references/auth.md for details on service token creation.
Once you have a token, store it in a shell variable (PRISMA_SERVICE_TOKEN) and use it for all subsequent API calls.
Fetch the list of available Prisma Postgres regions to let the user choose where to deploy.
curl -s -H "Authorization: Bearer $PRISMA_SERVICE_TOKEN" \
https://api.prisma.io/v1/regions/postgres
The response contains an array of regions with id, name, and status. Only present regions where status is available.
Present the regions as an interactive menu — let the user pick from options rather than typing a region ID manually.
Read references/endpoints.md for the full response shape.
curl -s -X POST https://api.prisma.io/v1/projects \
-H "Authorization: Bearer $PRISMA_SERVICE_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"name": "<project-name>",
"region": "<region-id>",
"createDatabase": true
}'
Use the current directory name as the project name by default.
The response is wrapped in { "data": { ... } }. Extract:
data.id — the project ID (prefixed with proj_)data.database.id — the database ID (prefixed with db_)data.database.connections[0].endpoints.direct.connectionString — the direct PostgreSQL connection stringUse the direct connection string (endpoints.direct.connectionString). Do not use the pooled or accelerate endpoints — those are for legacy Accelerate setups and not needed for new projects.
If the response status is provisioning, wait a few seconds and poll GET /v1/databases/<database-id> until status is ready.
If creation fails due to a database limit, list the user's existing projects and present them as an interactive menu for deletion. After the user picks one, delete it and retry.
Read references/endpoints.md for the full request/response shapes.
If you need a dedicated connection (e.g., per-developer or per-environment), create one:
curl -s -X POST https://api.prisma.io/v1/databases/<database-id>/connections \
-H "Authorization: Bearer $PRISMA_SERVICE_TOKEN" \
-H "Content-Type: application/json" \
-d '{ "name": "dev" }'
Extract the direct connection string from data.endpoints.direct.connectionString.
npm install prisma @prisma/client @prisma/adapter-pg pg dotenv
All five packages are required:
prisma — CLI for migrations, schema push, client generation@prisma/client — the generated query client@prisma/adapter-pg — Prisma 7 driver adapter for direct PostgreSQL connectionspg — Node.js PostgreSQL driver (used by the adapter)dotenv — loads .env variables for prisma.config.ts.env. Append to the file if it already exists — do not overwrite existing entries:DATABASE_URL="<direct-connection-string>"
Verify .gitignore includes .env. Create .gitignore if it does not exist. Warn the user if .env is not gitignored.
Ensure package.json has "type": "module" set (Prisma 7 generates ESM output).
If prisma/schema.prisma does not exist, run npx prisma init to scaffold the project. This creates both prisma/schema.prisma and prisma.config.ts.
Ensure schema.prisma has the postgresql provider and no url or directUrl in the datasource block (Prisma 7 manages connection URLs in prisma.config.ts, not in the schema):
datasource db {
provider = "postgresql"
}
prisma.config.ts loads the connection URL from the environment:import path from 'node:path'
import { defineConfig } from 'prisma/config'
import 'dotenv/config'
export default defineConfig({
earlyAccess: true,
schema: path.join(import.meta.dirname, 'prisma', 'schema.prisma'),
datasource: {
url: process.env.DATABASE_URL!,
},
})
Important Prisma 7 notes:
prisma.config.ts, never in schema.prismaschema.prisma must be "postgresql" (not "prismaPostgres")dotenv/config must be imported in prisma.config.ts to load .env variablesIf the schema already has models, skip to pushing. Otherwise, present these options as an interactive menu:
prisma/schema.prisma and come back when ready. Wait for them before proceeding.prisma/schema.prisma. Show the user what was added and ask if they want to adjust it before pushing.Once the schema has models and the user is ready, create a migration and generate the client:
npx prisma migrate dev --name init
This creates migration files in prisma/migrations/ and generates the client in one step. Migration history is essential for CI/CD workflows (prisma migrate deploy) and production deployments.
Only use npx prisma db push if the user explicitly asks for prototyping-only mode (no migration history). In that case, follow it with npx prisma generate.
After generating the client, create and run a quick verification script to confirm everything works end-to-end. This is critical — do not skip this step.
Create a file named test-connection.ts:
import 'dotenv/config'
import pg from 'pg'
import { PrismaPg } from '@prisma/adapter-pg'
import { PrismaClient } from './generated/prisma/client.js'
const pool = new pg.Pool({ connectionString: process.env.DATABASE_URL })
const adapter = new PrismaPg(pool)
const prisma = new PrismaClient({ adapter })
const result = await prisma.$queryRawUnsafe('SELECT 1 as connected')
console.log('Connected to Prisma Postgres:', result)
await prisma.$disconnect()
await pool.end()
Run it:
npx tsx test-connection.ts
Prisma 7 client instantiation rules:
./generated/prisma/client.js (not ./generated/prisma)pg.Pool with the DATABASE_URL connection stringPrismaPg adapter{ adapter } to the PrismaClient constructordatasourceUrl — that option does not exist in Prisma 7new PrismaClient() with no arguments — it will throwAfter verification succeeds, delete test-connection.ts.
Then share links for the user to explore their database:
npx prisma studio — opens a visual data browser locallyhttps://console.prisma.io/<workspaceId>/<projectId>/<databaseId>/dashboard — strip the prefixes (wksp_, proj_, db_) from the IDs returned in Step 3 to build this URLRead references/prisma7-client.md for the full client instantiation reference.
Read references/api-basics.md for the full error reference. Key self-correction patterns:
| HTTP Status | Error Code | Action |
|---|---|---|
| 401 | authentication-failed | Service token is invalid or expired. Ask the user to create a new one in Console → Workspace Settings → Service Tokens. |
| 404 | resource-not-found | Check that the resource ID includes the correct prefix (proj_, db_, con_). |
| 422 | validation-error | Check request body against the endpoint schema. Common: missing name, invalid region. |
| 429 | rate-limit-exceeded | Back off and retry after a few seconds. |
Detailed API and usage information is in:
references/auth.md — Service token creation and usage
references/api-basics.md — Base URL, envelope, IDs, errors, pagination
references/endpoints.md — Endpoint details for projects, databases, connections, regions
references/prisma7-client.md — Prisma 7 client instantiation and usage patterns
development
Enforce web security and avoid security vulnerabilities
development
Build clean, scalable UIs with Tailwind CSS using modern utilities and variants
development
Utilize built-in browser APIs (like Popover API, View Transitions etc) instead of building features manually via JavaScript
development
Build clean, modern React components that apply common best practices and avoid common pitfalls like unnecessary state management or useEffect usage