@prisma/dev 0.0.0-dev.202505091944 → 0.0.0-dev.202505091950

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 +1 -1
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -4,4 +4,4 @@ import{Buffer as q}from"buffer";import{createSecureServer as ye}from"http2";impo
4
4
  Received data: ${i}`));s({childProcess:r,url:`http://${p}:${m}`})};r.once("error",i=>{this.#e=null,o(new d(String(i)))}),r.once("exit",(i,a)=>{this.#e=null,o(new d(`Query Engine exited with code ${i} and signal ${a}`))}),r.stdout.on("data",c),r.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 le(t,"exit"))}async#n(){let t=await this.#o(),r=O(this.#t.clientVersion,t);await me(r,{recursive:!0});let{platform:o}=this.#t.platform,n=o==="windows"?".exe":"",s=pe(r,`query-engine-${o}${n}`);return await g(s)||await this.#s({commitHash:t,extension:n,engineBinaryPath:s}),s}async#o(){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 o=(await t.json()).dependencies?.["@prisma/engines-version"];if(!o)throw new Error("Couldn't find engines version in package.json");let n=o.split(".").at(-1);if(!n)throw new Error("Couldn't find commit hash in engines version");return n}async#s(t){let{commitHash:r,extension:o,engineBinaryPath:n}=t,{platform:s}=this.#t.platform,c=`https://binaries.prisma.sh/all_commits/${r}/${s}/query-engine${o}.gz`,i=await fetch(c);if(!i.ok)throw new Error(`Couldn't download engine. URL: ${c}, status code: ${i.status}`);await C(await i.arrayBuffer(),n)}},d=class extends Error{name="EngineStartError"},f=class e extends Error{constructor(r,o,n){super(`${r}: Query Engine response status ${o}, body: ${n}`);this.action=r;this.statusCode=o;this.responseBody=n}name="EngineHttpError";static async fromResponse(r){let o=new URL(r.url),n=await r.text();return new e(o.pathname,r.status,n)}};import{integer as B,looseObject as ue,minValue as $,number as R,object as de,pipe as I,safeParse as D,string as _,union as fe}from"valibot";var ge=de({isolation_level:_(),max_wait:I(R(),B(),$(0)),timeout:I(R(),B(),$(0))});async function L(e){let{output:t,success:r}=D(ge,await e.req.parseBody());return r?t:e.json({EngineNotStarted:{reason:"InvalidRequest"}},400)}var he=ue({id:fe([_(),R()])});function j(e,t){let{output:r,success:o}=D(he,e);return o?r:t.json({EngineMalfunction:{}},500)}async function U(e,t,r){let o=await Pe(e,t,r),n=await x(),{fail:s,promise:c,succeed:i}=u(),a=Se({createServer:ye,fetch:o.fetch,port:e,serverOptions:{...n,allowHTTP1:!0}},()=>{i()});return a.on("error",l=>{if(typeof l=="object"&&"code"in l&&l.code==="EADDRINUSE")return s({portNotAvailable:e});console.error(l)}),await c,{async close(){await we(a.close.bind(a))()},port:e,url:`http://localhost:${e}`}}async function Pe(e,t,r){let o=new K;o.route("/",y);let n=await ve.getPlatformInfo();return r&&console.log("platform info: %s",JSON.stringify(n)),o.use(async(s,c)=>{let i=s.req.query("api_key");if(i==null)return s.text("Missing API Key",401);let a=A(i);if(a==null)return s.text("Invalid API Key",401);let{databaseUrl:l}=a;return l!==t.connectionString?s.text("Unauthorized",401):(s.set("db",t),s.set("debug",!!r),s.set("decodedAPIKey",a),s.set("platform",n),s.set("port",e),s.set("protocol","https"),s.set("schemasByHash",new Map),await c())}),o}var y=new K().basePath("/:clientVersion/:schemaHash");y.post("/graphql",async e=>{let{req:t}=e,r=M(e);if(r instanceof Response)return r;let o=t.param("clientVersion"),n=e.get("platform");try{let s=await h.get({base64Schema:r.schemas.override,clientVersion:o,platform:n,schemaHash:r.schemaHash}),c=await t.text(),i=t.header("traceparent"),a=t.header("X-capture-telemetry"),l=await s.request(c,{traceparent:i,xCaptureTelemetry:a});return e.text(l)}catch(s){return N(s,e)}});y.put("/schema",async e=>{let{req:t}=e,r=await t.text(),o=t.param("schemaHash"),n=e.get("schemasByHash");return r===n.get(o)?.original||n.set(o,{original:r,override:Ee(r,e.get("db").connectionString)}),e.text(o)});y.post("/transaction/start",async e=>{let{req:t}=e,r=M(e);if(r instanceof Response)return r;let o=await L(e);if(o instanceof Response)return o;let{schemaHash:n}=r,s=t.param("clientVersion"),c=e.get("platform");try{let i=await h.get({base64Schema:r.schemas.override,clientVersion:s,platform:c,schemaHash:n}),a=t.header("traceparent"),l=t.header("X-capture-telemetry"),p=await i.startTransaction(o,{traceparent:a,"x-capture-telemetry":l}),m=j(p,e);if(m instanceof Response)return m;let{id:w}=m,F=e.get("port"),J=e.get("protocol");return e.json({...p,"data-proxy":{endpoint:`${J}://localhost:${F}/${s}/${n}/itx/${w}`}})}catch(i){return N(i,e)}});function M(e){let t=e.req.param("schemaHash"),o=e.get("schemasByHash").get(t);return o==null?e.json({EngineNotStarted:{reason:"SchemaMissing"}},404):{schemaHash:t,schemas:o}}var be=/datasource\s+db\s+[\w\s\d{="[\])(]+}/;function Ee(e,t){let r=q.from(e,"base64").toString("utf8"),o=`datasource db {
