@prisma/dev 0.0.0-dev.202505091306 → 0.0.0-dev.202505091334
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 +4 -4
- 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{Buffer as
|
|
3
|
-
`).find(w=>w.includes("Started query engine http server"));if(!m)return;r.stdout.removeListener("data",
|
|
4
|
-
Received data: ${s}`));i({childProcess:r,url:`http://${a}:${p}`})};r.once("error",s=>{this.#e=null,o(new d(String(s)))}),r.once("exit",(s,m)=>{this.#e=null,o(new d(`Query Engine exited with code ${s} and signal ${m}`))}),r.stdout.on("data",
|
|
2
|
+
import{Buffer as _}from"buffer";import{createSecureServer as ce}from"http2";import{promisify as le}from"util";import{serve as me}from"@hono/node-server";import pe from"@prisma/get-platform";import{Hono as j}from"hono/tiny";import{mkdir as W,readFile as C,writeFile as x}from"fs/promises";import{join as P}from"path";import{certificateFor as Y}from"@expo/devcert";import{chmod as J,stat as G,writeFile as Q}from"fs/promises";import X from"env-paths";import{inflate as z}from"pako";var S=X("prisma-dev").cache;function T(e,t){return`${S}/${e}/${t}`}async function g(e){try{return await G(e),!0}catch(t){if(t!=null&&typeof t=="object"&&"code"in t&&t.code==="ENOENT")return!1;throw t}}async function O(e,t){let r=z(e);await Q(t,r),await J(t,"755")}var E=P(S,"certs"),v=P(E,"tls.cert"),b=P(E,"tls.key");async function A(){if(await W(E,{recursive:!0}),await g(v)&&await g(b))return{cert:await C(v),key:await C(b)};let e=await Y("localhost");return await Promise.all([x(v,e.cert),x(b,e.key)]),{cert:e.cert,key:e.key}}import{spawn as Z}from"child_process";import{once as ee}from"events";import{mkdir as te}from"fs/promises";import{join as re}from"path";function u(){let e,t,r=new Promise((o,n)=>{e=o,t=n});return{fail:t,promise:r,succeed:e}}var h=class e{static#r=new Map;#t;#e;constructor(t){this.#t=t,this.#e=null}static async get(t){let r=`${t.schemaHash}:${t.clientVersion}`;try{let o=e.#r.get(r);if(o)return o;let n=new e(t);return e.#r.set(r,n),await n.start(),n}finally{e.stopAll(r)}}static async stopAll(t){let o=(await Promise.allSettled(Array.from(e.#r.entries()).filter(([n])=>n!==t).map(async([n,i])=>{try{await i.stop()}finally{e.#r.delete(n)}}))).filter(n=>n.status==="rejected").map(n=>n.reason);if(o.length>0)throw new AggregateError(o,"Failed to stop engines")}async request(t,r){let{url:o}=await this.#e,n=await fetch(o,{body:t,headers:{...r,"Content-Type":"application/json"},method:"POST"});if(!n.ok)throw await f.fromResponse(n);return await n.text()}async startTransaction(t,r){let{url:o}=await this.#e,n=await fetch(`${o}/transaction/start`,{body:JSON.stringify(t),headers:{...r,"Content-Type":"application/json"},method:"POST"});if(!n.ok)throw await f.fromResponse(n);return await n.json()}async start(){if(this.#e!=null)return;let t=await this.#n(),r=Z(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});r.stderr.setEncoding("utf8"),r.stdout.setEncoding("utf8");let{fail:o,promise:n,succeed:i}=u();this.#e=n;let c=s=>{let m=s.split(`
|
|
3
|
+
`).find(w=>w.includes("Started query engine http server"));if(!m)return;r.stdout.removeListener("data",c);let{fields:l}=JSON.parse(m);if(l==null)return o(new Error(`Unexpected data during initialization, "fields" are missing: ${s}`));let{ip:a,port:p}=l;if(a==null||p==null)return o(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: ${s}`));i({childProcess:r,url:`http://${a}:${p}`})};r.once("error",s=>{this.#e=null,o(new d(String(s)))}),r.once("exit",(s,m)=>{this.#e=null,o(new d(`Query Engine exited with code ${s} and signal ${m}`))}),r.stdout.on("data",c),r.stderr.on("data",s=>{console.error(s)}),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 ee(t,"exit"))}async#n(){let t=await this.#o(),r=T(this.#t.clientVersion,t);await te(r,{recursive:!0});let{platform:o}=this.#t.platform,n=o==="windows"?".exe":"",i=re(r,`query-engine-${o}${n}`);return await g(i)||await this.#s({commitHash:t,extension:n,engineBinaryPath:i}),i}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:i}=this.#t.platform,c=`https://binaries.prisma.sh/all_commits/${r}/${i}/query-engine${o}.gz`,s=await fetch(c);if(!s.ok)throw new Error(`Couldn't download engine. URL: ${c}, status code: ${s.status}`);await O(await s.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 H,looseObject as ne,minValue as $,number as R,object as oe,pipe as k,safeParse as B,string as I,union as se}from"valibot";var ie=oe({isolation_level:I(),max_wait:k(R(),H(),$(0)),timeout:k(R(),H(),$(0))});async function D(e){let{output:t,success:r}=B(ie,await e.req.parseBody());return r?t:e.json({EngineNotStarted:{reason:"InvalidRequest"}},400)}var ae=ne({id:se([I(),R()])});function L(e,t){let{output:r,success:o}=B(ae,e);return o?r:t.json({EngineMalfunction:{}},500)}async function q(e,t,r){let o=new j,n=await pe.getPlatformInfo();r&&console.log("platform info: %s",JSON.stringify(n)),o.use(async(a,p)=>{a.set("db",t),a.set("debug",!!r),a.set("platform",n),a.set("port",e),a.set("protocol","http"),a.set("schemasByHash",new Map),await p()}),o.route("/",y);let i=await A(),{fail:c,promise:s,succeed:m}=u(),l=me({createServer:ce,fetch:o.fetch,port:e,serverOptions:{...i,allowHTTP1:!0}},()=>{m()});return l.on("error",a=>{if(typeof a=="object"&&"code"in a&&a.code==="EADDRINUSE")return c({portNotAvailable:e});console.error(a)}),await s,{async close(){await le(l.close.bind(l))()},port:e,url:`http://localhost:${e}`}}var y=new j().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 i=await h.get({base64Schema:r.schemas.override,clientVersion:o,platform:n,schemaHash:r.schemaHash}),c=await t.text(),s=t.header("traceparent"),m=t.header("X-capture-telemetry"),l=await i.request(c,{traceparent:s,xCaptureTelemetry:m});return e.text(l)}catch(i){return N(i,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:de(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 D(e);if(o instanceof Response)return o;let{schemaHash:n}=r,i=t.param("clientVersion"),c=e.get("platform");try{let s=await h.get({base64Schema:r.schemas.override,clientVersion:i,platform:c,schemaHash:n}),m=t.header("traceparent"),l=t.header("X-capture-telemetry"),a=await s.startTransaction(o,{traceparent:m,"x-capture-telemetry":l}),p=L(a,e);if(p instanceof Response)return p;let{id:w}=p,F=e.get("port"),K=e.get("protocol");return e.json({...a,"data-proxy":{endpoint:`${K}://localhost:${F}/${i}/${n}/itx/${w}`}})}catch(s){return N(s,e)}});var ue=/datasource\s+db\s+[\w\s\d{="[\])(]+}/;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}}function de(e,t){let r=_.from(e,"base64").toString("utf8"),o=`datasource db {
|
|
5
5
|
provider = "postgresql"
|
|
6
6
|
url = "${t}"
|
|
7
|
-
}`,n=r.replace(
|
|
7
|
+
}`,n=r.replace(ue,o);return _.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{looseObject as fe,parse as tt,pipe as ge,regex as he,string as ye,url as we}from"valibot";var Se=/^(postgres|postgresql):\/\//,rt=fe({databaseUrl:ge(ye(),we(),he(Se))});function U(e){return Buffer.from(JSON.stringify(e),"utf8").toString("base64")}import{promisify as ve}from"util";import{PGlite as be}from"@electric-sql/pglite";import{createServer as Pe,LogLevel as Ee}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 be({database:r.database,dataDir:"memory://",debug:t?5:void 0,defaultDataTransferContainer:"file",username:r.username});await o.waitReady;let n=Pe(o,{keepAlive:!0,logLevel:t?Ee.Debug:void 0}),{fail:i,promise:c,succeed:s}=u();n.on("error",l=>{if("code"in l&&l.code==="EADDRINUSE")return i(new Error(`Port ${e} is already in use. Provide a different \`dbport\` number and try again.`));console.error(l)}),n.listen(e,()=>s()),await c;let m=`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 ve(n.close.bind(n))()}finally{await o.close()}},connectionString:m}}async function ut(e){let{acceleratePort:t=5433,databasePort:r=5432,debug:o}=e||{},n=await V(r,o),i=await q(t,n,o),c=`prisma+postgres://localhost:${i.port}/?${new URLSearchParams({api_key:U({databaseUrl:n.connectionString})}).toString()}`;return{accelerate:{url:i.url},close:()=>s([i,n]),database:{connectionString:n.connectionString},ppg:{url:c}};async function s(m){let a=(await Promise.allSettled(m.map(p=>p.close()))).filter(p=>p.status==="rejected").map(p=>new Error(p.reason));if(a.length>0)throw new AggregateError(a,"Failed to close some servers")}}export{ut as unstable_startServer};
|