@prisma/dev 0.0.0-dev.202505092340 → 0.0.0-dev.202505092348

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.
Files changed (2) hide show
  1. package/dist/index.js +5 -5
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
- import{createSecureServer as Se}from"http2";import{promisify as ve}from"util";import{serve as Pe}from"@hono/node-server";import be from"@prisma/get-platform";import{Hono as N}from"hono/tiny";import{looseObject as W,parse as Q,pipe as X,regex as z,string as Y,url as Z}from"valibot";var ee=/^(postgres|postgresql):\/\//,te=W({databaseUrl:X(Y(),Z(),z(ee))});function A(e){return Buffer.from(JSON.stringify(e),"utf8").toString("base64")}function k(e){try{let t=Buffer.from(e,"base64").toString("utf8");return Q(te,JSON.parse(t))}catch{return null}}import{mkdir as ae,readFile as $,writeFile as C}from"fs/promises";import{join as P}from"path";import{certificateFor as ce}from"@expo/devcert";import{chmod as ne,stat as re,writeFile as oe}from"fs/promises";import se from"env-paths";import{inflate as ie}from"pako";var w=se("prisma-dev").cache;function O(e,t){return`${w}/${e}/${t}`}async function g(e){try{return await re(e),!0}catch(t){if(t!=null&&typeof t=="object"&&"code"in t&&t.code==="ENOENT")return!1;throw t}}async function B(e,t){let n=ie(e);await oe(t,n),await ne(t,"755")}var b=P(w,"certs"),S=P(b,"tls.cert"),v=P(b,"tls.key");async function I(){if(await ae(b,{recursive:!0}),await g(S)&&await g(v))return{cert:await $(S),key:await $(v)};let e=await ce("localhost");return await Promise.all([C(S,e.cert),C(v,e.key)]),{cert:e.cert,key:e.key}}import{spawn as le}from"child_process";import{once as me}from"events";import{mkdir as pe}from"fs/promises";import{join as ue}from"path";function d(){let e,t,n=new Promise((r,o)=>{e=r,t=o});return{fail:t,promise:n,succeed:e}}var y=class e{static#n=new Map;#t;#e;constructor(t){this.#t=t,this.#e=null}static async get(t){let n=`${t.schemaHash}:${t.clientVersion}`;try{let r=e.#n.get(n);if(r)return r;let o=new e(t);return e.#n.set(n,o),await o.start(),o}finally{e.stopAll(n)}}static async stopAll(t){let r=(await Promise.allSettled(Array.from(e.#n.entries()).filter(([o])=>o!==t).map(async([o,s])=>{try{await s.stop()}finally{e.#n.delete(o)}}))).filter(o=>o.status==="rejected").map(o=>o.reason);if(r.length>0)throw new AggregateError(r,"Failed to stop engines")}async commitTransaction(t,n){return await this.#r(t,n,"commit")}async request(t,n){let{url:r}=await this.#e,o=await fetch(r,{body:typeof t=="string"?t:JSON.stringify(t),headers:{...n,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await u.fromResponse(o);return await o.text()}async rollbackTransaction(t,n){return await this.#r(t,n,"rollback")}async startTransaction(t,n){let{url:r}=await this.#e,o=await fetch(`${r}/transaction/start`,{body:JSON.stringify(t),headers:{...n,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await u.fromResponse(o);return await o.json()}async start(){if(this.#e!=null)return;let t=await this.#o(),n=le(t,["--enable-raw-queries","--enable-telemetry-in-response","--port","0"],{env:{LOG_QUERIES:"y",PRISMA_DML:this.#t.base64Schema,QE_LOG_LEVEL:"TRACE",RUST_BACKTRACE:"1",RUST_LOG:"info"},stdio:["ignore","pipe","pipe"],windowsHide:!0});n.stderr.setEncoding("utf8"),n.stdout.setEncoding("utf8");let{fail:r,promise:o,succeed:s}=d();this.#e=o;let a=i=>{let c=i.split(`
3
- `).find(G=>G.includes("Started query engine http server"));if(!c)return;n.stdout.removeListener("data",a);let{fields:l}=JSON.parse(c);if(l==null)return r(new Error(`Unexpected data during initialization, "fields" are missing: ${i}`));let{ip:p,port:m}=l;if(p==null||m==null)return r(new Error(`This version of query-engine is not compatible with minippg, "ip" and "port" are missing in the startup log entry.
4
- Received data: ${i}`));s({childProcess:n,url:`http://${p}:${m}`})};n.once("error",i=>{this.#e=null,r(new f(String(i)))}),n.once("exit",(i,c)=>{this.#e=null,r(new f(`Query Engine exited with code ${i} and signal ${c}`))}),n.stdout.on("data",a),n.stderr.on("data",i=>{console.error(i)}),await this.#e}async stop(){if(this.#e==null)return;let{childProcess:t}=await this.#e;t.exitCode==null&&t.signalCode==null&&(t.kill(),await me(t,"exit"))}async#o(){let t=await this.#s(),n=O(this.#t.clientVersion,t);await pe(n,{recursive:!0});let{platform:r}=this.#t.platform,o=r==="windows"?".exe":"",s=ue(n,`query-engine-${r}${o}`);return await g(s)||await this.#i({commitHash:t,extension:o,engineBinaryPath:s}),s}async#s(){let t=await fetch(`https://registry.npmjs.org/@prisma/client/${this.#t.clientVersion}`);if(!t.ok)throw new Error(`Couldn't fetch package.json from npm registry, status code: ${t.status}`);let r=(await t.json()).dependencies?.["@prisma/engines-version"];if(!r)throw new Error("Couldn't find engines version in package.json");let o=r.split(".").at(-1);if(!o)throw new Error("Couldn't find commit hash in engines version");return o}async#i(t){let{commitHash:n,extension:r,engineBinaryPath:o}=t,{platform:s}=this.#t.platform,a=`https://binaries.prisma.sh/all_commits/${n}/${s}/query-engine${r}.gz`,i=await fetch(a);if(!i.ok)throw new Error(`Couldn't download engine. URL: ${a}, status code: ${i.status}`);await B(await i.arrayBuffer(),o)}async#r(t,n,r){let{url:o}=await this.#e,s=await fetch(`${o}/transaction/${t}/${r}`,{headers:{...n,"Content-Type":"application/json"},method:"POST"});if(!s.ok)throw await u.fromResponse(s);try{return await s.json()}catch{return{}}}},f=class extends Error{name="EngineStartError"},u=class e extends Error{constructor(n,r,o){super(`${n}: Query Engine response status ${r}, body: ${o}`);this.action=n;this.statusCode=r;this.responseBody=o}name="EngineHttpError";static async fromResponse(n){let r=new URL(n.url),o=await n.text();return new e(r.pathname,n.status,o)}};import{Buffer as x}from"buffer";function D(e){let t=e.req.param("schemaHash"),r=e.get("schemasByHash").get(t);return r==null?e.json({EngineNotStarted:{reason:"SchemaMissing"}},404):{schemaHash:t,schemas:r}}var de=/datasource\s+db\s+[\w\s\d{="[\])(]+}/;function _(e,t){let n=x.from(e,"base64").toString("utf8"),r=`datasource db {
2
+ import{createSecureServer as Se}from"http2";import{promisify as ve}from"util";import{serve as Pe}from"@hono/node-server";import be from"@prisma/get-platform";import{Hono as N}from"hono/tiny";import{looseObject as G,parse as W,pipe as Q,regex as X,string as Y,url as Z}from"valibot";var ee=/^(postgres|postgresql):\/\//,te=G({databaseUrl:Q(Y(),Z(),X(ee))});function A(t){return Buffer.from(JSON.stringify(t),"utf8").toString("base64")}function k(t){try{let e=Buffer.from(t,"base64").toString("utf8");return W(te,JSON.parse(e))}catch{return null}}import{mkdir as ae,readFile as $,writeFile as C}from"fs/promises";import{join as P}from"path";import{certificateFor as ce}from"@expo/devcert";import{chmod as ne,stat as re,writeFile as oe}from"fs/promises";import se from"env-paths";import{inflate as ie}from"pako";var w=se("prisma-dev").cache;function O(t,e){return`${w}/${t}/${e}`}async function g(t){try{return await re(t),!0}catch(e){if(e!=null&&typeof e=="object"&&"code"in e&&e.code==="ENOENT")return!1;throw e}}async function B(t,e){let n=ie(t);await oe(e,n),await ne(e,"755")}var b=P(w,"certs"),S=P(b,"tls.cert"),v=P(b,"tls.key");async function I(){if(await ae(b,{recursive:!0}),await g(S)&&await g(v))return{cert:await $(S),key:await $(v)};let t=await ce("localhost");return await Promise.all([C(S,t.cert),C(v,t.key)]),{cert:t.cert,key:t.key}}import{spawn as le}from"child_process";import{once as me}from"events";import{mkdir as pe}from"fs/promises";import{join as ue}from"path";function d(){let t,e,n=new Promise((r,o)=>{t=r,e=o});return{fail:e,promise:n,succeed:t}}var y=class t{static#n=new Map;#t;#e;constructor(e){this.#t=e,this.#e=null}static async get(e){let n=`${e.schemaHash}:${e.clientVersion}`;try{let r=t.#n.get(n);if(r)return r;let o=new t(e);return t.#n.set(n,o),await o.start(),o}finally{t.stopAll(n)}}static async stopAll(e){let r=(await Promise.allSettled(Array.from(t.#n.entries()).filter(([o])=>o!==e).map(async([o,s])=>{try{await s.stop()}finally{t.#n.delete(o)}}))).filter(o=>o.status==="rejected").map(o=>o.reason);if(r.length>0)throw new AggregateError(r,"Failed to stop engines")}async commitTransaction(e,n){return await this.#o(e,n,"commit")}async request(e,n){let{url:r}=await this.#e,o=this.#r(n),s=await fetch(r,{body:typeof e=="string"?e:JSON.stringify(e),headers:{...o,"Content-Type":"application/json"},method:"POST"});if(!s.ok)throw await u.fromResponse(s);return await s.text()}async rollbackTransaction(e,n){return await this.#o(e,n,"rollback")}async startTransaction(e,n){let{url:r}=await this.#e,o=this.#r(n),s=await fetch(`${r}/transaction/start`,{body:JSON.stringify(e),headers:{...o,"Content-Type":"application/json"},method:"POST"});if(!s.ok)throw await u.fromResponse(s);return await s.json()}async start(){if(this.#e!=null)return;let e=await this.#s(),n=le(e,["--enable-raw-queries","--enable-telemetry-in-response","--port","0"],{env:{LOG_QUERIES:"y",PRISMA_DML:this.#t.base64Schema,QE_LOG_LEVEL:"TRACE",RUST_BACKTRACE:"1",RUST_LOG:"info"},stdio:["ignore","pipe","pipe"],windowsHide:!0});n.stderr.setEncoding("utf8"),n.stdout.setEncoding("utf8");let{fail:r,promise:o,succeed:s}=d();this.#e=o;let a=i=>{let c=i.split(`
3
+ `).find(J=>J.includes("Started query engine http server"));if(!c)return;n.stdout.removeListener("data",a);let{fields:l}=JSON.parse(c);if(l==null)return r(new Error(`Unexpected data during initialization, "fields" are missing: ${i}`));let{ip:p,port:m}=l;if(p==null||m==null)return r(new Error(`This version of query-engine is not compatible with minippg, "ip" and "port" are missing in the startup log entry.
4
+ Received data: ${i}`));s({childProcess:n,url:`http://${p}:${m}`})};n.once("error",i=>{this.#e=null,r(new f(String(i)))}),n.once("exit",(i,c)=>{this.#e=null,r(new f(`Query Engine exited with code ${i} and signal ${c}`))}),n.stdout.on("data",a),n.stderr.on("data",i=>{console.error(i)}),await this.#e}async stop(){if(this.#e==null)return;let{childProcess:e}=await this.#e;e.exitCode==null&&e.signalCode==null&&(e.kill(),await me(e,"exit"))}async#s(){let e=await this.#i(),n=O(this.#t.clientVersion,e);await pe(n,{recursive:!0});let{platform:r}=this.#t.platform,o=r==="windows"?".exe":"",s=ue(n,`query-engine-${r}${o}`);return await g(s)||await this.#a({commitHash:e,extension:o,engineBinaryPath:s}),s}async#i(){let e=await fetch(`https://registry.npmjs.org/@prisma/client/${this.#t.clientVersion}`);if(!e.ok)throw new Error(`Couldn't fetch package.json from npm registry, status code: ${e.status}`);let r=(await e.json()).dependencies?.["@prisma/engines-version"];if(!r)throw new Error("Couldn't find engines version in package.json");let o=r.split(".").at(-1);if(!o)throw new Error("Couldn't find commit hash in engines version");return o}async#a(e){let{commitHash:n,extension:r,engineBinaryPath:o}=e,{platform:s}=this.#t.platform,a=`https://binaries.prisma.sh/all_commits/${n}/${s}/query-engine${r}.gz`,i=await fetch(a);if(!i.ok)throw new Error(`Couldn't download engine. URL: ${a}, status code: ${i.status}`);await B(await i.arrayBuffer(),o)}#r(e){let n={};for(let[r,o]of Object.entries(e))o!=null&&(n[r]=o);return n}async#o(e,n,r){let{url:o}=await this.#e,s=this.#r(n),a=await fetch(`${o}/transaction/${e}/${r}`,{headers:{...s,"Content-Type":"application/json"},method:"POST"});if(!a.ok)throw await u.fromResponse(a);try{return await a.json()}catch{return{}}}},f=class extends Error{name="EngineStartError"},u=class t extends Error{constructor(n,r,o){super(`${n}: Query Engine response status ${r}, body: ${o}`);this.action=n;this.statusCode=r;this.responseBody=o}name="EngineHttpError";static async fromResponse(n){let r=new URL(n.url),o=await n.text();return new t(r.pathname,n.status,o)}};import{Buffer as x}from"buffer";function D(t){let e=t.req.param("schemaHash"),r=t.get("schemasByHash").get(e);return r==null?t.json({EngineNotStarted:{reason:"SchemaMissing"}},404):{schemaHash:e,schemas:r}}var de=/datasource\s+db\s+[\w\s\d{="[\])(]+}/;function _(t,e){let n=x.from(t,"base64").toString("utf8"),r=`datasource db {
5
5
  provider = "postgresql"