5
5
  provider = "postgresql"
6
6
  url = "${t}"
7
- }`,n=r.replace(be,o);return q.from(n,"utf8").toString("base64")}function N(e,t){return e instanceof d?t.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:e.message}}}},500):e instanceof f?t.text(e.responseBody,e.statusCode):t.body(null,500)}import{promisify as Re}from"util";import{PGlite as Te}from"@electric-sql/pglite";import{createServer as Ae,LogLevel as Oe}from"pglite-server";async function V(e,t){let r={connectionLimit:1,connectTimeout:0,database:"postgres",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,port:e,socketTimeout:0,sslMode:"disable",username:"postgres"},o=new Te({database:r.database,dataDir:"memory://",debug:t?5:void 0,defaultDataTransferContainer:"file",username:r.username});await o.waitReady;let n=Ae(o,{keepAlive:!0,logLevel:t?Oe.Debug:void 0}),{fail:s,promise:c,succeed:i}=u();n.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)}),n.listen(e,()=>i()),await c;let a=`postgres://${r.username}:${r.password}@localhost:${e}/${r.database}?${new URLSearchParams({connection_limit:String(r.connectionLimit),connect_timeout:String(r.connectTimeout),max_idle_connection_lifetime:String(r.maxIdleConnectionLifetime),pool_timeout:String(r.poolTimeout),socket_timeout:String(r.socketTimeout),sslmode:r.sslMode}).toString()}`;return{...r,async close(){try{await Re(n.close.bind(n))()}finally{await o.close()}},connectionString:a}}async function gt(e){let{acceleratePort:t=5433,databasePort:r=5432,debug:o}=e||{},n=await V(r,o),s=await U(t,n,o),c=`prisma+postgres://localhost:${s.port}/?${new URLSearchParams({api_key:T({databaseUrl:n.connectionString})}).toString()}`;return{accelerate:{url:s.url},close:()=>i([s,n]),database:{connectionString:n.connectionString},ppg:{url:c}};async function i(a){let p=(await Promise.allSettled(a.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{gt as unstable_startServer};
7
+ }`,n=r.replace(be,o);return q.from(n,"utf8").toString("base64")}function N(e,t){return e instanceof d?t.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:e.message}}}},500):e instanceof f?t.text(e.responseBody,e.statusCode):t.body(null,500)}import{promisify as Re}from"util";import{PGlite as Te}from"@electric-sql/pglite";import{createServer as Ae,LogLevel as Oe}from"pglite-server";async function V(e,t){let r={connectionLimit:1,connectTimeout:0,database:"postgres",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,port:e,socketTimeout:0,sslMode:"disable",username:"postgres"},o=await Te.create({database:r.database,dataDir:"memory://",debug:t?5:void 0,defaultDataTransferContainer:"file",username:r.username});await o.waitReady;let n=Ae(o,{keepAlive:!0,logLevel:t?Oe.Debug:void 0}),{fail:s,promise:c,succeed:i}=u();n.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)}),n.listen(e,()=>i()),await c;let a=`postgres://${r.username}:${r.password}@localhost:${e}/${r.database}?${new URLSearchParams({connection_limit:String(r.connectionLimit),connect_timeout:String(r.connectTimeout),max_idle_connection_lifetime:String(r.maxIdleConnectionLifetime),pool_timeout:String(r.poolTimeout),socket_timeout:String(r.socketTimeout),sslmode:r.sslMode}).toString()}`;return{...r,async close(){try{await Re(n.close.bind(n))()}finally{await o.close()}},connectionString:a}}async function gt(e){let{acceleratePort:t=5433,databasePort:r=5432,debug:o}=e||{},n=await V(r,o),s=await U(t,n,o),c=`prisma+postgres://localhost:${s.port}/?${new URLSearchParams({api_key:T({databaseUrl:n.connectionString})}).toString()}`;return{accelerate:{url:s.url},close:()=>i([s,n]),database:{connectionString:n.connectionString},ppg:{url:c}};async function i(a){let p=(await Promise.allSettled(a.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{gt as unstable_startServer};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@prisma/dev",
3
- "version": "0.0.0-dev.202505091944",
3
+ "version": "0.0.0-dev.202505091950",
4
4
  "description": "A local Prisma Postgres server for development and testing",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",