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