6
- url = "${t}"
7
- }`,o=n.replace(de,r);return x.from(o,"utf8").toString("base64")}import{integer as j,looseObject as fe,minValue as L,number as E,object as ge,pipe as q,safeParse as K,string as V,union as he}from"valibot";var ye=ge({isolation_level:V(),max_wait:q(E(),j(),L(0)),timeout:q(E(),j(),L(0))});async function U(e){let{output:t,success:n}=K(ye,await e.req.parseBody());return n?t:e.json({EngineNotStarted:{reason:"InvalidRequest"}},400)}var we=fe({id:he([V(),E()])});function M(e,t){let{output:n,success:r}=K(we,e);return r?n:t.json({EngineMalfunction:{}},500)}async function F(e,t,n){let r=await Ee(e,t,n),o=await I(),{fail:s,promise:a,succeed:i}=d(),c=Pe({createServer:Se,fetch:r.fetch,port:e,serverOptions:{...o,allowHTTP1:!0}},()=>{i()});return c.on("error",l=>{if(typeof l=="object"&&"code"in l&&l.code==="EADDRINUSE")return s({portNotAvailable:e});console.error(l)}),await a,{async close(){await ve(c.close.bind(c))()},port:e,url:`http://localhost:${e}`}}async function Ee(e,t,n){let r=new N;r.route("/",h);let o=await be.getPlatformInfo();return n&&console.log("platform info: %s",JSON.stringify(o)),r.use(async(s,a)=>{let i=s.req.query("api_key");if(i==null)return s.text("Missing API Key",401);let c=k(i);if(c==null)return s.text("Invalid API Key",401);let{databaseUrl:l}=c;return l!==t.connectionString?s.text("Unauthorized",401):(s.set("db",t),s.set("debug",!!n),s.set("decodedAPIKey",c),s.set("platform",o),s.set("port",e),s.set("protocol","https"),s.set("schemasByHash",new Map),await a())}),r}var Te="/:clientVersion/:schemaHash",h=new N().basePath(Te);h.on("POST",["/graphql","/itx/:transactionId/graphql"],async e=>{let{req:t}=e;try{let n=await T(e);if(n instanceof Response)return n;let r=await t.text(),o=t.param("transactionId"),s=await n.request(r,{...R(e),"X-transaction-id":o});return e.text(s)}catch(n){return H(n,e)}});h.basePath("/itx/:transactionId").on("POST",["/commit","/rollback"],async e=>{let{req:t}=e,n=t.path.split("/").filter(Boolean).at(-1);try{let r=await T(e);if(r instanceof Response)return r;let o=`${n}Transaction`,s=t.param("transactionId"),a=await r[o](s,R(e));return e.json(a)}catch(r){return H(r,e)}});h.put("/schema",async e=>{let{req:t}=e,n=await t.text(),r=t.param("schemaHash"),o=e.get("schemasByHash");return n===o.get(r)?.original||o.set(r,{original:n,override:_(n,e.get("db").connectionString)}),e.text(r)});h.post("/transaction/start",async e=>{let{req:t}=e,n=await U(e);if(n instanceof Response)return n;try{let r=await T(e);if(r instanceof Response)return r;let o=await r.startTransaction(n,R(e)),s=M(o,e);if(s instanceof Response)return s;let{id:a}=s,i=t.param("clientVersion"),c=e.get("port"),l=e.get("protocol"),p=t.param("schemaHash");return e.json({...o,"data-proxy":{endpoint:`${l}://localhost:${c}/${i}/${p}/itx/${a}`}})}catch(r){return H(r,e)}});async function T(e){let{req:t}=e,n=D(e);return n instanceof Response?n:await y.get({base64Schema:n.schemas.override,clientVersion:t.param("clientVersion"),platform:e.get("platform"),schemaHash:n.schemaHash})}function R(e){let{req:t}=e;return{traceparent:t.header("traceparent"),"X-capture-telemetry":t.header("X-capture-telemetry")}}function H(e,t){return e instanceof f?t.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:e.message}}}},500):e instanceof u?t.text(e.responseBody,e.statusCode):t.body(null,500)}import{promisify as Re}from"util";import{PGlite as He}from"@electric-sql/pglite";import{createServer as Ae,LogLevel as ke}from"pglite-server";async function J(e,t){let n={connectionLimit:1,connectTimeout:0,database:"postgres",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,port:e,socketTimeout:0,sslMode:"disable",username:"postgres"},r=await He.create({database:n.database,dataDir:"memory://",debug:t?5:void 0,defaultDataTransferContainer:"file",username:n.username});await r.waitReady;let o=Ae(r,{keepAlive:!0,logLevel:t?ke.Debug:void 0}),{fail:s,promise:a,succeed:i}=d();o.on("error",l=>{if("code"in l&&l.code==="EADDRINUSE")return s(new Error(`Port ${e} is already in use. Provide a different \`dbport\` number and try again.`));console.error(l)}),o.listen(e,()=>i()),await a;let c=`postgres://${n.username}:${n.password}@localhost:${e}/${n.database}?${new URLSearchParams({connection_limit:String(n.connectionLimit),connect_timeout:String(n.connectTimeout),max_idle_connection_lifetime:String(n.maxIdleConnectionLifetime),pool_timeout:String(n.poolTimeout),socket_timeout:String(n.socketTimeout),sslmode:n.sslMode}).toString()}`;return{...n,async close(){try{await Re(o.close.bind(o))()}finally{await r.close()}},connectionString:c}}async function wt(e){let{acceleratePort:t=5433,databasePort:n=5432,debug:r}=e||{},o=await J(n,r),s=await F(t,o,r),a=`prisma+postgres://localhost:${s.port}/?${new URLSearchParams({api_key:A({databaseUrl:o.connectionString})}).toString()}`;return{accelerate:{url:s.url},close:()=>i([s,o]),database:{connectionString:o.connectionString},ppg:{url:a}};async function i(c){let p=(await Promise.allSettled(c.map(m=>m.close()))).filter(m=>m.status==="rejected").map(m=>new Error(m.reason));if(p.length>0)throw new AggregateError(p,"Failed to close some servers")}}export{wt as unstable_startServer};
6
+ url = "${e}"
7
+ }`,o=n.replace(de,r);return x.from(o,"utf8").toString("base64")}import{integer as j,looseObject as fe,minValue as L,number as E,object as ge,pipe as q,safeParse as K,string as V,union as he}from"valibot";var ye=ge({isolation_level:V(),max_wait:q(E(),j(),L(0)),timeout:q(E(),j(),L(0))});async function U(t){let{output:e,success:n}=K(ye,await t.req.parseBody());return n?e:t.json({EngineNotStarted:{reason:"InvalidRequest"}},400)}var we=fe({id:he([V(),E()])});function M(t,e){let{output:n,success:r}=K(we,t);return r?n:e.json({EngineMalfunction:{}},500)}async function F(t,e,n){let r=await Ee(t,e,n),o=await I(),{fail:s,promise:a,succeed:i}=d(),c=Pe({createServer:Se,fetch:r.fetch,port:t,serverOptions:{...o,allowHTTP1:!0}},()=>{i()});return c.on("error",l=>{if(typeof l=="object"&&"code"in l&&l.code==="EADDRINUSE")return s({portNotAvailable:t});console.error(l)}),await a,{async close(){await ve(c.close.bind(c))()},port:t,url:`http://localhost:${t}`}}async function Ee(t,e,n){let r=new N;r.route("/",h);let o=await be.getPlatformInfo();return n&&console.log("platform info: %s",JSON.stringify(o)),r.use(async(s,a)=>{let i=s.req.query("api_key");if(i==null)return s.text("Missing API Key",401);let c=k(i);if(c==null)return s.text("Invalid API Key",401);let{databaseUrl:l}=c;return l!==e.connectionString?s.text("Unauthorized",401):(s.set("db",e),s.set("debug",!!n),s.set("decodedAPIKey",c),s.set("platform",o),s.set("port",t),s.set("protocol","https"),s.set("schemasByHash",new Map),await a())}),r}var Te="/:clientVersion/:schemaHash",h=new N().basePath(Te);h.on("POST",["/graphql","/itx/:transactionId/graphql"],async t=>{let{req:e}=t;try{let n=await T(t);if(n instanceof Response)return n;let r=await e.text(),o=e.param("transactionId"),s=await n.request(r,{...H(t),"X-transaction-id":o});return t.text(s)}catch(n){return R(n,t)}});h.basePath("/itx/:transactionId").on("POST",["/commit","/rollback"],async t=>{let{req:e}=t,n=e.path.split("/").filter(Boolean).at(-1);try{let r=await T(t);if(r instanceof Response)return r;let o=`${n}Transaction`,s=e.param("transactionId"),a=await r[o](s,H(t));return t.json(a)}catch(r){return R(r,t)}});h.put("/schema",async t=>{let{req:e}=t,n=await e.text(),r=e.param("schemaHash"),o=t.get("schemasByHash");return n===o.get(r)?.original||o.set(r,{original:n,override:_(n,t.get("db").connectionString)}),t.text(r)});h.post("/transaction/start",async t=>{let{req:e}=t,n=await U(t);if(n instanceof Response)return n;try{let r=await T(t);if(r instanceof Response)return r;let o=await r.startTransaction(n,H(t)),s=M(o,t);if(s instanceof Response)return s;let{id:a}=s,i=e.param("clientVersion"),c=t.get("port"),l=t.get("protocol"),p=e.param("schemaHash");return t.json({...o,"data-proxy":{endpoint:`${l}://localhost:${c}/${i}/${p}/itx/${a}`}})}catch(r){return R(r,t)}});async function T(t){let{req:e}=t,n=D(t);return n instanceof Response?n:await y.get({base64Schema:n.schemas.override,clientVersion:e.param("clientVersion"),platform:t.get("platform"),schemaHash:n.schemaHash})}function H(t){let{req:e}=t;return{traceparent:e.header("traceparent"),"X-capture-telemetry":e.header("X-capture-telemetry")}}function R(t,e){return t instanceof f?e.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:t.message}}}},500):t instanceof u?e.text(t.responseBody,t.statusCode):e.body(null,500)}import{promisify as He}from"util";import{PGlite as Re}from"@electric-sql/pglite";import{createServer as Ae,LogLevel as ke}from"pglite-server";async function z(t,e){let n={connectionLimit:1,connectTimeout:0,database:"postgres",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,port:t,socketTimeout:0,sslMode:"disable",username:"postgres"},r=await Re.create({database:n.database,dataDir:"memory://",debug:e?5:void 0,defaultDataTransferContainer:"file",username:n.username});await r.waitReady;let o=Ae(r,{keepAlive:!0,logLevel:e?ke.Debug:void 0}),{fail:s,promise:a,succeed:i}=d();o.on("error",l=>{if("code"in l&&l.code==="EADDRINUSE")return s(new Error(`Port ${t} is already in use. Provide a different \`dbport\` number and try again.`));console.error(l)}),o.listen(t,()=>i()),await a;let c=`postgres://${n.username}:${n.password}@localhost:${t}/${n.database}?${new URLSearchParams({connection_limit:String(n.connectionLimit),connect_timeout:String(n.connectTimeout),max_idle_connection_lifetime:String(n.maxIdleConnectionLifetime),pool_timeout:String(n.poolTimeout),socket_timeout:String(n.socketTimeout),sslmode:n.sslMode}).toString()}`;return{...n,async close(){try{await He(o.close.bind(o))()}finally{await r.close()}},connectionString:c}}async function wt(t){let{acceleratePort:e=5433,databasePort:n=5432,debug:r}=t||{},o=await z(n,r),s=await F(e,o,r),a=`prisma+postgres://localhost:${s.port}/?${new URLSearchParams({api_key:A({databaseUrl:o.connectionString})}).toString()}`;return{accelerate:{url:s.url},close:()=>i([s,o]),database:{connectionString:o.connectionString},ppg:{url:a}};async function i(c){let p=(await Promise.allSettled(c.map(m=>m.close()))).filter(m=>m.status==="rejected").map(m=>new Error(m.reason));if(p.length>0)throw new AggregateError(p,"Failed to close some servers")}}export{wt as unstable_startServer};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@prisma/dev",
3
- "version": "0.0.0-dev.202505092340",
3
+ "version": "0.0.0-dev.202505092348",
4
4
  "description": "A local Prisma Postgres server for development and testing",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",