@prisma/dev 0.0.0-dev.202505082123 → 0.0.0-dev.202505082225
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 -6
- package/package.json +1 -6
package/dist/index.js
CHANGED
|
@@ -1,7 +1,2 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
|
-
import{
|
|
3
|
-
`).find($=>$.includes("Started query engine http server"));if(!l)return;r.stdout.removeListener("data",c);let{fields:a}=JSON.parse(l);if(a==null)return s(new Error(`Unexpected data during initialization, "fields" are missing: ${o}`));let{ip:m,port:g}=a;if(m==null||g==null)return s(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: ${o}`));i({childProcess:r,url:`http://${m}:${g}`})};r.once("error",o=>{this.#e=null,s(new u(String(o)))}),r.once("exit",(o,l)=>{this.#e=null,s(new u(`Query Engine exited with code ${o} and signal ${l}`))}),r.stdout.on("data",c),r.stderr.on("data",o=>{console.error(o)}),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 O(e,"exit"))}async#n(){let e=await this.#s(),r=w(this.#t.clientVersion,e);await T(r,{recursive:!0});let{platform:s}=this.#t.platform,t=s==="windows"?".exe":"",i=D(r,`query-engine-${s}${t}`);return await y(i)||await this.#o({commitHash:e,extension:t,engineBinaryPath:i}),i}async#s(){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 s=(await e.json()).dependencies?.["@prisma/engines-version"];if(!s)throw new Error("Couldn't find engines version in package.json");let t=s.split(".").at(-1);if(!t)throw new Error("Couldn't find commit hash in engines version");return t}async#o(e){let{commitHash:r,extension:s,engineBinaryPath:t}=e,{platform:i}=this.#t.platform,c=`https://binaries.prisma.sh/all_commits/${r}/${i}/query-engine${s}.gz`,o=await fetch(c);if(!o.ok)throw new Error(`Couldn't download engine. URL: ${c}, status code: ${o.status}`);await v(await o.arrayBuffer(),t)}},u=class extends Error{name="EngineStartError"},d=class n extends Error{constructor(r,s,t){super(`${r}: Query Engine response status ${s}, body: ${t}`);this.action=r;this.statusCode=s;this.responseBody=t}name="EngineHttpError";static async fromResponse(r){let s=new URL(r.url),t=await r.text();return new n(s.pathname,r.status,t)}};async function E(n,e,r){let s=new S,t=await q.getPlatformInfo();r&&console.log("platform info: %s",JSON.stringify(t)),s.use(async(a,m)=>{a.set("db",e),a.set("debug",!!r),a.set("platform",t),a.set("schemasByHash",new Map),await m()}),s.route("/",h);let{fail:i,promise:c,succeed:o}=p(),l=j({createServer:L,fetch:s.fetch,port:n},()=>{o()});return l.on("error",a=>{if(typeof a=="object"&&"code"in a&&a.code==="EADDRINUSE")return i({portNotAvailable:n});console.error(a)}),await c,{async close(){await V(l.close.bind(l))()},port:n,url:`http://localhost:${n}`}}var h=new S;h.put("/:clientVersion/:schemaHash/schema",async n=>{let{req:e}=n,r=await e.text(),s=e.param("schemaHash"),t=n.get("schemasByHash");return r===t.get(s)?.original||t.set(s,{original:r,override:N(r,n.get("db").connectionString)}),n.text(s)});h.post("/:clientVersion/:schemaHash/graphql",async n=>{let{req:e}=n,r=e.param("schemaHash"),t=n.get("schemasByHash").get(r);if(t==null)return n.json({EngineNotStarted:{reason:"SchemaMissing"}},404);let i=e.param("clientVersion"),c=n.get("platform");try{let o=await f.get({base64Schema:t.override,clientVersion:i,platform:c,schemaHash:r}),l=await e.text(),a=e.header("traceparent"),m=e.header("X-capture-telemetry"),g=await o.request(l,{traceparent:a,xCaptureTelemetry:m});return n.text(g)}catch(o){return o instanceof u?n.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:o.message}}}},500):o instanceof d?n.text(o.responseBody,o.statusCode):n.body(null,500)}});var I=/datasource\s+db\s+[\w\s\d{="[\])(]+}/;function N(n,e){let r=b.from(n,"base64").toString("utf8"),s=`datasource db {
|
|
5
|
-
provider = "postgresql"
|
|
6
|
-
url = "${e}"
|
|
7
|
-
}`,t=r.replace(I,s);return b.from(t,"utf8").toString("base64")}import{promisify as M}from"util";import{PGlite as F}from"@electric-sql/pglite";import{createServer as U,LogLevel as _}from"pglite-server";async function P(n,e){let r="default",s="postgres",t=new F({database:r,dataDir:"memory://",debug:e?5:void 0,username:s});await t.waitReady;let i=U(t,{keepAlive:!0,logLevel:e?_.Debug:void 0}),{fail:c,promise:o,succeed:l}=p();return i.on("error",a=>{if("code"in a&&a.code==="EADDRINUSE")return c(new Error(`Port ${n} is already in use. Provide a different \`dbport\` number and try again.`));console.error(a)}),i.listen(n,()=>l()),await o,{async close(){try{await M(i.close.bind(i))()}finally{await t.close()}},connectionString:`postgres://${s}@localhost:${n}/${r}`,database:r,port:n,username:s}}async function ve(n){let{acceleratePort:e=5433,databasePort:r=5432,debug:s}=n||{},t=await P(r,s),i=await E(e,t,s);return{accelerate:{url:i.url},close:()=>c([i,t]),database:{connectionString:t.connectionString},ppg:{url:`prisma+postgres://localhost:${i.port}/?dbname=${t.database}&dbport=${t.port}&dbuser=${t.username}`}};async function c(o){let a=(await Promise.allSettled(o.map(m=>m.close()))).filter(m=>m.status==="rejected").map(m=>new Error(m.reason));if(a.length>0)throw new AggregateError(a,"Failed to close some servers")}}export{ve as unstable_startServer};
|
|
2
|
+
import{createHash as g}from"crypto";import{createServer as S}from"http2";import{promisify as h}from"util";import{serve as w}from"@hono/node-server";import{Hono as p}from"hono/tiny";function d(){let e,a,o=new Promise((r,t)=>{e=r,a=t});return{fail:a,promise:o,succeed:e}}async function v(e,a,o){let r=new p;r.use(async(n,i)=>{n.set("db",a),n.set("debug",!!o),await i()}),r.route("/",f);let{fail:t,promise:s,succeed:l}=d(),c=w({createServer:S,fetch:r.fetch,port:e},()=>{l()});return c.on("error",n=>{if(typeof n=="object"&&"code"in n&&n.code==="EADDRINUSE")return t({portNotAvailable:e});console.error(n)}),await s,{async close(){await h(c.close.bind(c))()},port:e,url:`http://localhost:${e}`}}var u=new Map,f=new p;f.put("/:clientVersion/:schemaHash/schema",async e=>{let{req:a}=e,o=await a.text(),r=a.param("schemaHash");return o===u.get(r)?e.text(r):r!==y(o)?e.text("hashes do not match",500):(u.set(r,o),e.text(r))});function y(e){return g("sha256").update(e).digest("hex")}import{promisify as P}from"util";import{PGlite as D}from"@electric-sql/pglite";import{createServer as A,LogLevel as x}from"pglite-server";async function b(e,a){let o="default",r="postgres",t=new D({database:o,dataDir:"memory://",debug:a?5:void 0,username:r});await t.waitReady;let s=A(t,{keepAlive:!0,logLevel:a?x.Debug:void 0}),{fail:l,promise:c,succeed:n}=d();return s.on("error",i=>{if("code"in i&&i.code==="EADDRINUSE")return l(new Error(`Port ${e} is already in use. Provide a different \`dbport\` number and try again.`));console.error(i)}),s.listen(e,()=>n()),await c,{async close(){try{await P(s.close.bind(s))()}finally{await t.close()}},connectionString:`postgres://${r}@localhost:${e}/${o}`,database:o,port:e,username:r}}async function F(e){let{acceleratePort:a=5433,databasePort:o=5432,debug:r}=e||{},t=await b(o,r),s=await v(a,t,r);return{accelerate:{url:s.url},close:()=>l([s,t]),database:{connectionString:t.connectionString},ppg:{url:`prisma+postgres://localhost:${s.port}/?dbname=${t.database}&dbport=${t.port}&dbuser=${t.username}`}};async function l(c){let i=(await Promise.allSettled(c.map(m=>m.close()))).filter(m=>m.status==="rejected").map(m=>new Error(m.reason));if(i.length>0)throw new AggregateError(i,"Failed to close some servers")}}export{F as unstable_startServer};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@prisma/dev",
|
|
3
|
-
"version": "0.0.0-dev.
|
|
3
|
+
"version": "0.0.0-dev.202505082225",
|
|
4
4
|
"description": "A local Prisma Postgres server for development and testing",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "./dist/index.js",
|
|
@@ -29,8 +29,6 @@
|
|
|
29
29
|
"devDependencies": {
|
|
30
30
|
"@arethetypeswrong/cli": "0.17.4",
|
|
31
31
|
"@types/node": "22.3.0",
|
|
32
|
-
"@types/pako": "2.0.3",
|
|
33
|
-
"pkg-types": "2.1.0",
|
|
34
32
|
"tsup": "8.0.2",
|
|
35
33
|
"typescript": "5.8.3",
|
|
36
34
|
"vitest": "3.1.3"
|
|
@@ -38,10 +36,7 @@
|
|
|
38
36
|
"dependencies": {
|
|
39
37
|
"@electric-sql/pglite": "0.2.17",
|
|
40
38
|
"@hono/node-server": "1.14.1",
|
|
41
|
-
"@prisma/get-platform": "6.7.0",
|
|
42
|
-
"env-paths": "3.0.0",
|
|
43
39
|
"hono": "4.7.8",
|
|
44
|
-
"pako": "2.1.0",
|
|
45
40
|
"pglite-server": "0.1.4"
|
|
46
41
|
},
|
|
47
42
|
"scripts": {
|