@prisma/dev 0.0.0-dev.202505202028 → 0.0.0-dev.202505202131
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.
- package/dist/index.js +1 -1
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -4,4 +4,4 @@ import{createServer as je}from"http";import{promisify as Ue}from"util";import{se
|
|
|
4
4
|
Received data: ${i}`));s({childProcess:n,url:`http://${u}:${v}`})};n.once("error",i=>{this.#t=null,r(new y(String(i)))}),n.once("exit",(i,c)=>{this.#t=null,r(new y(`Query Engine exited with code ${i} and signal ${c}`))}),n.stdout.on("data",a),n.stderr.on("data",i=>{console.error(i)}),await this.#t}async stop(){if(this.#t==null)return;let{childProcess:e}=await this.#t;e.exitCode==null&&e.signalCode==null&&(e.kill(),await xe(e,"exit"))}async#s(){this.#e.debug&&console.debug("getting engine commit hash...");let e=await this.#a();this.#e.debug&&console.debug("got engine commit hash",e);let n=q(this.#e.clientVersion,e);this.#e.debug&&console.debug("cache directory path",n),await He(n,{recursive:!0});let{platform:r}=this.#e.platform,o=r==="windows"?".exe":"",s=Ie(n,`query-engine-${r}${o}`);return this.#e.debug&&console.debug("engine binary path",s),(process.env.PRISMA_DEV_FORCE_ENGINE_DOWNLOAD==="1"||await F(s)===!1)&&await this.#i({commitHash:e,extension:o,engineBinaryPath:s}),s}async#a(){let e=await fetch(`https://registry.npmjs.org/@prisma/client/${this.#e.clientVersion}`);if(!e.ok)throw new Error(`Couldn't fetch package.json from npm registry, status code: ${e.status}`);let r=(await e.json()).devDependencies?.["@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(e){let{commitHash:n,extension:r,engineBinaryPath:o}=e,{binaryTarget:s}=this.#e.platform,a=`https://binaries.prisma.sh/all_commits/${n}/${s}/query-engine${r}.gz`;this.#e.debug&&console.debug("downloading engine from url",a);let i=await fetch(a);if(!i.ok)throw new Error(`Couldn't download engine. URL: ${a}, status code: ${i.status}`);await M(await i.arrayBuffer(),o),this.#e.debug&&console.debug("engine downloaded and saved at",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.#t,s=this.#r(n),a=await fetch(`${o}/transaction/${e}/${r}`,{headers:{...s,"Content-Type":"application/json"},method:"POST"});if(!a.ok)throw await m.fromResponse(a);try{return await a.json()}catch{return{}}}};function A(t,e){return console.error(t),t instanceof y?e.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:t.message}}}},500):t instanceof m?e.text(t.responseBody,t.statusCode):e.body(null,500)}var y=class extends Error{name="EngineStartError"},m=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)}};var N=51213,V=51214,K=51215,g=class extends Error{constructor(n,r){super(`Port number \`${n}\` is not available for service ${r}.`);this.port=n;this.service=r}name="PortNotAvailableError"};import{Buffer as G}from"buffer";var T=new Map;async function H(t){let n=new TextEncoder().encode(t),r=await crypto.subtle.digest("SHA-256",n);return Array.from(new Uint8Array(r)).map(a=>a.toString(16).padStart(2,"0")).join("")}function z(t){let e=t.req.param("schemaHash"),n=T.get(e);return n==null?t.json({EngineNotStarted:{reason:"SchemaMissing"}},404):{schemaHash:e,schemas:n}}var De=/datasource\s+db\s+\{\s*provider\s*=\s*"postgres(!?ql)?"\s+url\s*=\s*.+\s*\}/;async function J(t,e){let n=G.from(t,"base64").toString("utf8"),r=`datasource db {
|
|
5
5
|
provider = "postgresql"
|
|
6
6
|
url = "${e}"
|
|
7
|
-
}`,o=n.replace(De,r),s=await H(o);return{base64Override:G.from(o,"utf8").toString("base64"),overrideHash:s}}function R(t){let{req:e}=t;return{traceparent:e.header("traceparent"),"X-capture-telemetry":e.header("X-capture-telemetry")}}import{integer as Q,looseObject as _e,minValue as X,number as I,object as Ce,optional as $e,pipe as W,safeParse as Y,string as Z,union as ke}from"valibot";var Be=Ce({isolation_level:$e(Z()),max_wait:W(I(),Q(),X(0)),timeout:W(I(),Q(),X(0))});async function ee(t){let{issues:e,output:n,success:r}=Y(Be,await t.req.json(),{abortEarly:!0});return r?n:t.json({EngineNotStarted:{reason:"InvalidRequest",issues:e}},400)}var Le=_e({id:ke([Z(),I()])});function te(t,e){let{output:n,success:r}=Y(Le,t);return r?n:e.json({EngineMalfunction:{}},500)}async function oe(t){let{dbServer:e,debug:n,dryRun:r,port:o}=t;if(r)return ne(o,null);let s=await Ne(o,e,n),{fail:a,promise:i,succeed:c}=E(),p=qe({createServer:je,fetch:s.fetch,port:o},()=>{c()});return p.on("error",u=>{if(typeof u=="object"&&"code"in u&&u.code==="EADDRINUSE")return a(new g(o,"accelerate"));console.error(u)}),await i,ne(o,p)}function ne(t,e){return{async close(){e&&await Promise.allSettled([Ue(e.close.bind(e))(),h.stopAll()])},port:t,url:`http://localhost:${t}`}}async function Ne(t,e,n){let r=new re,o=await Fe.getPlatformInfo();return n&&console.debug("platform info: %s",JSON.stringify(o)),n&&r.use("*",Me()),r.use("*",async(s,a)=>(s.set("db",e),s.set("debug",!!n),s.set("platform",o),s.set("port",t),s.set("protocol","http"),await a())),r.route("/",w),r}var w=new re;w.get("/health",t=>t.text("ok"));w.post("/invalidate",S("header",d),async t=>{let e=await U(t);return e instanceof Response?e:t.body(null)});var Ve="/:clientVersion/:schemaHash",b=w.basePath(Ve);w.route("/",b);var Ke=["/graphql","/itx/:transactionId/graphql"];b.on("POST",[...Ke],S("header",d),async t=>{let{req:e}=t;try{let n=await D(t);if(n instanceof Response)return n;let r=await e.text(),o=e.param("transactionId"),s=await n.request(r,{...R(t),"X-transaction-id":o});return t.text(s)}catch(n){return A(n,t)}});b.basePath("/itx/:transactionId").on("POST",["/commit","/rollback"],S("header",d),async t=>{let{req:e}=t;try{let n=await D(t);if(n instanceof Response)return n;let o=`${e.routePath.split("/").filter(Boolean).at(-1)}Transaction`,s=e.param("transactionId"),a=await n[o](s,R(t));return t.json(a)}catch(n){return A(n,t)}});b.put("/schema",S("header",d),async t=>{let{req:e}=t,n=await e.text();if(!n)return t.text("Missing schema",400);let r=e.param("schemaHash"),o=T.get(r);if(o==null){if(r!==await H(n))return t.text("Schema hash mismatch",400);let s=await J(n,t.get("db").connectionString);return T.set(r,{base64Original:n,...s}),t.text(r)}return n!==o.base64Original?t.text("Schema mismatch",400):t.text(r)});b.post("/transaction/start",S("header",d),async t=>{let{req:e}=t,n=await ee(t);if(n instanceof Response)return n;try{let r=await D(t);if(r instanceof Response)return r;let o=await r.startTransaction(n,R(t)),s=te(o,t);if(s instanceof Response)return s;let{id:a}=s,i=e.param("clientVersion"),c=t.get("port"),p=t.get("protocol"),u=e.param("schemaHash");return t.json({...o,"data-proxy":{endpoint:`${p}://localhost:${c}/${i}/${u}/itx/${a}`}})}catch(r){return A(r,t)}});async function D(t){let{req:e}=t,n=z(t);if(n instanceof Response)return n;let{base64Override:r,overrideHash:o}=n.schemas;return await h.get({base64Schema:r,clientVersion:process.env.PRISMA_DEV_FORCE_CLIENT_VERSION||e.param("clientVersion"),debug:t.get("debug"),platform:t.get("platform"),schemaHash:o})}import{PGlite as Ge}from"@electric-sql/pglite";import{PGLiteSocketServer as ze}from"@electric-sql/pglite-socket";var l={connectionLimit:1,connectTimeout:0,database:"postgres",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,socketTimeout:0,sslMode:"disable",username:"postgres"},Je=`postgres://${l.username}:${l.password}@localhost`,Qe=new URLSearchParams({connection_limit:String(l.connectionLimit),connect_timeout:String(l.connectTimeout),max_idle_connection_lifetime:String(l.maxIdleConnectionLifetime),pool_timeout:String(l.poolTimeout),socket_timeout:String(l.socketTimeout),sslmode:l.sslMode});async function _(t){let{debug:e,dryRun:n,port:r,purpose:o}=t;if(n)return se(r,null,null);let s=await Ge.create({database:l.database,dataDir:"memory://",debug:e?5:void 0,defaultDataTransferContainer:"file",username:l.username});await s.waitReady;let a=new ze({db:s,inspect:e,port:r});try{await a.start()}catch(i){throw i instanceof Error&&"code"in i&&i.code==="EADDRINUSE"?new g(r,o):i}return e&&console.debug(`${o} server started on port %i`,r),se(r,s,a)}function se(t,e,n){return{...l,close:async()=>{if(!(!e||!n))try{await n.stop()}finally{await e.close()}},connectionString:Xe(t),port:t}}function Xe(t){return`${Je}:${t}/${l.database}?${Qe.toString()}`}async function
|
|
7
|
+
}`,o=n.replace(De,r),s=await H(o);return{base64Override:G.from(o,"utf8").toString("base64"),overrideHash:s}}function R(t){let{req:e}=t;return{traceparent:e.header("traceparent"),"X-capture-telemetry":e.header("X-capture-telemetry")}}import{integer as Q,looseObject as _e,minValue as X,number as I,object as Ce,optional as $e,pipe as W,safeParse as Y,string as Z,union as ke}from"valibot";var Be=Ce({isolation_level:$e(Z()),max_wait:W(I(),Q(),X(0)),timeout:W(I(),Q(),X(0))});async function ee(t){let{issues:e,output:n,success:r}=Y(Be,await t.req.json(),{abortEarly:!0});return r?n:t.json({EngineNotStarted:{reason:"InvalidRequest",issues:e}},400)}var Le=_e({id:ke([Z(),I()])});function te(t,e){let{output:n,success:r}=Y(Le,t);return r?n:e.json({EngineMalfunction:{}},500)}async function oe(t){let{dbServer:e,debug:n,dryRun:r,port:o}=t;if(r)return ne(o,null);let s=await Ne(o,e,n),{fail:a,promise:i,succeed:c}=E(),p=qe({createServer:je,fetch:s.fetch,port:o},()=>{c()});return p.on("error",u=>{if(typeof u=="object"&&"code"in u&&u.code==="EADDRINUSE")return a(new g(o,"accelerate"));console.error(u)}),await i,ne(o,p)}function ne(t,e){return{async close(){e&&await Promise.allSettled([Ue(e.close.bind(e))(),h.stopAll()])},port:t,url:`http://localhost:${t}`}}async function Ne(t,e,n){let r=new re,o=await Fe.getPlatformInfo();return n&&console.debug("platform info: %s",JSON.stringify(o)),n&&r.use("*",Me()),r.use("*",async(s,a)=>(s.set("db",e),s.set("debug",!!n),s.set("platform",o),s.set("port",t),s.set("protocol","http"),await a())),r.route("/",w),r}var w=new re;w.get("/health",t=>t.text("ok"));w.post("/invalidate",S("header",d),async t=>{let e=await U(t);return e instanceof Response?e:t.body(null)});var Ve="/:clientVersion/:schemaHash",b=w.basePath(Ve);w.route("/",b);var Ke=["/graphql","/itx/:transactionId/graphql"];b.on("POST",[...Ke],S("header",d),async t=>{let{req:e}=t;try{let n=await D(t);if(n instanceof Response)return n;let r=await e.text(),o=e.param("transactionId"),s=await n.request(r,{...R(t),"X-transaction-id":o});return t.text(s)}catch(n){return A(n,t)}});b.basePath("/itx/:transactionId").on("POST",["/commit","/rollback"],S("header",d),async t=>{let{req:e}=t;try{let n=await D(t);if(n instanceof Response)return n;let o=`${e.routePath.split("/").filter(Boolean).at(-1)}Transaction`,s=e.param("transactionId"),a=await n[o](s,R(t));return t.json(a)}catch(n){return A(n,t)}});b.put("/schema",S("header",d),async t=>{let{req:e}=t,n=await e.text();if(!n)return t.text("Missing schema",400);let r=e.param("schemaHash"),o=T.get(r);if(o==null){if(r!==await H(n))return t.text("Schema hash mismatch",400);let s=await J(n,t.get("db").connectionString);return T.set(r,{base64Original:n,...s}),t.text(r)}return n!==o.base64Original?t.text("Schema mismatch",400):t.text(r)});b.post("/transaction/start",S("header",d),async t=>{let{req:e}=t,n=await ee(t);if(n instanceof Response)return n;try{let r=await D(t);if(r instanceof Response)return r;let o=await r.startTransaction(n,R(t)),s=te(o,t);if(s instanceof Response)return s;let{id:a}=s,i=e.param("clientVersion"),c=t.get("port"),p=t.get("protocol"),u=e.param("schemaHash");return t.json({...o,"data-proxy":{endpoint:`${p}://localhost:${c}/${i}/${u}/itx/${a}`}})}catch(r){return A(r,t)}});async function D(t){let{req:e}=t,n=z(t);if(n instanceof Response)return n;let{base64Override:r,overrideHash:o}=n.schemas;return await h.get({base64Schema:r,clientVersion:process.env.PRISMA_DEV_FORCE_CLIENT_VERSION||e.param("clientVersion"),debug:t.get("debug"),platform:t.get("platform"),schemaHash:o})}import{PGlite as Ge}from"@electric-sql/pglite";import{PGLiteSocketServer as ze}from"@electric-sql/pglite-socket";var l={connectionLimit:1,connectTimeout:0,database:"postgres",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,socketTimeout:0,sslMode:"disable",username:"postgres"},Je=`postgres://${l.username}:${l.password}@localhost`,Qe=new URLSearchParams({connection_limit:String(l.connectionLimit),connect_timeout:String(l.connectTimeout),max_idle_connection_lifetime:String(l.maxIdleConnectionLifetime),pool_timeout:String(l.poolTimeout),socket_timeout:String(l.socketTimeout),sslmode:l.sslMode});async function _(t){let{debug:e,dryRun:n,port:r,purpose:o}=t;if(n)return se(r,null,null);let s=await Ge.create({database:l.database,dataDir:"memory://",debug:e?5:void 0,defaultDataTransferContainer:"file",username:l.username});await s.waitReady;let a=new ze({db:s,inspect:e,port:r});try{await a.start()}catch(i){throw i instanceof Error&&"code"in i&&i.code==="EADDRINUSE"?new g(r,o):i}return e&&console.debug(`${o} server started on port %i`,r),se(r,s,a)}function se(t,e,n){return{...l,close:async()=>{if(!(!e||!n))try{await n.stop()}finally{await e.close()}},connectionString:Xe(t),port:t}}function Xe(t){return`${Je}:${t}/${l.database}?${Qe.toString()}`}async function Kt(t){let{acceleratePort:e=51213,databasePort:n=51214,debug:r=!1,dryRun:o=!1,shadowDatabasePort:s=51215}=t||{},[a,i]=await Promise.all([_({debug:r,dryRun:o,port:n,purpose:"database"}),_({debug:r,dryRun:o,port:s,purpose:"shadow_database"})]),c=await oe({dbServer:a,debug:r,dryRun:o,port:e}),p=`prisma+postgres://localhost:${c.port}/?${new URLSearchParams({api_key:j({databaseUrl:a.connectionString,shadowDatabaseUrl:i.connectionString})}).toString()}`;return{accelerate:{url:c.url},close:()=>u([c,a,i]),database:{connectionString:a.connectionString},ppg:{url:p},shadowDatabase:{connectionString:i.connectionString}};async function u(v){let $=(await Promise.allSettled(v.map(f=>f.close()))).filter(f=>f.status==="rejected").map(f=>new Error(f.reason));if($.length>0)throw new AggregateError($,"Failed to close some servers")}}export{N as DEFAULT_ACCELERATE_PORT,V as DEFAULT_DATABASE_PORT,K as DEFAULT_SHADOW_DATABASE_PORT,g as PortNotAvailableError,Kt as unstable_startServer};
|