@prisma/dev 0.24.13 → 0.24.14
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/accelerate-45DUGMGZ.js +11 -0
- package/dist/chunk-662IKR3V.js +1 -0
- package/dist/chunk-ANHBRJRZ.js +1 -0
- package/dist/chunk-DOJAPHLY.js +1 -0
- package/dist/chunk-FB4QA6EA.js +1 -0
- package/dist/{chunk-2XJK3IOI.js → chunk-HFONW2ZS.js} +3 -3
- package/dist/chunk-SW3J2PL2.js +1 -0
- package/dist/daemon.cjs +27 -27
- package/dist/daemon.js +1 -1
- package/dist/engine-YTEOPVUP.js +3 -0
- package/dist/index.cjs +27 -27
- package/dist/index.js +1 -1
- package/dist/query-plan-executor-ZS4544O3.js +1 -0
- package/dist/server-QR7P25DP.js +1 -0
- package/dist/state.cjs +3 -3
- package/dist/state.js +1 -1
- package/dist/utility-YEFNU35E.js +1 -0
- package/package.json +2 -4
- package/dist/accelerate-5FDEK4T6.js +0 -11
- package/dist/chunk-3UF2MBYQ.js +0 -1
- package/dist/chunk-GMUOAEZU.js +0 -1
- package/dist/chunk-HQMJSXYT.js +0 -1
- package/dist/engine-XP6YJ63T.js +0 -3
- package/dist/query-plan-executor-F6RXHJSD.js +0 -1
- package/dist/utility-Q5A254LJ.js +0 -1
package/dist/daemon.cjs
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
"use strict";var Nn=Object.create;var ae=Object.defineProperty;var On=Object.getOwnPropertyDescriptor;var Mn=Object.getOwnPropertyNames;var Bn=Object.getPrototypeOf,Ln=Object.prototype.hasOwnProperty;var T=(e,t)=>()=>(e&&(t=e(e=0)),t);var ie=(e,t)=>{for(var r in t)ae(e,r,{get:t[r],enumerable:!0})},Mt=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Mn(t))!Ln.call(e,s)&&s!==r&&ae(e,s,{get:()=>t[s],enumerable:!(n=On(t,s))||n.enumerable});return e};var v=(e,t,r)=>(r=e!=null?Nn(Bn(e)):{},Mt(t||!e||!e.__esModule?ae(r,"default",{value:e,enumerable:!0}):r,e)),$n=e=>Mt(ae({},"__esModule",{value:!0}),e);var kn,y,m=T(()=>{"use strict";kn=()=>typeof document>"u"?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.tagName.toUpperCase()==="SCRIPT"?document.currentScript.src:new URL("main.js",document.baseURI).href,y=kn()});function Lt(e){return Buffer.from(JSON.stringify(Object.fromEntries(Object.entries(e).sort(([[t],[r]])=>t.localeCompare(r)))),"utf8").toString("base64url")}function Un(e){let t=Buffer.from(e,"base64url").toString("utf8"),{issues:r,output:n,success:s}=(0,P.safeParse)(Cn,t,{abortEarly:!0});return s?[null,n]:[r]}var P,Bt,Cn,Q,Ae=T(()=>{"use strict";m();P=require("valibot"),Bt=/^(postgres|postgresql):\/\//,Cn=(0,P.pipe)((0,P.string)(),(0,P.parseJson)(),(0,P.object)({databaseUrl:(0,P.pipe)((0,P.string)(),(0,P.url)(),(0,P.regex)(Bt)),name:(0,P.optional)((0,P.pipe)((0,P.string)(),(0,P.minLength)(1))),shadowDatabaseUrl:(0,P.pipe)((0,P.string)(),(0,P.url)(),(0,P.regex)(Bt))}));Q=async(e,t)=>{let{authorization:r}=e,{HTTPException:n}=await import("hono/http-exception");if(!r)throw new n(401,{message:"Missing API Key"});let[s,o="",a]=r.split(" ");if(s!=="Bearer"||a)throw new n(401,{message:"Invalid API Key"});let[i,c]=Un(o);if(i)throw new n(401,{message:"Invalid API Key",cause:i.join(", ")});let{databaseUrl:u,name:l,shadowDatabaseUrl:h}=c,d=t.get("name"),p=new URL(t.req.url).port;if(!l)throw new n(401,{message:`Wrong API Key; The Prisma Dev server running at port ${p} requires an API Key from a newer version of \`prisma dev\`. Check the "${d}" server's output for the updated \`DATABASE_URL\` value.`});if(l!==d)throw new n(401,{message:`Wrong API Key; The Prisma Dev server running at port ${p} is named "${d}", but the API Key is for "${l}"`});let{hostname:f,port:E}=new URL(u),{port:J}=t.get("db"),{hostname:_e,port:_n}=new URL(h),An=t.get("shadowDBPort");if(f!=="localhost"||Number(E)!==J||_e!=="localhost"||Number(_n)!==An)throw new n(401,{message:"Wrong API Key; Check your Prisma schema's `provider.url` value (probably defined in `.env`'s `DATABASE_URL` environment variable) is aligned with `prisma dev`'s output"});return{decodedAPIKey:c}}});function Me(e,{suffix:t="nodejs"}={}){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return t&&(e+=`-${t}`),ce.default.platform==="darwin"?Qn(e):ce.default.platform==="win32"?qn(e):Fn(e)}var w,Ne,ce,B,Oe,G,Qn,qn,Fn,$t=T(()=>{"use strict";m();w=v(require("path"),1),Ne=v(require("os"),1),ce=v(require("process"),1),B=Ne.default.homedir(),Oe=Ne.default.tmpdir(),{env:G}=ce.default,Qn=e=>{let t=w.default.join(B,"Library");return{data:w.default.join(t,"Application Support",e),config:w.default.join(t,"Preferences",e),cache:w.default.join(t,"Caches",e),log:w.default.join(t,"Logs",e),temp:w.default.join(Oe,e)}},qn=e=>{let t=G.APPDATA||w.default.join(B,"AppData","Roaming"),r=G.LOCALAPPDATA||w.default.join(B,"AppData","Local");return{data:w.default.join(r,e,"Data"),config:w.default.join(t,e,"Config"),cache:w.default.join(r,e,"Cache"),log:w.default.join(r,e,"Log"),temp:w.default.join(Oe,e)}},Fn=e=>{let t=w.default.basename(B);return{data:w.default.join(G.XDG_DATA_HOME||w.default.join(B,".local","share"),e),config:w.default.join(G.XDG_CONFIG_HOME||w.default.join(B,".config"),e),cache:w.default.join(G.XDG_CACHE_HOME||w.default.join(B,".cache"),e),log:w.default.join(G.XDG_STATE_HOME||w.default.join(B,".local","state"),e),temp:w.default.join(Oe,t,e)}}});function Qt(e,t){return`${le.cache}/engine/${e}/${t}`}function Y(e){return`${le.data}/${e}`}async function H(e){try{return await(0,R.access)(e,R.constants.F_OK),!0}catch(t){if(Be(t))return!1;throw t}}async function qt(e,t){let r=await Wn(e);await(0,R.writeFile)(t,r),await(0,R.chmod)(t,"755")}async function Ft(e,t){await e.stream().pipeTo(ue.WriteStream.toWeb((0,ue.createWriteStream)(t,{encoding:"utf8"})))}function Be(e){return e!=null&&typeof e=="object"&&"code"in e&&e.code==="ENOENT"}async function Wt(e){try{return await(0,R.readFile)(e,{encoding:"utf-8"})}catch(t){if(Be(t))return null;throw t}}async function Gt(e){await(0,R.mkdir)(e,{recursive:!0})}async function Ht(e,t){try{return(await(0,R.readdir)(e,{withFileTypes:!0})).reduce((n,s)=>(s.isDirectory()&&!s.name.startsWith(".")&&(!t||(0,Ut.default)(t,s.name))&&n.push(s.name),n),[])}catch(r){if(Be(r))return[];throw r}}async function j(e){await(0,R.rm)(e,{force:!0,recursive:!0})}var ue,R,kt,Ct,Ut,le,Wn,K=T(()=>{"use strict";m();ue=require("fs"),R=require("fs/promises"),kt=require("util"),Ct=require("zlib");$t();Ut=v(require("zeptomatch"),1),le=Me("prisma-dev"),Wn=(0,kt.promisify)(Ct.unzip)});function Pe(e){let t,r,n=new Promise((a,i)=>{t=a,r=i}),s=a=>{s=o=null,r(a),e?.onRejected?.(a),e?.onFulfilled?.()},o=a=>{o=s=null,t(a),e?.onResolved?.(a),e?.onFulfilled?.()};return{isFulfilled:()=>o===s,promise:n,reject:a=>s?.(a),resolve:a=>o?.(a)}}var rt=T(()=>{"use strict";m()});var st={};ie(st,{Engine:()=>nt,handleEngineError:()=>Ks});function Ks(e,t){return console.error(e),e instanceof Z?t.json({EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:e.message}}}},500):e instanceof V?t.text(e.responseBody,e.statusCode):t.body(null,500)}var Nr,Or,Mr,Br,Lr,$r,Hs,js,Ar,nt,Z,V,ot=T(()=>{"use strict";m();Nr=require("child_process"),Or=require("events"),Mr=require("fs/promises"),Br=require("path"),Lr=require("timers/promises");rt();$r=require("std-env");K();({PRISMA_DEV_FORCE_ENGINE_BINARY_DOWNLOAD:Hs,PRISMA_DEV_FORCE_ENGINE_BINARY_PATH:js,PRISMA_DEV_FORCE_NETWORK_DELAY_MS:Ar}=$r.process.env),nt=class e{static#r=new Map;#e;#t;constructor(t){this.#e=t,this.#t=null}static async get(t){let{debug:r}=t,n=`${t.schemaHash}:${t.clientVersion}`;try{let s=e.#r.get(n);if(s)return s;let o=new e(t);return e.#r.set(n,o),r&&console.debug("[Query Engine] starting...",t),await o.start(),r&&console.debug("[Query Engine] started!"),o}finally{e.stopAll(n)}}static async stopAll(t){let n=(await Promise.allSettled(Array.from(e.#r.entries()).filter(([s])=>s!==t).map(async([s,o])=>{try{await o.stop()}finally{e.#r.delete(s)}}))).filter(s=>s.status==="rejected").map(s=>s.reason);if(n.length>0)throw new AggregateError(n,"Failed to stop engines")}async commitTransaction(t,r){return await this.#i(t,r,"commit")}async request(t,r){let{url:n}=await this.start(),s=this.#n(r),o=await fetch(n,{body:typeof t=="string"?t:JSON.stringify(t),headers:{...s,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await V.fromResponse(o);return await o.text()}async rollbackTransaction(t,r){return await this.#i(t,r,"rollback")}async startTransaction(t,r){let{url:n}=await this.start(),s=this.#n(r),o=await fetch(`${n}/transaction/start`,{body:JSON.stringify(t),headers:{...s,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await V.fromResponse(o);return await o.json()}async start(){if(this.#t!=null)return await this.#t;let{promise:t,reject:r,resolve:n}=Pe();this.#t=t;let s=js||await this.#s();this.#e.debug&&console.debug("[Query Engine] spinning up at path...",s);let{proxySignals:o}=await import("foreground-child/proxy-signals"),a=(0,Nr.spawn)(s,["--enable-raw-queries","--enable-telemetry-in-response","--port","0"],{env:{LOG_QUERIES:"y",PRISMA_DML:this.#e.base64Schema,QE_LOG_LEVEL:"TRACE",RUST_BACKTRACE:"1",RUST_LOG:"info"},stdio:["ignore","pipe","pipe"],windowsHide:!0});o(a),a.stderr.setEncoding("utf8"),a.stdout.setEncoding("utf8");let i=l=>{let h=l.split(`
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
`)&&!e.includes("\r")){let h=e.trim();return h.length===0?`${o}${i}${o}${r}`:`${o}${a}${h}${o}${i}${o}${r}`}let c=s.at(-1);if(c&&c.terminator===""&&/^\s*$/.test(c.line))return`${at(s.slice(0,-1))}${i}${o}${r}`;let u=at(s),l=u.endsWith(`
|
|
6
|
-
`)||u.endsWith("\r")?"":o;return`${u}${l}${i}${o}${r}`}function to(e){let t=[],r=0;for(let n=0;n<e.length;n+=1){if(e[n]==="\r"&&e[n+1]===`
|
|
1
|
+
"use strict";var Wn=Object.create;var me=Object.defineProperty;var Gn=Object.getOwnPropertyDescriptor;var jn=Object.getOwnPropertyNames;var Vn=Object.getPrototypeOf,Kn=Object.prototype.hasOwnProperty;var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var re=(e,t)=>{for(var r in t)me(e,r,{get:t[r],enumerable:!0})},qt=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of jn(t))!Kn.call(e,s)&&s!==r&&me(e,s,{get:()=>t[s],enumerable:!(n=Gn(t,s))||n.enumerable});return e};var D=(e,t,r)=>(r=e!=null?Wn(Vn(e)):{},qt(t||!e||!e.__esModule?me(r,"default",{value:e,enumerable:!0}):r,e)),zn=e=>qt(me({},"__esModule",{value:!0}),e);var Jn,h,m=v(()=>{"use strict";Jn=()=>typeof document>"u"?new URL(`file:${__filename}`).href:document.currentScript&&document.currentScript.tagName.toUpperCase()==="SCRIPT"?document.currentScript.src:new URL("main.js",document.baseURI).href,h=Jn()});var A,pe=v(()=>{"use strict";m();A=class extends Error{constructor(r,n,s){super(n,s);this.status=r}name="HTTPError"}});function Ft(e){return Buffer.from(JSON.stringify(Object.fromEntries(Object.entries(e).sort(([[t],[r]])=>t.localeCompare(r)))),"utf8").toString("base64url")}function Xn(e){let t=Buffer.from(e,"base64url").toString("utf8"),{issues:r,output:n,success:s}=(0,P.safeParse)(Yn,t,{abortEarly:!0});return s?[null,n]:[r]}function G(e,t){let r=e.headers.authorization;if(!r)throw new A(401,"Missing API Key");let[n,s="",o]=r.split(" ");if(n!=="Bearer"||o)throw new A(401,"Invalid API Key");let[a,i]=Xn(s);if(a)throw new A(401,"Invalid API Key",{cause:a.join(", ")});let{databaseUrl:c,name:u,shadowDatabaseUrl:l}=i,f=t.name,d=t.port;if(!u)throw new A(401,`Wrong API Key; The Prisma Dev server running at port ${d} requires an API Key from a newer version of \`prisma dev\`. Check the "${f}" server's output for the updated \`DATABASE_URL\` value.`);if(u!==f)throw new A(401,`Wrong API Key; The Prisma Dev server running at port ${d} is named "${f}", but the API Key is for "${u}"`);let{hostname:p,port:y}=new URL(c),{port:E}=t.db,{hostname:te,port:Le}=new URL(l),Fn=t.shadowDBPort;if(p!=="localhost"||Number(y)!==E||te!=="localhost"||Number(Le)!==Fn)throw new A(401,"Wrong API Key; Check your Prisma schema's `provider.url` value (probably defined in `.env`'s `DATABASE_URL` environment variable) is aligned with `prisma dev`'s output");return i}var P,Ht,Yn,$e=v(()=>{"use strict";m();P=require("valibot");pe();Ht=/^(postgres|postgresql):\/\//,Yn=(0,P.pipe)((0,P.string)(),(0,P.parseJson)(),(0,P.object)({databaseUrl:(0,P.pipe)((0,P.string)(),(0,P.url)(),(0,P.regex)(Ht)),name:(0,P.optional)((0,P.pipe)((0,P.string)(),(0,P.minLength)(1))),shadowDatabaseUrl:(0,P.pipe)((0,P.string)(),(0,P.url)(),(0,P.regex)(Ht))}))});function Ue(e,{suffix:t="nodejs"}={}){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return t&&(e+=`-${t}`),ge.default.platform==="darwin"?Zn(e):ge.default.platform==="win32"?es(e):ts(e)}var w,ke,ge,U,Ce,K,Zn,es,ts,Wt=v(()=>{"use strict";m();w=D(require("path"),1),ke=D(require("os"),1),ge=D(require("process"),1),U=ke.default.homedir(),Ce=ke.default.tmpdir(),{env:K}=ge.default,Zn=e=>{let t=w.default.join(U,"Library");return{data:w.default.join(t,"Application Support",e),config:w.default.join(t,"Preferences",e),cache:w.default.join(t,"Caches",e),log:w.default.join(t,"Logs",e),temp:w.default.join(Ce,e)}},es=e=>{let t=K.APPDATA||w.default.join(U,"AppData","Roaming"),r=K.LOCALAPPDATA||w.default.join(U,"AppData","Local");return{data:w.default.join(r,e,"Data"),config:w.default.join(t,e,"Config"),cache:w.default.join(r,e,"Cache"),log:w.default.join(r,e,"Log"),temp:w.default.join(Ce,e)}},ts=e=>{let t=w.default.basename(U);return{data:w.default.join(K.XDG_DATA_HOME||w.default.join(U,".local","share"),e),config:w.default.join(K.XDG_CONFIG_HOME||w.default.join(U,".config"),e),cache:w.default.join(K.XDG_CACHE_HOME||w.default.join(U,".cache"),e),log:w.default.join(K.XDG_STATE_HOME||w.default.join(U,".local","state"),e),temp:w.default.join(Ce,t,e)}}});function Kt(e,t){return`${he.cache}/engine/${e}/${t}`}function ne(e){return`${he.data}/${e}`}async function z(e){try{return await(0,R.access)(e,R.constants.F_OK),!0}catch(t){if(Qe(t))return!1;throw t}}async function zt(e,t){let r=await rs(e);await(0,R.writeFile)(t,r),await(0,R.chmod)(t,"755")}async function Jt(e,t){await e.stream().pipeTo(fe.WriteStream.toWeb((0,fe.createWriteStream)(t,{encoding:"utf8"})))}function Qe(e){return e!=null&&typeof e=="object"&&"code"in e&&e.code==="ENOENT"}async function Yt(e){try{return await(0,R.readFile)(e,{encoding:"utf-8"})}catch(t){if(Qe(t))return null;throw t}}async function Xt(e){await(0,R.mkdir)(e,{recursive:!0})}async function Zt(e,t){try{return(await(0,R.readdir)(e,{withFileTypes:!0})).reduce((n,s)=>(s.isDirectory()&&!s.name.startsWith(".")&&(!t||(0,Vt.default)(t,s.name))&&n.push(s.name),n),[])}catch(r){if(Qe(r))return[];throw r}}async function J(e){await(0,R.rm)(e,{force:!0,recursive:!0})}var fe,R,Gt,jt,Vt,he,rs,Y=v(()=>{"use strict";m();fe=require("fs"),R=require("fs/promises"),Gt=require("util"),jt=require("zlib");Wt();Vt=D(require("zeptomatch"),1),he=Ue("prisma-dev"),rs=(0,Gt.promisify)(jt.unzip)});async function Ke(e){let{debug:t,name:r,requestedPorts:n,servers:s}=e,{portsUsedByOtherServers:o,portsUsedByThisServerLastTime:a}=os(r,s);t&&(console.debug(`ports used by other servers: ${Object.keys(o).join(", ")}`),console.debug(`ports used by "${r}" server last time: ${JSON.stringify(a)}`));let i={databasePort:_,port:_,shadowDatabasePort:_,streamsPort:_},c=["port","databasePort","shadowDatabasePort","streamsPort"];for(let u of c){let l=await ns({debug:t,portKey:u,portsUsedByOtherServers:o,portsUsedByThisServerLastTime:a,requestedPorts:n})??await ss({debug:t,pickedPorts:i,portKey:u,portsUsedByOtherServers:o,portsUsedByThisServerLastTime:a});t&&console.debug(`Got port for "${u}": ${l}`),i[u]=l}return t&&console.debug(`Picked ports: ${JSON.stringify(i)}`),i}async function ns(e){let{debug:t,portKey:r,portsUsedByOtherServers:n,portsUsedByThisServerLastTime:s,requestedPorts:o}=e,{[r]:a,...i}=o;if(Ge(a))return await cs({debug:t,otherRequestedPorts:i,portKey:r,portsUsedByOtherServers:n,requestedPort:a}),a;let c=s?.[r]??_;if(!Ge(c))return t&&console.debug(`No port specified for "${r}". Trying to pick a new port.`),null;let u=c in n;return u||Object.values(i).includes(c)?(t&&console.debug(`Port ${c} that was used last time for this server, ${u?"is also used by another server":"has been requested for another service"}. Trying to pick a new port.`),null):await(0,Q.checkPort)(c)===!1?(t&&console.debug(`Port ${c}, that was used last time for this server, is not available. Trying to pick a new port.`),null):(t&&console.debug(`Using port ${c} for "${r}" as it was used last time and is available.`),c)}async function ss(e){let{debug:t,pickedPorts:r,portKey:n,portsUsedByOtherServers:s,portsUsedByThisServerLastTime:o}=e,a=Math.max(qe,He,Fe,We)+1,i=Object.values(r).filter(p=>p!==void 0),c=o?is(o):[],u=[...i,...Object.keys(s).map(Number),...c],l=Math.min(Math.max(a,...u)+100,ye),f=(0,Se.difference)((0,Se.range)(a,l),u),d={port:He,databasePort:qe,shadowDatabasePort:Fe,streamsPort:We}[n];try{return await(0,Q.getPort)({port:d in s||i.includes(d)||c.includes(d)?void 0:d,ports:f})}catch(p){if(p instanceof Error&&p.name==="GetPortError"&&l+1<=ye)return t&&console.debug(`Expanding port lookup to range [${l+1}, ${ye}].`),await(0,Q.getPort)({portRange:[l+1,ye]});throw p}}function Ge(e){return Number.isFinite(e)&&e>=0}function os(e,t){let r={},n;for(let s of t){let{databasePort:o,port:a,shadowDatabasePort:i}=s,c=as(s);if(s.name===e){n={databasePort:o,port:a,shadowDatabasePort:i,streamsPort:c};continue}r[o]=!0,r[a]=!0,r[i]=!0,Ge(c)&&(r[c]=!0)}return{portsUsedByOtherServers:r,portsUsedByThisServerLastTime:n}}function as(e){let t=e.experimental?.streams?.serverUrl;if(!t)return _;try{let r=Number(new URL(t).port);return Number.isInteger(r)&&r>0?r:_}catch{return _}}function is(e){return[e.port,e.databasePort,e.shadowDatabasePort,e.streamsPort]}async function cs(e){let{debug:t,otherRequestedPorts:r,portKey:n,portsUsedByOtherServers:s,requestedPort:o}=e;if(o!==j){if(o in s)throw t&&console.error(`Port ${o} was requested for "${n}", but is already used by another server.`),new Ve(o);if(Object.values(r).includes(o))throw t&&console.error(`Port ${o} was requested for "${n}", but also for another key.`),new je(o);if((0,Q.isUnsafePort)(o))throw t&&console.error(`Port ${o} was requested for "${n}", but is unsafe.`),new N(o);if(await(0,Q.checkPort)(o)===!1)throw t&&console.error(`Port ${o} was requested for "${n}", but is not available.`),new N(o)}}var Q,Se,qe,He,Fe,We,ye,j,_,N,je,Ve,se=v(()=>{"use strict";m();Q=require("get-port-please"),Se=require("remeda"),qe=51214,He=51213,Fe=51215,We=51216,ye=65535,j=0,_=-1/0;N=class extends Error{constructor(r){super(`Port \`${r}\` is not available.`);this.port=r}name="PortNotAvailableError"},je=class extends Error{constructor(r){super(`Port number \`${r}\` was requested twice. Please choose a different port for each service.`);this.port=r}name="PortRequestedTwiceError"},Ve=class extends Error{constructor(r){super(`Port number \`${r}\` belongs to another Prisma Dev server. Please choose a different port.`);this.port=r}name="PortBelongsToAnotherServerError"}});function T(e,t,r=200){let n=ct.Buffer.from(JSON.stringify(t),"utf8");e.headersSent||(e.setHeader("Content-Type","application/json; charset=utf-8"),e.setHeader("Content-Length",n.byteLength),e.statusCode=r),e.end(n)}function x(e,t,r=200){let n=ct.Buffer.from(t,"utf8");e.headersSent||(e.setHeader("Content-Type","text/plain; charset=utf-8"),e.setHeader("Content-Length",n.byteLength),e.statusCode=r),e.end(n)}function X(e,t=204){e.headersSent||(e.statusCode=t,e.setHeader("Content-Length",0)),e.end()}function Cr(e,t){x(e,t.message,t.status)}var ct,C=v(()=>{"use strict";m();ct=require("buffer")});async function Qr(e,t){let r;try{r=await(0,Ur.json)(e)}catch{return x(t,"Invalid input",400),null}let{output:n,success:s}=(0,I.safeParse)(so,r,{abortEarly:!0});return s?n:(x(t,"Invalid input",400),null)}var Ur,I,so,qr=v(()=>{"use strict";m();Ur=require("stream/consumers"),I=require("valibot");C();so=(0,I.object)({tags:(0,I.union)([(0,I.pipe)((0,I.array)((0,I.string)()),(0,I.minLength)(1)),(0,I.literal)("all")])})});async function dt(e){let r=new TextEncoder().encode(e),n=await crypto.subtle.digest("SHA-256",r);return Array.from(new Uint8Array(n)).map(a=>a.toString(16).padStart(2,"0")).join("")}function Fr(e,t){let r=e.schemaHash;if(r==null)return T(t,{EngineNotStarted:{reason:"SchemaMissing"}},404),null;let n=xe.get(r);return n==null?(T(t,{EngineNotStarted:{reason:"SchemaMissing"}},404),null):{schemaHash:r,schemas:n}}async function Wr(e,t,r){let n=lt.Buffer.from(e,"base64").toString("utf8"),s=ao(n,t.toString());r&&console.log("[Accelerate] schema with override:",s);let o=await dt(s);return{base64Override:lt.Buffer.from(s,"utf8").toString("base64"),overrideHash:o}}function ao(e,t){let r=io(e);if(!r)throw new Error("No datasource block found in schema.");let n=e.slice(r.openBraceIndex+1,r.closeBraceIndex),s=lo(n,t,go(e,r.openBraceIndex));return`${e.slice(0,r.openBraceIndex+1)}${s}${e.slice(r.closeBraceIndex)}`}function io(e){let t="datasource";for(let r=0;r<e.length;r+=1){let n=e[r];if(n==="/"&&e[r+1]==="/"){r=mt(e,r+2);continue}if(n==="/"&&e[r+1]==="*"){r=pt(e,r+2);continue}if(n==='"'){r=gt(e,r+1);continue}if(e.startsWith(t,r)&&!Hr(e[r-1])&&!Hr(e[r+t.length])){let s=co(e,r+t.length,"{");if(s===-1)return null;let o=uo(e,s);return o===-1?null:{closeBraceIndex:o,openBraceIndex:s}}}return null}function co(e,t,r){for(let n=t;n<e.length;n+=1){let s=e[n];if(s==="/"&&e[n+1]==="/"){n=mt(e,n+2);continue}if(s==="/"&&e[n+1]==="*"){n=pt(e,n+2);continue}if(s==='"'){n=gt(e,n+1);continue}if(s===r)return n}return-1}function uo(e,t){let r=0;for(let n=t;n<e.length;n+=1){let s=e[n];if(s==="/"&&e[n+1]==="/"){n=mt(e,n+2);continue}if(s==="/"&&e[n+1]==="*"){n=pt(e,n+2);continue}if(s==='"'){n=gt(e,n+1);continue}if(s==="{"){r+=1;continue}if(s==="}"&&(r-=1,r===0))return n}return-1}function mt(e,t){let r=t;for(;r<e.length&&e[r]!==`
|
|
2
|
+
`;)r+=1;return r}function pt(e,t){let r=e.indexOf("*/",t);return r===-1?e.length:r+1}function gt(e,t){let r=t;for(;r<e.length;){if(e[r]==="\\"){r+=2;continue}if(e[r]==='"')return r;r+=1}return e.length}function Hr(e){return e!=null&&/[A-Za-z0-9_]/.test(e)}function lo(e,t,r){let n=`"${ho(t)}"`,s=mo(e);for(let[f,d]of s.entries()){let{comment:p,code:y}=Gr(d.line),E=y.match(/^(\s*)url(\s*)=(\s*).*/);if(E)return s[f]={line:`${E[1]}url${E[2]}=${E[3]}${n}${p}`,terminator:d.terminator},ut(s)}let o=fo(e),a=po(s,r),i=`${a}url = ${n}`;if(!e.includes(`
|
|
3
|
+
`)&&!e.includes("\r")){let f=e.trim();return f.length===0?`${o}${i}${o}${r}`:`${o}${a}${f}${o}${i}${o}${r}`}let c=s.at(-1);if(c&&c.terminator===""&&/^\s*$/.test(c.line))return`${ut(s.slice(0,-1))}${i}${o}${r}`;let u=ut(s),l=u.endsWith(`
|
|
4
|
+
`)||u.endsWith("\r")?"":o;return`${u}${l}${i}${o}${r}`}function mo(e){let t=[],r=0;for(let n=0;n<e.length;n+=1){if(e[n]==="\r"&&e[n+1]===`
|
|
7
5
|
`){t.push({line:e.slice(r,n),terminator:`\r
|
|
8
6
|
`}),n+=1,r=n+1;continue}(e[n]===`
|
|
9
|
-
`||e[n]==="\r")&&(t.push({line:e.slice(r,n),terminator:e[n]}),r=n+1)}return(r<e.length||e.length===0)&&t.push({line:e.slice(r),terminator:""}),t}function
|
|
10
|
-
`,t)+1,n=r;for(;e[n]===" "||e[n]===" ";)n+=1;return e.slice(r,n)}function
|
|
7
|
+
`||e[n]==="\r")&&(t.push({line:e.slice(r,n),terminator:e[n]}),r=n+1)}return(r<e.length||e.length===0)&&t.push({line:e.slice(r),terminator:""}),t}function ut(e){return e.map(t=>`${t.line}${t.terminator}`).join("")}function Gr(e){let t=!1,r=!1;for(let n=0;n<e.length;n+=1){let s=e[n];if(r){if(t){t=!1;continue}if(s==="\\"){t=!0;continue}s==='"'&&(r=!1);continue}if(s==='"'){r=!0;continue}if(s==="/"&&e[n+1]==="/")return{code:e.slice(0,n),comment:e.slice(n)}}return{code:e,comment:""}}function po(e,t){for(let r of e){let{code:n}=Gr(r.line),s=n.match(/^([ \t]+)[A-Za-z_][A-Za-z0-9_]*\s*=/);if(s?.[1])return s[1]}return`${t}${oo}`}function go(e,t){let r=e.lastIndexOf(`
|
|
8
|
+
`,t)+1,n=r;for(;e[n]===" "||e[n]===" ";)n+=1;return e.slice(r,n)}function fo(e){return e.includes(`\r
|
|
11
9
|
`)?`\r
|
|
12
10
|
`:`
|
|
13
|
-
`}function
|
|
11
|
+
`}function ho(e){return e.replaceAll("\\","\\\\").replaceAll('"','\\"')}var lt,xe,oo,jr=v(()=>{"use strict";m();lt=require("buffer");C();xe=new Map;oo=" "});function ae(e,t){let r=e[t];return Array.isArray(r)?r.at(-1):r}var ft=v(()=>{"use strict";m()});function Kr(e,t){let r=(e.method??"GET").toUpperCase(),n=`${t.origin}${e.url??"/"}`,s={headers:So(e.headers),method:r};return yo.has(r)||(s.body=ht.Readable.toWeb(e),s.duplex="half"),new Request(n,s)}async function zr(e,t){t.statusCode=e.status;for(let[r,n]of e.headers)t.setHeader(r,n);if(e.body===null){t.end();return}await(0,Vr.pipeline)(ht.Readable.fromWeb(e.body),t)}function So(e){let t=new Headers;for(let[r,n]of Object.entries(e))if(typeof n=="string")t.append(r,n);else if(Array.isArray(n))for(let s of n)t.append(r,s);return t}var ht,Vr,yo,Jr=v(()=>{"use strict";m();ht=require("stream"),Vr=require("stream/promises"),yo=new Set(["GET","HEAD"])});var Zr={};re(Zr,{createHTTPServer:()=>Po,wrap:()=>O});function O(e,t){return async function(n,s,o){let a=t?Date.now():0;t&&s.once("finish",()=>{let i=Date.now()-a;console.log("[Accelerate]",`<-- ${n.method??"?"} ${n.url??""} ${s.statusCode} ${i}ms`)});try{await e(n,s,o)}catch(i){try{bo(i,s,n,t)}catch(c){t&&console.error("[Accelerate]","error while handling handler error",c),s.destroyed||s.destroy()}}}}function bo(e,t,r,n){if(t.destroyed||t.headersSent||t.writableEnded){n&&console.error("[Accelerate]",`error after response was no longer writable for ${r.method??"?"} ${r.url??""}`,e),t.destroy();return}if(e instanceof A){Cr(t,e);return}console.error("[Accelerate]",e);try{X(t,500)}catch(s){n&&console.error("[Accelerate]","failed to write 500 response (client likely disconnected)",s),t.destroy()}}function Po(e){let{router:t}=e;return{async listen(r){let n=(0,Yr.createServer)((a,i)=>{t.lookup(a,i)}),o=(await wo(n,r)).port;return n.on("error",a=>{console.error("[Accelerate]",a)}),{async close(){await(0,Xr.promisify)(n.close.bind(n))()},port:o,url:`http://localhost:${o}`}}}}function wo(e,t){return new Promise((r,n)=>{let s=a=>{if(e.off("listening",o),typeof a=="object"&&a!==null&&"code"in a&&a.code==="EADDRINUSE"){n(new N(t));return}n(a)},o=()=>{e.off("error",s),r(e.address())};e.once("error",s),e.once("listening",o),e.listen(t)})}var Yr,Xr,Ie=v(()=>{"use strict";m();Yr=require("http"),Xr=require("util");se();pe();C()});function De(e){return{traceparent:ae(e.headers,"traceparent"),"X-capture-telemetry":ae(e.headers,"x-capture-telemetry")}}var en=v(()=>{"use strict";m();ft()});async function rn(e,t){let r;try{r=await(0,tn.json)(e)}catch{return T(t,{EngineNotStarted:{reason:"InvalidRequest",issues:[]}},400),null}let{issues:n,output:s,success:o}=(0,b.safeParse)(Eo,r,{abortEarly:!0});return o?s:(T(t,{EngineNotStarted:{reason:"InvalidRequest",issues:n}},400),null)}function nn(e,t){let{output:r,success:n}=(0,b.safeParse)(vo,e);return n?r:(T(t,{EngineMalfunction:{}},500),null)}var tn,b,Eo,vo,sn=v(()=>{"use strict";m();tn=require("stream/consumers"),b=require("valibot");C();Eo=(0,b.object)({isolation_level:(0,b.optional)((0,b.string)()),max_wait:(0,b.pipe)((0,b.number)(),(0,b.integer)(),(0,b.minValue)(0)),timeout:(0,b.pipe)((0,b.number)(),(0,b.integer)(),(0,b.minValue)(0))});vo=(0,b.looseObject)({id:(0,b.union)([(0,b.string)(),(0,b.number)()])})});function on(e){let t,r,n=new Promise((a,i)=>{t=a,r=i}),s=a=>{s=o=null,r(a),e?.onRejected?.(a),e?.onFulfilled?.()},o=a=>{o=s=null,t(a),e?.onResolved?.(a),e?.onFulfilled?.()};return{isFulfilled:()=>o===s,promise:n,reject:a=>s?.(a),resolve:a=>o?.(a)}}var an=v(()=>{"use strict";m()});var St={};re(St,{Engine:()=>yt,handleEngineError:()=>xo});function xo(e,t){if(console.error(e),e instanceof ie){T(t,{EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:e.message}}}},500);return}if(e instanceof Z){x(t,e.responseBody,e.statusCode);return}X(t,500)}var un,ln,dn,mn,pn,gn,Ro,To,cn,yt,ie,Z,bt=v(()=>{"use strict";m();un=require("child_process"),ln=require("events"),dn=require("fs/promises"),mn=require("path"),pn=require("timers/promises");an();gn=require("std-env");Y();C();({PRISMA_DEV_FORCE_ENGINE_BINARY_DOWNLOAD:Ro,PRISMA_DEV_FORCE_ENGINE_BINARY_PATH:To,PRISMA_DEV_FORCE_NETWORK_DELAY_MS:cn}=gn.process.env),yt=class e{static#r=new Map;#e;#t;constructor(t){this.#e=t,this.#t=null}static async get(t){let{debug:r}=t,n=`${t.schemaHash}:${t.clientVersion}`;try{let s=e.#r.get(n);if(s)return s;let o=new e(t);return e.#r.set(n,o),r&&console.debug("[Query Engine] starting...",t),await o.start(),r&&console.debug("[Query Engine] started!"),o}finally{e.stopAll(n)}}static async stopAll(t){let n=(await Promise.allSettled(Array.from(e.#r.entries()).filter(([s])=>s!==t).map(async([s,o])=>{try{await o.stop()}finally{e.#r.delete(s)}}))).filter(s=>s.status==="rejected").map(s=>s.reason);if(n.length>0)throw new AggregateError(n,"Failed to stop engines")}async commitTransaction(t,r){return await this.#i(t,r,"commit")}async request(t,r){let{url:n}=await this.start(),s=this.#n(r),o=await fetch(n,{body:typeof t=="string"?t:JSON.stringify(t),headers:{...s,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await Z.fromResponse(o);return await o.text()}async rollbackTransaction(t,r){return await this.#i(t,r,"rollback")}async startTransaction(t,r){let{url:n}=await this.start(),s=this.#n(r),o=await fetch(`${n}/transaction/start`,{body:JSON.stringify(t),headers:{...s,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await Z.fromResponse(o);return await o.json()}async start(){if(this.#t!=null)return await this.#t;let{promise:t,reject:r,resolve:n}=on();this.#t=t;let s=To||await this.#s();this.#e.debug&&console.debug("[Query Engine] spinning up at path...",s);let{proxySignals:o}=await import("foreground-child/proxy-signals"),a=(0,un.spawn)(s,["--enable-raw-queries","--enable-telemetry-in-response","--port","0"],{env:{LOG_QUERIES:"y",PRISMA_DML:this.#e.base64Schema,QE_LOG_LEVEL:"TRACE",RUST_BACKTRACE:"1",RUST_LOG:"info"},stdio:["ignore","pipe","pipe"],windowsHide:!0});o(a),a.stderr.setEncoding("utf8"),a.stdout.setEncoding("utf8");let i=l=>{let f=l.split(`
|
|
12
|
+
`).find(E=>E.includes("Started query engine http server"));if(!f)return;a.stdout.removeListener("data",i);let{fields:d}=JSON.parse(f);if(d==null)return r(new Error(`Unexpected data during initialization, "fields" are missing: ${l}`));let{ip:p,port:y}=d;if(p==null||y==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.
|
|
13
|
+
Received data: ${l}`));n({childProcess:a,url:`http://${p}:${y}`})},c=l=>{this.#t=null,r(new ie(String(l))),a.removeListener("exit",u),a.kill()};a.once("error",c);let u=(l,f)=>{this.#t=null,r(new ie(`Query Engine exited with code ${l} and signal ${f}`))};return a.once("exit",u),a.stdout.on("data",i),this.#e.debug&&(a.stderr.on("data",console.error.bind(console,"[Query Engine]")),a.stdout.on("data",console.debug.bind(console,"[Query Engine]"))),await this.#t}async stop(){if(this.#t==null)return;let{childProcess:t}=await this.#t;t.exitCode==null&&t.signalCode==null&&(this.#t=null,t.kill(),await(0,ln.once)(t,"exit"))}async#s(){this.#e.debug&&console.debug("[Query Engine] getting engine commit hash...");let t=await this.#o();this.#e.debug&&console.debug("[Query Engine] got engine commit hash",t);let r=Kt(this.#e.clientVersion,t);this.#e.debug&&console.debug("[Query Engine] cache directory path",r),await(0,dn.mkdir)(r,{recursive:!0});let{binaryTarget:n}=this.#e.platform,s=n==="windows"?".exe":"",o=(0,mn.join)(r,`query-engine-${n}${s}`);return this.#e.debug&&console.debug("[Query Engine] binary path",o),(Ro==="1"||await z(o)===!1)&&await this.#a({commitHash:t,extension:s,engineBinaryPath:o}),o}async#o(){let t=await fetch(`https://registry.npmjs.org/@prisma/client/${this.#e.clientVersion}`);if(!t.ok)throw new Error(`Couldn't fetch package.json from npm registry, status code: ${t.status}`);let n=(await t.json()).devDependencies?.["@prisma/engines-version"];if(!n)throw new Error("Couldn't find engines version in package.json");let s=n.split(".").at(-1);if(!s)throw new Error("Couldn't find commit hash in engines version");return s}async#a(t){let{commitHash:r,extension:n,engineBinaryPath:s}=t,{binaryTarget:o}=this.#e.platform,a=`https://binaries.prisma.sh/all_commits/${r}/${o}/query-engine${n}.gz`;this.#e.debug&&console.debug("[Query Engine] 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}`);cn&&await(0,pn.setTimeout)(Number(cn)),await zt(await i.arrayBuffer(),s),this.#e.debug&&console.debug("[Query Engine] downloaded and saved at",s)}#n(t){let r={};for(let[n,s]of Object.entries(t))s!=null&&(r[n]=s);return r}async#i(t,r,n){let{url:s}=await this.#t,o=this.#n(r),a=await fetch(`${s}/transaction/${t}/${n}`,{headers:{...o,"Content-Type":"application/json"},method:"POST"});if(!a.ok)throw await Z.fromResponse(a);try{return await a.json()}catch{return{}}}};ie=class extends Error{name="EngineStartError"},Z=class e extends Error{constructor(r,n,s){super(`${r}: Query Engine response status ${n}, body: ${s}`);this.action=r;this.statusCode=n;this.responseBody=s}name="EngineHttpError";static async fromResponse(r){let n=new URL(r.url),s=await r.text();return new e(n.pathname,r.status,s)}}});var fn={};re(fn,{getQueryPlanExecutorServer:()=>Io,queryPlanExecutorVersion:()=>hn.version});async function Io(e){return Pt===void 0&&(Pt=await W.Server.create({databaseUrl:e.db.connectionString,maxResponseSize:(0,W.parseSize)("128 MiB"),queryTimeout:(0,W.parseDuration)("PT5M"),maxTransactionTimeout:(0,W.parseDuration)("PT5M"),maxTransactionWaitTime:(0,W.parseDuration)("PT5M"),perRequestLogContext:{logFormat:"text",logLevel:e.debug?"debug":"off"}})),Pt}var W,hn,Pt,yn=v(()=>{"use strict";m();W=require("@prisma/query-plan-executor"),hn=require("@prisma/query-plan-executor")});var wn={};re(wn,{registerAccelerateRoutes:()=>_o});function Ae(){return Sn??=Promise.resolve().then(()=>(bt(),St)),Sn}function Do(){return Pn??=Promise.resolve().then(()=>(yn(),fn)),Pn}async function Ao(){return bn??=import("@prisma/get-platform").then(async({default:e})=>await e.getPlatformInfo()),await bn}function _o(e,t,r){e.on("POST","/invalidate",O(async(s,o)=>{G(s,t),await Qr(s,o)!==null&&X(o,200)},r));for(let s of["/:clientVersion/:schemaHash/graphql","/:clientVersion/:schemaHash/itx/:transactionId/graphql"])e.on("POST",s,O(async(o,a,i)=>{G(o,t);try{let c=await wt(a,t,i);if(c===null)return;let u=await(0,Et.text)(o),l=i.transactionId,f=await c.request(u,{...De(o),"X-transaction-id":l});x(a,f)}catch(c){let{handleEngineError:u}=await Ae();u(c,a)}},r));for(let s of["commit","rollback"])e.on("POST",`/:clientVersion/:schemaHash/itx/:transactionId/${s}`,O(async(o,a,i)=>{G(o,t);try{let c=await wt(a,t,i);if(c===null)return;let u=i.transactionId;if(u==null){T(a,{EngineMalfunction:{}},500);return}let l=`${s}Transaction`,f=await c[l](u,De(o));T(a,f)}catch(c){let{handleEngineError:u}=await Ae();u(c,a)}},r));e.on("PUT","/:clientVersion/:schemaHash/schema",O(async(s,o,a)=>{G(s,t);let i=await(0,Et.text)(s);if(!i){x(o,"Missing schema",400);return}let c=a.schemaHash;if(c==null){x(o,"Missing schema hash",400);return}let u=xe.get(c);if(u==null){if(c!==await dt(i)){x(o,"Schema hash mismatch",400);return}let l=await Wr(i,t.db.prismaORMConnectionString,t.debug);xe.set(c,{base64Original:i,...l}),x(o,c);return}if(i!==u.base64Original){x(o,"Schema mismatch",400);return}x(o,c)},r)),e.on("POST","/:clientVersion/:schemaHash/transaction/start",O(async(s,o,a)=>{G(s,t);let i=await rn(s,o);if(i!==null)try{let c=await wt(o,t,a);if(c===null)return;let u=await c.startTransaction(i,De(s)),l=nn(u,o);if(l===null)return;let{id:f}=l,d=a.clientVersion,p=a.schemaHash;T(o,{...u,"data-proxy":{endpoint:`http://localhost:${t.port}/${d}/${p}/itx/${f}`}})}catch(c){let{handleEngineError:u}=await Ae();u(c,o)}},r));let n=[["GET","/connection-info"],["POST","/query"],["POST","/transaction/start"],["POST","/transaction/:transactionId/commit"],["POST","/transaction/:transactionId/query"],["POST","/transaction/:transactionId/rollback"]];for(let[s,o]of n)e.on(s,o,O(async(a,i)=>{G(a,t);let{getQueryPlanExecutorServer:c,queryPlanExecutorVersion:u}=await Do(),l=ae(a.headers,"prisma-engine-hash");if(l!=="0.0.0"&&l!==u)throw new A(400,`Using an HTTP connection string is not supported with Prisma Client version ${l??"<missing>"} by this version of \`prisma dev\`. Please either use a direct TCP connection string or upgrade your client to version ${u}.`);let f=await c(t),d=Kr(a,{origin:`http://localhost:${t.port}`}),p=await f.fetch(d);await zr(p,i)},r))}async function wt(e,t,r){let{Engine:n}=await Ae(),s=Fr(r,e);if(s===null)return null;let{base64Override:o,overrideHash:a}=s.schemas;return await n.get({base64Schema:o,clientVersion:process.env.PRISMA_DEV_FORCE_CLIENT_VERSION||r.clientVersion||"",debug:t.debug,platform:await Ao(),schemaHash:a})}var Et,Sn,bn,Pn,En=v(()=>{"use strict";m();Et=require("stream/consumers");$e();qr();jr();ft();pe();Jr();C();Ie();en();sn()});var vn={};re(vn,{registerUtilityRoutes:()=>Oo});function Oo(e,t,r){e.on("POST","/database/dump",O(async(n,s)=>{await t.db.dump(t.databaseDumpPath),T(s,{dumpPath:t.databaseDumpPath},201)},r)),e.on("GET","/health",O((n,s)=>{T(s,{name:t.name})},r))}var Rn=v(()=>{"use strict";m();C();Ie()});var pa={};module.exports=zn(pa);m();var Hn=require("timers/promises");m();m();$e();m();var Te=require("net"),Dr=require("path"),Ar=require("pathe/utils");Y();se();m();var Je=require("perf_hooks"),dr=require("@electric-sql/pglite");m();var nr=require("buffer"),er=500,tr=/(?:"[^"]+"|`[^`]+`|\[[^\]]+\]|\w+)/,us=new RegExp(`(?:${tr.source}\\.)*${tr.source}`),ls=new RegExp(`(?:FROM|JOIN|UPDATE|INTO|TABLE)\\s+(${us.source})`,"gi"),ds=/"([^"]+)"|`([^`]+)`|\[([^\]]+)\]|(\w+)/g,rr=/prismaQuery='([^']+)'/,ms=new Set([q(`
|
|
14
14
|
select b.oid, b.typarray
|
|
15
15
|
from pg_catalog.pg_type a
|
|
16
16
|
left join pg_catalog.pg_type b on b.oid = a.typelem
|
|
17
17
|
where a.typcategory = $1
|
|
18
18
|
group by b.oid, b.typarray
|
|
19
19
|
order by b.oid
|
|
20
|
-
`),$('GRANT "pg_write_all_data" TO "prisma_application"'),$("SELECT SUM(reads)::BIGINT AS reads, SUM(writes)::BIGINT AS writes, SUM(COALESCE(extends, $1))::BIGINT AS extends FROM pg_stat_io"),$("SELECT pg_database_size(current_database())::BIGINT, SUM(pg_total_relation_size(relid))::BIGINT AS pg_total_relation_size FROM pg_stat_user_tables"),$("SELECT COUNT(*) AS cnt FROM pg_stat_activity WHERE pid <> pg_backend_pid() and xact_start notnull")]),es=[/^BEGIN\b/i,/^COMMIT\b/i,/^ROLLBACK\b/i,/^SAVEPOINT\b/i,/^RELEASE\b/i,/^SET\b/i,/^SHOW\b/i,/^DISCARD\b/i,/^DEALLOCATE\b/i,/^CLOSE\b/i,/^CREATE EXTENSION\b/i,/^WITH state_assign\b/i];function Jt(){return{generatedAt:Date.now(),queries:[]}}function $(e){return e.replace(/\s+/g," ").trim()}function Yt(e){return rr($(e))}function Xt(e){if(!e?.action||!e.model&&/raw/i.test(e.action))return null;let t=e.payload?rr(JSON.stringify(e.payload)):"0";return`${e.model??""}.${e.action}:${t}`}function ts(e){let t=new Set;for(let r of e.matchAll(Yn)){let n=r[1];if(!n)continue;let s;for(let o of n.matchAll(Xn))s=o[1]??o[2]??o[3]??o[4];s&&!s.startsWith("pg_")&&t.add(s)}return Array.from(t)}function rs(e){return Zn.has(e)?!0:es.some(t=>t.test(e))}function Zt(e){if(rs($(e)))return null;let t=ts(e);return t.length===0&&/\bpg_\w+/i.test(e)?null:t}function We(e){if(Array.isArray(e))return e.map(We);if(e!==null&&typeof e=="object"){let t=e;return t.$type==="Param"?"<<redacted>>":Object.fromEntries(Object.entries(t).map(([r,n])=>[r,We(n)]))}return e}function er(e){let t=e.match(Vt);if(!t?.[1])return{cleanedSql:$(e),prismaQueryInfo:null};let r=e.replace(Vt,"");r=r.replace(/,\s*,/g,",").replace(/\/\*\s*,/g,"/*").replace(/,\s*\*\//g,"*/").replace(/\/\*\s*\*\//g,"").replace(/\s+/g," ").trim();let n=decodeURIComponent(t[1]),s=n.indexOf(":");if(s===-1)return{cleanedSql:r,prismaQueryInfo:{action:n,isRaw:!0}};let o=n.slice(0,s),a=n.slice(s+1),i=o.indexOf("."),c=i===-1?void 0:o.slice(0,i),u=i===-1?o:o.slice(i+1);if(!u)return{cleanedSql:r,prismaQueryInfo:null};let l;try{l=We(JSON.parse(zt.Buffer.from(a,"base64url").toString("utf8")))}catch{l=void 0}return{cleanedSql:r,prismaQueryInfo:{action:u,isRaw:!1,model:c,payload:l}}}function tr(e,t={}){let r=new Set(t.excludeApplications??[]),n=ns(t.limit),s=typeof t.since=="number"&&Number.isFinite(t.since)?t.since:null,o=new Map;for(let i of e){if(i.applicationName&&r.has(i.applicationName))continue;let c=Date.parse(i.timestamp);if(!Number.isFinite(c))continue;let u=`${i.queryId}:${i.groupKey??""}`,l=o.get(u);if(!l){o.set(u,{count:1,duration:i.durationMs,groupKey:i.groupKey,id:u,lastSeen:c,maxDurationMs:i.durationMs,minDurationMs:i.durationMs,prismaQueryInfo:i.prismaQueryInfo,query:i.query,queryId:i.queryId,reads:i.reads,rowsReturned:i.rowsReturned,tables:i.tables,totalDurationMs:i.durationMs});continue}l.count+=1,l.lastSeen=Math.max(l.lastSeen,c),l.maxDurationMs=Math.max(l.maxDurationMs??i.durationMs,i.durationMs),l.minDurationMs=Math.min(l.minDurationMs??i.durationMs,i.durationMs),l.reads+=i.reads,l.rowsReturned+=i.rowsReturned,l.totalDurationMs+=i.durationMs,l.duration=l.totalDurationMs/l.count,!l.prismaQueryInfo&&i.prismaQueryInfo&&(l.prismaQueryInfo=i.prismaQueryInfo),l.tables.length===0&&i.tables.length>0&&(l.tables=i.tables)}let a=Array.from(o.values()).filter(i=>s===null||i.lastSeen>=s).sort((i,c)=>c.lastSeen-i.lastSeen).slice(0,n).map(({totalDurationMs:i,...c})=>c);return{generatedAt:Date.now(),queries:a}}function ns(e){return typeof e=="number"&&Number.isInteger(e)&&Number.isSafeInteger(e)&&e>0?Math.min(e,jt):jt}function rr(e){let t=5381;for(let r=0;r<e.length;r++)t=(t<<5)+t+e.charCodeAt(r)&4294967295;return(t>>>0).toString(36)}var pe=new WeakMap;function sr(e){let t=pe.get(e);if(t&&!t.closed)return t.bridge;let r=ss(e),n={bridge:{close:()=>(n.closed||(n.closed=!0,n.sessions.clear(),n.subscribers.clear(),n.queryQueue.enqueue=n.originalEnqueue,n.queryQueue.clearQueueForHandler=n.originalClearQueueForHandler,pe.delete(e)),Promise.resolve()),subscribe:s=>(n.subscribers.add(s),()=>{n.subscribers.delete(s)})},closed:!1,originalClearQueueForHandler:r.clearQueueForHandler.bind(r),originalEnqueue:r.enqueue.bind(r),queryQueue:r,sessions:new Map,subscribers:new Set};return r.clearQueueForHandler=s=>{n.sessions.delete(s),n.originalClearQueueForHandler(s)},r.enqueue=async(s,o,a)=>{let i=os(n,s),c=cs(o);as(i,c);let u=is(i,c);if(!u)return await n.originalEnqueue(s,o,a);let l={commandTags:[],dataRowCount:0},h=new nr.protocol.Parser,d=Ge.performance.now(),p=await n.originalEnqueue(s,o,E=>{h.parse(E,J=>{fs(l,J)}),a(E)}),f=Math.max(0,Ge.performance.now()-d);return hs(n,{applicationName:u.applicationName,durationMs:f,query:u.query,responseStats:l}),p},pe.set(e,n),n.bridge}async function or(e){await pe.get(e)?.bridge.close()}function ss(e){let t=e.queryQueue;if(!t||typeof t.enqueue!="function"||typeof t.clearQueueForHandler!="function")throw new Error("PGLiteSocketServer query queue is unavailable for query insights capture");return t}function os(e,t){let r=e.sessions.get(t);if(r)return r;let n={applicationName:null,portals:new Map,statements:new Map};return e.sessions.set(t,n),n}function as(e,t){if(t)switch(t.kind){case"startup":e.applicationName=t.applicationName;return;case"parse":e.statements.set(t.statementName,t.query);return;case"bind":{let r=e.statements.get(t.statementName);r&&e.portals.set(t.portalName,r);return}case"close":t.target==="portal"?e.portals.delete(t.name):e.statements.delete(t.name);return;default:return}}function is(e,t){if(!t)return null;if(t.kind==="query")return{applicationName:e.applicationName,query:t.query};if(t.kind==="execute"){let r=e.portals.get(t.portalName);return r?{applicationName:e.applicationName,query:r}:null}return null}function cs(e){let t=Buffer.from(e);if(t.length<4)return null;let r=t.readInt32BE(0);if(t.length>=8&&r===t.length){let s=t.readInt32BE(4);if(s===196608||s===196608)return us(t)}if(t.length<5)return null;switch(String.fromCharCode(t[0]??0)){case"Q":return ls(t);case"P":return ds(t);case"B":return ms(t);case"E":return ps(t);case"C":return gs(t);default:return null}}function us(e){let t=8,r=null;for(;t<e.length-1;){let n=O(e,t);if(!n||n.value==="")break;t=n.nextOffset;let s=O(e,t);if(!s)break;t=s.nextOffset,n.value==="application_name"&&(r=s.value)}return{applicationName:r,kind:"startup"}}function ls(e){let t=O(e,5);return t?{kind:"query",query:t.value}:null}function ds(e){let t=O(e,5);if(!t)return null;let r=O(e,t.nextOffset);return r?{kind:"parse",query:r.value,statementName:t.value}:null}function ms(e){let t=O(e,5);if(!t)return null;let r=O(e,t.nextOffset);return r?{kind:"bind",portalName:t.value,statementName:r.value}:null}function ps(e){let t=O(e,5);return t?{kind:"execute",portalName:t.value}:null}function gs(e){if(e.length<7)return null;let t=e[5];if(t===void 0)return null;let r=O(e,6);return r?{kind:"close",name:r.value,target:t===80?"portal":"statement"}:null}function O(e,t){let r=e.indexOf(0,t);return r===-1?null:{nextOffset:r+1,value:e.toString("utf8",t,r)}}function fs(e,t){if(t.name==="dataRow"){e.dataRowCount+=1;return}t.name==="commandComplete"&&typeof t.text=="string"&&t.text.length>0&&e.commandTags.push(t.text)}function hs(e,t){let r=er(t.query),n=Zt(r.cleanedSql);if(!n)return;let s=Yt(r.cleanedSql),o={applicationName:t.applicationName,durationMs:t.durationMs,groupKey:Xt(r.prismaQueryInfo),prismaQueryInfo:r.prismaQueryInfo,query:r.cleanedSql,queryId:s,reads:0,rowsReturned:ys(t.responseStats),tables:n,timestamp:new Date().toISOString()};for(let a of e.subscribers)a([o])}function ys(e){let t=e.commandTags.reduce((r,n)=>r+bs(n),0);return Math.max(t,e.dataRowCount)}function bs(e){let t=e.trim().split(/\s+/).at(-1);return!t||!/^\d+$/.test(t)?0:Number(t)}m();var C=require("fs"),k=require("fs/promises"),ir=require("module"),cr=require("path"),M=require("url"),Ss=(0,ir.createRequire)(y),Ps=["initdb.wasm","pglite.data","pglite.wasm"],je="pglite-seed.tar.gz",ur={amcheck:"amcheck.tar.gz",bloom:"bloom.tar.gz",btree_gin:"btree_gin.tar.gz",btree_gist:"btree_gist.tar.gz",citext:"citext.tar.gz",cube:"cube.tar.gz",dict_int:"dict_int.tar.gz",dict_xsyn:"dict_xsyn.tar.gz",earthdistance:"earthdistance.tar.gz",file_fdw:"file_fdw.tar.gz",fuzzystrmatch:"fuzzystrmatch.tar.gz",hstore:"hstore.tar.gz",intarray:"intarray.tar.gz",isn:"isn.tar.gz",lo:"lo.tar.gz",ltree:"ltree.tar.gz",pageinspect:"pageinspect.tar.gz",pg_buffercache:"pg_buffercache.tar.gz",pg_freespacemap:"pg_freespacemap.tar.gz",pg_surgery:"pg_surgery.tar.gz",pg_trgm:"pg_trgm.tar.gz",pg_visibility:"pg_visibility.tar.gz",pg_walinspect:"pg_walinspect.tar.gz",seg:"seg.tar.gz",tablefunc:"tablefunc.tar.gz",tcn:"tcn.tar.gz",tsm_system_rows:"tsm_system_rows.tar.gz",tsm_system_time:"tsm_system_time.tar.gz",unaccent:"unaccent.tar.gz",uuid_ossp:"uuid-ossp.tar.gz",vector:"vector.tar.gz"},ws=[...Ps.map(e=>({fileName:e,kind:"core",name:e})),{fileName:je,kind:"core",name:je},...Object.entries(ur).map(([e,t])=>({fileName:t,kind:"extension",name:e}))],he=new Map,Es=Symbol.for("@prisma/dev/bundled-pglite-runtime-asset-sources"),ge=null;async function Ke(){await As();let e=lr();if(e)return await Ts(e),await vs(e);let t=Ds(),r=t.href,n=he.get(r);return n||(n=Rs(t),he.set(r,n)),await n}async function vs(e){let t=`bundled:${e.wasmModule.href}:${e.fsBundle.href}`,r=he.get(t);return r||(r=xs(e),he.set(t,r)),await r}async function Rs(e){let t=ye(new URL("./runtime-assets/",y)),[r,n,s]=await Promise.all([(0,k.readFile)(fe("pglite.data",e,t)),(0,k.readFile)(fe(je,e,t)),(0,k.readFile)(fe("pglite.wasm",e,t))]),o=dr();return{extensions:Object.fromEntries(Object.entries(ur).map(([a,i])=>[a,fe(i,e,t)])),fsBundle:new Blob([Uint8Array.from(r)]),loadDataDir:new Blob([Uint8Array.from(n)]),wasmModule:await o.compile(s)}}async function xs(e){let[t,r,n]=await Promise.all([He(e.fsBundle),He(e.loadDataDir),He(e.wasmModule)]),s=dr();return{extensions:e.extensions,fsBundle:new Blob([Uint8Array.from(t)]),loadDataDir:new Blob([Uint8Array.from(r)]),wasmModule:await s.compile(n)}}async function Ts(e){if(e.initdbWasm.protocol!=="file:")return;let t=new URL("initdb.wasm",ye(new URL("./",e.initdbWasm))),r=(0,M.fileURLToPath)(t);(0,C.existsSync)(r)||await(0,k.copyFile)((0,M.fileURLToPath)(e.initdbWasm),r)}function ye(e){return e instanceof URL?ar(e):ar((0,M.pathToFileURL)(e))}function ar(e){return e.href.endsWith("/")?e:new URL(`${e.href}/`)}function Is(){let e=Ss.resolve("@electric-sql/pglite");return ye((0,cr.dirname)(e))}function Ds(){let e=ye(new URL("./",y));if(_s(e))return e;if(Ns())return Is();throw new Error("Unable to locate PGlite runtime assets. If you bundled @prisma/dev, copy them next to the bundle with copyPrismaDevRuntimeAssets().")}function _s(e){return ws.every(t=>(0,C.existsSync)((0,M.fileURLToPath)(new URL(t.fileName,e))))}function lr(){return globalThis[Es]??null}async function As(){!Os()||lr()||(ge||(ge=import("./runtime-assets-manifest.bun.js").then(()=>{}).catch(e=>{throw ge=null,e})),await ge)}function Ns(){let e=(0,M.fileURLToPath)(new URL("../package.json",y));if(!(0,C.existsSync)(e))return!1;try{return JSON.parse((0,C.readFileSync)(e,"utf8")).name==="@prisma/dev"}catch{return!1}}function Os(){return typeof globalThis.Bun<"u"}function dr(){let e=globalThis.WebAssembly;if(!e)throw new Error("WebAssembly is not available in this runtime.");return e}async function He(e){if(e.protocol==="file:")return await(0,k.readFile)(e);let t=await fetch(e);if(!t.ok)throw new Error(`Failed to fetch runtime asset ${e.href}: ${t.status} ${t.statusText}`);return new Uint8Array(await t.arrayBuffer())}function fe(e,t,r){let n=new URL(e,t);if((0,C.existsSync)((0,M.fileURLToPath)(n)))return n;if(r){let s=new URL(e,r);if((0,C.existsSync)((0,M.fileURLToPath)(s)))return s}return n}m();var Je=require("@electric-sql/pglite"),_="_prisma_dev_wal",ze="events",gr="install_all_triggers",mr="capture_event",pr="prisma_dev_wal_capture",X=new WeakMap,Ms=new Set(["ALTER","COMMIT","COPY","CREATE","DELETE","DROP","INSERT","MERGE","TRUNCATE","UPDATE"]);async function Ye(e,t){let r=X.get(e);if(r&&!r.closed)return r.bridge;let n=e.execProtocolRaw.bind(e),s=e.execProtocolRawStream.bind(e),o={bridge:{close:async()=>{o.closed||(o.closed=!0,o.subscribers.clear(),e.execProtocolRaw===a&&(e.execProtocolRaw=n),e.execProtocolRawStream===i&&(e.execProtocolRawStream=s),await o.pollPromise,X.delete(e))},poll:async()=>{await Ve(o,e)},subscribe:c=>(o.subscribers.add(c),()=>{o.subscribers.delete(c)})},closed:!1,ensureInfrastructurePromise:null,pendingPoll:!1,pollPromise:null,subscribers:new Set,suppressDepth:0},a=async(c,u)=>{let l=await n(c,u);return!o.closed&&o.suppressDepth===0&&hr(l)&&Ve(o,e),l},i=async(c,u)=>{let l=[],h=new Je.protocol.Parser,d=u?.onRawData;await s(c,{...u,onRawData:p=>{h.parse(p,f=>{l.push(f)}),d?.(p)}}),!o.closed&&o.suppressDepth===0&&Xe(l)&&Ve(o,e)};return e.execProtocolRaw=a,e.execProtocolRawStream=i,X.set(e,o),await yr(o,e),o.bridge}async function fr(e){let t=X.get(e);t&&await t.bridge.close()}function Xe(e){for(let t of e){if(t.name!=="commandComplete"||typeof t.text!="string")continue;let r=t.text.split(/\s+/,1)[0]?.toUpperCase();if(r&&Ms.has(r))return!0}return!1}function hr(e){if(e.length===0)return!1;let t=[];return new Je.protocol.Parser().parse(e,n=>{t.push(n)}),Xe(t)}async function yr(e,t){e.ensureInfrastructurePromise??=Ze(e,t,async()=>{await t.exec(`CREATE SCHEMA IF NOT EXISTS "${_}"`),await t.exec(`
|
|
21
|
-
CREATE TABLE IF NOT EXISTS "${
|
|
20
|
+
`),q('GRANT "pg_write_all_data" TO "prisma_application"'),q("SELECT SUM(reads)::BIGINT AS reads, SUM(writes)::BIGINT AS writes, SUM(COALESCE(extends, $1))::BIGINT AS extends FROM pg_stat_io"),q("SELECT pg_database_size(current_database())::BIGINT, SUM(pg_total_relation_size(relid))::BIGINT AS pg_total_relation_size FROM pg_stat_user_tables"),q("SELECT COUNT(*) AS cnt FROM pg_stat_activity WHERE pid <> pg_backend_pid() and xact_start notnull")]),ps=[/^BEGIN\b/i,/^COMMIT\b/i,/^ROLLBACK\b/i,/^SAVEPOINT\b/i,/^RELEASE\b/i,/^SET\b/i,/^SHOW\b/i,/^DISCARD\b/i,/^DEALLOCATE\b/i,/^CLOSE\b/i,/^CREATE EXTENSION\b/i,/^WITH state_assign\b/i];function sr(){return{generatedAt:Date.now(),queries:[]}}function q(e){return e.replace(/\s+/g," ").trim()}function or(e){return lr(q(e))}function ar(e){if(!e?.action||!e.model&&/raw/i.test(e.action))return null;let t=e.payload?lr(JSON.stringify(e.payload)):"0";return`${e.model??""}.${e.action}:${t}`}function gs(e){let t=new Set;for(let r of e.matchAll(ls)){let n=r[1];if(!n)continue;let s;for(let o of n.matchAll(ds))s=o[1]??o[2]??o[3]??o[4];s&&!s.startsWith("pg_")&&t.add(s)}return Array.from(t)}function fs(e){return ms.has(e)?!0:ps.some(t=>t.test(e))}function ir(e){if(fs(q(e)))return null;let t=gs(e);return t.length===0&&/\bpg_\w+/i.test(e)?null:t}function ze(e){if(Array.isArray(e))return e.map(ze);if(e!==null&&typeof e=="object"){let t=e;return t.$type==="Param"?"<<redacted>>":Object.fromEntries(Object.entries(t).map(([r,n])=>[r,ze(n)]))}return e}function cr(e){let t=e.match(rr);if(!t?.[1])return{cleanedSql:q(e),prismaQueryInfo:null};let r=e.replace(rr,"");r=r.replace(/,\s*,/g,",").replace(/\/\*\s*,/g,"/*").replace(/,\s*\*\//g,"*/").replace(/\/\*\s*\*\//g,"").replace(/\s+/g," ").trim();let n=decodeURIComponent(t[1]),s=n.indexOf(":");if(s===-1)return{cleanedSql:r,prismaQueryInfo:{action:n,isRaw:!0}};let o=n.slice(0,s),a=n.slice(s+1),i=o.indexOf("."),c=i===-1?void 0:o.slice(0,i),u=i===-1?o:o.slice(i+1);if(!u)return{cleanedSql:r,prismaQueryInfo:null};let l;try{l=ze(JSON.parse(nr.Buffer.from(a,"base64url").toString("utf8")))}catch{l=void 0}return{cleanedSql:r,prismaQueryInfo:{action:u,isRaw:!1,model:c,payload:l}}}function ur(e,t={}){let r=new Set(t.excludeApplications??[]),n=hs(t.limit),s=typeof t.since=="number"&&Number.isFinite(t.since)?t.since:null,o=new Map;for(let i of e){if(i.applicationName&&r.has(i.applicationName))continue;let c=Date.parse(i.timestamp);if(!Number.isFinite(c))continue;let u=`${i.queryId}:${i.groupKey??""}`,l=o.get(u);if(!l){o.set(u,{count:1,duration:i.durationMs,groupKey:i.groupKey,id:u,lastSeen:c,maxDurationMs:i.durationMs,minDurationMs:i.durationMs,prismaQueryInfo:i.prismaQueryInfo,query:i.query,queryId:i.queryId,reads:i.reads,rowsReturned:i.rowsReturned,tables:i.tables,totalDurationMs:i.durationMs});continue}l.count+=1,l.lastSeen=Math.max(l.lastSeen,c),l.maxDurationMs=Math.max(l.maxDurationMs??i.durationMs,i.durationMs),l.minDurationMs=Math.min(l.minDurationMs??i.durationMs,i.durationMs),l.reads+=i.reads,l.rowsReturned+=i.rowsReturned,l.totalDurationMs+=i.durationMs,l.duration=l.totalDurationMs/l.count,!l.prismaQueryInfo&&i.prismaQueryInfo&&(l.prismaQueryInfo=i.prismaQueryInfo),l.tables.length===0&&i.tables.length>0&&(l.tables=i.tables)}let a=Array.from(o.values()).filter(i=>s===null||i.lastSeen>=s).sort((i,c)=>c.lastSeen-i.lastSeen).slice(0,n).map(({totalDurationMs:i,...c})=>c);return{generatedAt:Date.now(),queries:a}}function hs(e){return typeof e=="number"&&Number.isInteger(e)&&Number.isSafeInteger(e)&&e>0?Math.min(e,er):er}function lr(e){let t=5381;for(let r=0;r<e.length;r++)t=(t<<5)+t+e.charCodeAt(r)&4294967295;return(t>>>0).toString(36)}var be=new WeakMap;function mr(e){let t=be.get(e);if(t&&!t.closed)return t.bridge;let r=ys(e),n={bridge:{close:()=>(n.closed||(n.closed=!0,n.sessions.clear(),n.subscribers.clear(),n.queryQueue.enqueue=n.originalEnqueue,n.queryQueue.clearQueueForHandler=n.originalClearQueueForHandler,be.delete(e)),Promise.resolve()),subscribe:s=>(n.subscribers.add(s),()=>{n.subscribers.delete(s)})},closed:!1,originalClearQueueForHandler:r.clearQueueForHandler.bind(r),originalEnqueue:r.enqueue.bind(r),queryQueue:r,sessions:new Map,subscribers:new Set};return r.clearQueueForHandler=s=>{n.sessions.delete(s),n.originalClearQueueForHandler(s)},r.enqueue=async(s,o,a)=>{let i=Ss(n,s),c=ws(o);bs(i,c);let u=Ps(i,c);if(!u)return await n.originalEnqueue(s,o,a);let l={commandTags:[],dataRowCount:0},f=new dr.protocol.Parser,d=Je.performance.now(),p=await n.originalEnqueue(s,o,E=>{f.parse(E,te=>{Ds(l,te)}),a(E)}),y=Math.max(0,Je.performance.now()-d);return As(n,{applicationName:u.applicationName,durationMs:y,query:u.query,responseStats:l}),p},be.set(e,n),n.bridge}async function pr(e){await be.get(e)?.bridge.close()}function ys(e){let t=e.queryQueue;if(!t||typeof t.enqueue!="function"||typeof t.clearQueueForHandler!="function")throw new Error("PGLiteSocketServer query queue is unavailable for query insights capture");return t}function Ss(e,t){let r=e.sessions.get(t);if(r)return r;let n={applicationName:null,portals:new Map,statements:new Map};return e.sessions.set(t,n),n}function bs(e,t){if(t)switch(t.kind){case"startup":e.applicationName=t.applicationName;return;case"parse":e.statements.set(t.statementName,t.query);return;case"bind":{let r=e.statements.get(t.statementName);r&&e.portals.set(t.portalName,r);return}case"close":t.target==="portal"?e.portals.delete(t.name):e.statements.delete(t.name);return;default:return}}function Ps(e,t){if(!t)return null;if(t.kind==="query")return{applicationName:e.applicationName,query:t.query};if(t.kind==="execute"){let r=e.portals.get(t.portalName);return r?{applicationName:e.applicationName,query:r}:null}return null}function ws(e){let t=Buffer.from(e);if(t.length<4)return null;let r=t.readInt32BE(0);if(t.length>=8&&r===t.length){let s=t.readInt32BE(4);if(s===196608||s===196608)return Es(t)}if(t.length<5)return null;switch(String.fromCharCode(t[0]??0)){case"Q":return vs(t);case"P":return Rs(t);case"B":return Ts(t);case"E":return xs(t);case"C":return Is(t);default:return null}}function Es(e){let t=8,r=null;for(;t<e.length-1;){let n=$(e,t);if(!n||n.value==="")break;t=n.nextOffset;let s=$(e,t);if(!s)break;t=s.nextOffset,n.value==="application_name"&&(r=s.value)}return{applicationName:r,kind:"startup"}}function vs(e){let t=$(e,5);return t?{kind:"query",query:t.value}:null}function Rs(e){let t=$(e,5);if(!t)return null;let r=$(e,t.nextOffset);return r?{kind:"parse",query:r.value,statementName:t.value}:null}function Ts(e){let t=$(e,5);if(!t)return null;let r=$(e,t.nextOffset);return r?{kind:"bind",portalName:t.value,statementName:r.value}:null}function xs(e){let t=$(e,5);return t?{kind:"execute",portalName:t.value}:null}function Is(e){if(e.length<7)return null;let t=e[5];if(t===void 0)return null;let r=$(e,6);return r?{kind:"close",name:r.value,target:t===80?"portal":"statement"}:null}function $(e,t){let r=e.indexOf(0,t);return r===-1?null:{nextOffset:r+1,value:e.toString("utf8",t,r)}}function Ds(e,t){if(t.name==="dataRow"){e.dataRowCount+=1;return}t.name==="commandComplete"&&typeof t.text=="string"&&t.text.length>0&&e.commandTags.push(t.text)}function As(e,t){let r=cr(t.query),n=ir(r.cleanedSql);if(!n)return;let s=or(r.cleanedSql),o={applicationName:t.applicationName,durationMs:t.durationMs,groupKey:ar(r.prismaQueryInfo),prismaQueryInfo:r.prismaQueryInfo,query:r.cleanedSql,queryId:s,reads:0,rowsReturned:_s(t.responseStats),tables:n,timestamp:new Date().toISOString()};for(let a of e.subscribers)a([o])}function _s(e){let t=e.commandTags.reduce((r,n)=>r+Os(n),0);return Math.max(t,e.dataRowCount)}function Os(e){let t=e.trim().split(/\s+/).at(-1);return!t||!/^\d+$/.test(t)?0:Number(t)}m();var F=require("fs"),H=require("fs/promises"),fr=require("module"),hr=require("path"),k=require("url"),Ns=(0,fr.createRequire)(h),Ms=["initdb.wasm","pglite.data","pglite.wasm"],Xe="pglite-seed.tar.gz",yr={amcheck:"amcheck.tar.gz",bloom:"bloom.tar.gz",btree_gin:"btree_gin.tar.gz",btree_gist:"btree_gist.tar.gz",citext:"citext.tar.gz",cube:"cube.tar.gz",dict_int:"dict_int.tar.gz",dict_xsyn:"dict_xsyn.tar.gz",earthdistance:"earthdistance.tar.gz",file_fdw:"file_fdw.tar.gz",fuzzystrmatch:"fuzzystrmatch.tar.gz",hstore:"hstore.tar.gz",intarray:"intarray.tar.gz",isn:"isn.tar.gz",lo:"lo.tar.gz",ltree:"ltree.tar.gz",pageinspect:"pageinspect.tar.gz",pg_buffercache:"pg_buffercache.tar.gz",pg_freespacemap:"pg_freespacemap.tar.gz",pg_surgery:"pg_surgery.tar.gz",pg_trgm:"pg_trgm.tar.gz",pg_visibility:"pg_visibility.tar.gz",pg_walinspect:"pg_walinspect.tar.gz",seg:"seg.tar.gz",tablefunc:"tablefunc.tar.gz",tcn:"tcn.tar.gz",tsm_system_rows:"tsm_system_rows.tar.gz",tsm_system_time:"tsm_system_time.tar.gz",unaccent:"unaccent.tar.gz",uuid_ossp:"uuid-ossp.tar.gz",vector:"vector.tar.gz"},Bs=[...Ms.map(e=>({fileName:e,kind:"core",name:e})),{fileName:Xe,kind:"core",name:Xe},...Object.entries(yr).map(([e,t])=>({fileName:t,kind:"extension",name:e}))],Ee=new Map,Ls=Symbol.for("@prisma/dev/bundled-pglite-runtime-asset-sources"),Pe=null;async function Ze(){await Fs();let e=Sr();if(e)return await Us(e),await $s(e);let t=qs(),r=t.href,n=Ee.get(r);return n||(n=ks(t),Ee.set(r,n)),await n}async function $s(e){let t=`bundled:${e.wasmModule.href}:${e.fsBundle.href}`,r=Ee.get(t);return r||(r=Cs(e),Ee.set(t,r)),await r}async function ks(e){let t=ve(new URL("./runtime-assets/",h)),[r,n,s]=await Promise.all([(0,H.readFile)(we("pglite.data",e,t)),(0,H.readFile)(we(Xe,e,t)),(0,H.readFile)(we("pglite.wasm",e,t))]),o=br();return{extensions:Object.fromEntries(Object.entries(yr).map(([a,i])=>[a,we(i,e,t)])),fsBundle:new Blob([Uint8Array.from(r)]),loadDataDir:new Blob([Uint8Array.from(n)]),wasmModule:await o.compile(s)}}async function Cs(e){let[t,r,n]=await Promise.all([Ye(e.fsBundle),Ye(e.loadDataDir),Ye(e.wasmModule)]),s=br();return{extensions:e.extensions,fsBundle:new Blob([Uint8Array.from(t)]),loadDataDir:new Blob([Uint8Array.from(r)]),wasmModule:await s.compile(n)}}async function Us(e){if(e.initdbWasm.protocol!=="file:")return;let t=new URL("initdb.wasm",ve(new URL("./",e.initdbWasm))),r=(0,k.fileURLToPath)(t);(0,F.existsSync)(r)||await(0,H.copyFile)((0,k.fileURLToPath)(e.initdbWasm),r)}function ve(e){return e instanceof URL?gr(e):gr((0,k.pathToFileURL)(e))}function gr(e){return e.href.endsWith("/")?e:new URL(`${e.href}/`)}function Qs(){let e=Ns.resolve("@electric-sql/pglite");return ve((0,hr.dirname)(e))}function qs(){let e=ve(new URL("./",h));if(Hs(e))return e;if(Ws())return Qs();throw new Error("Unable to locate PGlite runtime assets. If you bundled @prisma/dev, copy them next to the bundle with copyPrismaDevRuntimeAssets().")}function Hs(e){return Bs.every(t=>(0,F.existsSync)((0,k.fileURLToPath)(new URL(t.fileName,e))))}function Sr(){return globalThis[Ls]??null}async function Fs(){!Gs()||Sr()||(Pe||(Pe=import("./runtime-assets-manifest.bun.js").then(()=>{}).catch(e=>{throw Pe=null,e})),await Pe)}function Ws(){let e=(0,k.fileURLToPath)(new URL("../package.json",h));if(!(0,F.existsSync)(e))return!1;try{return JSON.parse((0,F.readFileSync)(e,"utf8")).name==="@prisma/dev"}catch{return!1}}function Gs(){return typeof globalThis.Bun<"u"}function br(){let e=globalThis.WebAssembly;if(!e)throw new Error("WebAssembly is not available in this runtime.");return e}async function Ye(e){if(e.protocol==="file:")return await(0,H.readFile)(e);let t=await fetch(e);if(!t.ok)throw new Error(`Failed to fetch runtime asset ${e.href}: ${t.status} ${t.statusText}`);return new Uint8Array(await t.arrayBuffer())}function we(e,t,r){let n=new URL(e,t);if((0,F.existsSync)((0,k.fileURLToPath)(n)))return n;if(r){let s=new URL(e,r);if((0,F.existsSync)((0,k.fileURLToPath)(s)))return s}return n}m();var rt=require("@electric-sql/pglite"),M="_prisma_dev_wal",tt="events",Er="install_all_triggers",Pr="capture_event",wr="prisma_dev_wal_capture",oe=new WeakMap,js=new Set(["ALTER","COMMIT","COPY","CREATE","DELETE","DROP","INSERT","MERGE","TRUNCATE","UPDATE"]);async function nt(e,t){let r=oe.get(e);if(r&&!r.closed)return r.bridge;let n=e.execProtocolRaw.bind(e),s=e.execProtocolRawStream.bind(e),o={bridge:{close:async()=>{o.closed||(o.closed=!0,o.subscribers.clear(),e.execProtocolRaw===a&&(e.execProtocolRaw=n),e.execProtocolRawStream===i&&(e.execProtocolRawStream=s),await o.pollPromise,oe.delete(e))},poll:async()=>{await et(o,e)},subscribe:c=>(o.subscribers.add(c),()=>{o.subscribers.delete(c)})},closed:!1,ensureInfrastructurePromise:null,pendingPoll:!1,pollPromise:null,subscribers:new Set,suppressDepth:0},a=async(c,u)=>{let l=await n(c,u);return!o.closed&&o.suppressDepth===0&&Rr(l)&&et(o,e),l},i=async(c,u)=>{let l=[],f=new rt.protocol.Parser,d=u?.onRawData;await s(c,{...u,onRawData:p=>{f.parse(p,y=>{l.push(y)}),d?.(p)}}),!o.closed&&o.suppressDepth===0&&st(l)&&et(o,e)};return e.execProtocolRaw=a,e.execProtocolRawStream=i,oe.set(e,o),await Tr(o,e),o.bridge}async function vr(e){let t=oe.get(e);t&&await t.bridge.close()}function st(e){for(let t of e){if(t.name!=="commandComplete"||typeof t.text!="string")continue;let r=t.text.split(/\s+/,1)[0]?.toUpperCase();if(r&&js.has(r))return!0}return!1}function Rr(e){if(e.length===0)return!1;let t=[];return new rt.protocol.Parser().parse(e,n=>{t.push(n)}),st(t)}async function Tr(e,t){e.ensureInfrastructurePromise??=ot(e,t,async()=>{await t.exec(`CREATE SCHEMA IF NOT EXISTS "${M}"`),await t.exec(`
|
|
21
|
+
CREATE TABLE IF NOT EXISTS "${M}"."${tt}" (
|
|
22
22
|
id BIGSERIAL PRIMARY KEY,
|
|
23
23
|
txid BIGINT NOT NULL DEFAULT txid_current(),
|
|
24
24
|
schema_name TEXT NOT NULL,
|
|
@@ -29,16 +29,16 @@ Received data: ${l}`));n({childProcess:a,url:`http://${p}:${f}`})},c=l=>{this.#t
|
|
|
29
29
|
created_at TIMESTAMPTZ NOT NULL DEFAULT clock_timestamp()
|
|
30
30
|
)
|
|
31
31
|
`),await t.exec(`
|
|
32
|
-
CREATE OR REPLACE FUNCTION "${
|
|
32
|
+
CREATE OR REPLACE FUNCTION "${M}"."${Pr}"()
|
|
33
33
|
RETURNS trigger
|
|
34
34
|
LANGUAGE plpgsql
|
|
35
35
|
AS $$
|
|
36
36
|
BEGIN
|
|
37
|
-
IF TG_TABLE_SCHEMA = '${
|
|
37
|
+
IF TG_TABLE_SCHEMA = '${M}' THEN
|
|
38
38
|
RETURN COALESCE(NEW, OLD);
|
|
39
39
|
END IF;
|
|
40
40
|
|
|
41
|
-
INSERT INTO "${
|
|
41
|
+
INSERT INTO "${M}"."${tt}" (
|
|
42
42
|
txid,
|
|
43
43
|
schema_name,
|
|
44
44
|
table_name,
|
|
@@ -59,7 +59,7 @@ Received data: ${l}`));n({childProcess:a,url:`http://${p}:${f}`})},c=l=>{this.#t
|
|
|
59
59
|
END;
|
|
60
60
|
$$;
|
|
61
61
|
`),await t.exec(`
|
|
62
|
-
CREATE OR REPLACE FUNCTION "${
|
|
62
|
+
CREATE OR REPLACE FUNCTION "${M}"."${Er}"()
|
|
63
63
|
RETURNS void
|
|
64
64
|
LANGUAGE plpgsql
|
|
65
65
|
AS $$
|
|
@@ -71,7 +71,7 @@ Received data: ${l}`));n({childProcess:a,url:`http://${p}:${f}`})},c=l=>{this.#t
|
|
|
71
71
|
FROM pg_class AS c
|
|
72
72
|
JOIN pg_namespace AS n ON n.oid = c.relnamespace
|
|
73
73
|
WHERE c.relkind IN ('r', 'p')
|
|
74
|
-
AND n.nspname NOT IN ('${
|
|
74
|
+
AND n.nspname NOT IN ('${M}', 'information_schema', 'pg_catalog')
|
|
75
75
|
AND n.nspname NOT LIKE 'pg_temp_%'
|
|
76
76
|
AND n.nspname NOT LIKE 'pg_toast%'
|
|
77
77
|
LOOP
|
|
@@ -79,28 +79,28 @@ Received data: ${l}`));n({childProcess:a,url:`http://${p}:${f}`})},c=l=>{this.#t
|
|
|
79
79
|
SELECT 1
|
|
80
80
|
FROM pg_trigger
|
|
81
81
|
WHERE tgrelid = target
|
|
82
|
-
AND tgname = '${
|
|
82
|
+
AND tgname = '${wr}'
|
|
83
83
|
) THEN
|
|
84
84
|
CONTINUE;
|
|
85
85
|
END IF;
|
|
86
86
|
|
|
87
87
|
EXECUTE format(
|
|
88
|
-
'CREATE TRIGGER %I AFTER INSERT OR UPDATE OR DELETE ON %s FOR EACH ROW EXECUTE FUNCTION "${
|
|
89
|
-
'${
|
|
88
|
+
'CREATE TRIGGER %I AFTER INSERT OR UPDATE OR DELETE ON %s FOR EACH ROW EXECUTE FUNCTION "${M}"."${Pr}"()',
|
|
89
|
+
'${wr}',
|
|
90
90
|
target::text
|
|
91
91
|
);
|
|
92
92
|
END LOOP;
|
|
93
93
|
END;
|
|
94
94
|
$$;
|
|
95
|
-
`),await
|
|
95
|
+
`),await xr(e,t)}),await e.ensureInfrastructurePromise}async function xr(e,t){await ot(e,t,async()=>{await t.query(`SELECT "${M}"."${Er}"()`)})}async function Vs(e,t){await Tr(e,t),await xr(e,t);let r=await ot(e,t,async()=>await t.query(`
|
|
96
96
|
WITH drained AS (
|
|
97
|
-
DELETE FROM "${
|
|
97
|
+
DELETE FROM "${M}"."${tt}"
|
|
98
98
|
RETURNING txid, schema_name, table_name, op, row_data, old_row_data, id
|
|
99
99
|
)
|
|
100
100
|
SELECT txid, schema_name, table_name, op, row_data, old_row_data
|
|
101
101
|
FROM drained
|
|
102
102
|
ORDER BY id
|
|
103
|
-
`));if(r.rows.length===0||e.subscribers.size===0)return;let n=r.rows.map(
|
|
103
|
+
`));if(r.rows.length===0||e.subscribers.size===0)return;let n=r.rows.map(Ks);for(let s of e.subscribers)queueMicrotask(()=>{if(!e.closed&&e.subscribers.has(s))try{s(n)}catch(o){console.error("[WAL bridge] subscriber failed",o)}})}async function et(e,t){if(!e.closed){if(e.pollPromise){e.pendingPoll=!0,await e.pollPromise;return}e.pollPromise=(async()=>{do e.pendingPoll=!1,await Vs(e,t);while(e.pendingPoll&&!e.closed)})().finally(()=>{e.pollPromise=null}),await e.pollPromise}}async function ot(e,t,r){e.suppressDepth+=1;try{return await r()}finally{e.suppressDepth-=1,e.suppressDepth===0&&!e.closed&&oe.get(t)!==e&&(e.closed=!0)}}function Ks(e){return{oldRecord:e.old_row_data,record:e.row_data,schema:e.schema_name,table:e.table_name,txid:String(e.txid),type:zs(e.op)}}function zs(e){switch(e.toLowerCase()){case"delete":return"delete";case"insert":return"insert";case"update":return"update";default:throw new Error(`Unsupported WAL bridge operation: ${e}`)}}var Js=10,_r="127.0.0.1",Or=128*1024*1024,Nr=["-c","shared_buffers=16MB","-c","temp_buffers=1MB","-c","work_mem=1MB","-c","maintenance_work_mem=16MB","-c","wal_buffers=1MB"],S={connectionLimit:Js,connectTimeout:0,database:"template1",maxIdleConnectionLifetime:0,password:"postgres",poolTimeout:0,socketTimeout:0,sslMode:"disable",username:"postgres"},Ys=`postgres://${S.username}:${S.password}@localhost`,at=new URLSearchParams({sslmode:S.sslMode}),Mr=new URLSearchParams({...Object.fromEntries(at.entries()),connection_limit:String(S.connectionLimit),connect_timeout:String(S.connectTimeout),max_idle_connection_lifetime:String(S.maxIdleConnectionLifetime),pool_timeout:String(S.poolTimeout),socket_timeout:String(S.socketTimeout)});async function Br(e){let{rows:t}=await e.query("SELECT EXISTS(SELECT 1 FROM pg_roles WHERE rolname = 'postgres') AS exists");t[0]?.exists?await e.exec(`ALTER ROLE ${S.username} WITH LOGIN SUPERUSER PASSWORD '${S.password}'`):await e.exec(`CREATE ROLE ${S.username} WITH LOGIN SUPERUSER PASSWORD '${S.password}'`),await e.exec(`SET ROLE ${S.username}`)}async function it(e,t){if(e==="shadow_database"&&!t.dryRun)return await Xs(t);let r=e==="database"?t.databasePort:t.shadowDatabasePort;return t.dryRun?$r(e,t,{db:null,port:r,server:null}):await Lr(e,t,{port:r,updateServerStatePort:!0})}async function Xs(e,t=async()=>await Lr("shadow_database",e,{port:0,updateServerStatePort:!1})){let{debug:r}=e,n=null,s=null,o=!1,a=new Set,i=(0,Te.createServer)(u),c=await Zs(i,e.shadowDatabasePort);return e.shadowDatabasePort=c,r&&console.debug(`[shadow_database] lazy proxy listening on port ${c}`),{...S,attachWalEventBridge:()=>Promise.reject(new Error("WAL bridge is only available for the primary database server")),attachQueryInsightsBridge:()=>Promise.reject(new Error("Query insights are only available for the primary database server")),close:async()=>{o=!0;for(let p of a)p.destroy();a.clear();let d=[];try{await eo(i),r&&console.debug(`[shadow_database] lazy proxy stopped on port ${c}`)}catch(p){console.error("[shadow_database] lazy proxy stop error",p),d.push(p)}try{await s?.catch(()=>null),await n?.close()}catch(p){console.error("[shadow_database] backend close error",p),d.push(p)}if(d.length>0)throw new AggregateError(d,"Failed to close shadow_database properly")},connectionString:Re(c,at),dump:async()=>{},getPrimaryKeyColumns:()=>Promise.reject(new Error("Primary key resolution is only available for the primary database server")),port:c,prismaORMConnectionString:Re(c,Mr),terminalCommand:`PGPASSWORD=${S.password} PGSSLMODE=${S.sslMode} psql -h localhost -p ${c} -U ${S.username} -d ${S.database}`};function u(d){a.add(d);let p=()=>{a.delete(d)};d.once("close",p),d.once("error",p),d.pause(),l(d)}async function l(d){try{let p=await f();if(o){d.destroy();return}let y=(0,Te.createConnection)({host:_r,port:p.port});a.add(y);let E=()=>{a.delete(y)};y.once("close",E),y.once("error",E),d.once("close",()=>y.destroy()),d.once("error",()=>y.destroy()),y.once("error",()=>d.destroy()),y.once("connect",()=>{r&&console.debug(`[shadow_database] proxying connection to lazy backend on port ${p.port}`),d.resume(),d.pipe(y),y.pipe(d)})}catch(p){r&&console.error("[shadow_database] failed to start lazy backend",p),d.destroy(p instanceof Error?p:void 0)}}async function f(){if(n)return n;if(o)throw new Error("shadow_database is closed");return s||(r&&console.debug("[shadow_database] starting lazy backend..."),s=t().then(d=>(n=d,r&&console.debug(`[shadow_database] lazy backend started on port ${d.port}`),d)).catch(d=>{throw s=null,d})),await s}}async function Lr(e,t,r){let{debug:n}=t,{port:s,updateServerStatePort:o}=r,i=await(e==="shadow_database"?to:kr)(t.pgliteDataDirPath,n);n&&i.onNotification((d,p)=>{console.debug(`[${e}][${d}] ${p}`)});let{PGLiteSocketServer:c}=await import("@electric-sql/pglite-socket"),u=e==="shadow_database"?t.shadowDatabaseIdleTimeoutMillis:t.databaseIdleTimeoutMillis,l=new c({db:i,debug:n,idleTimeout:Number.isFinite(u)?u:0,inspect:n,maxConnections:S.connectionLimit,port:s});n&&(l.addEventListener("listening",d=>{let{detail:p}=d;console.debug(`[${e}] server listening on ${JSON.stringify(p)}`)}),l.addEventListener("connection",d=>{let{clientAddress:p,clientPort:y}=d.detail;console.debug(`[${e}] client connected from ${p}:${y}`)}),l.addEventListener("error",d=>{let{detail:p}=d;console.error(`[${e}] server error:`,p)}));try{await l.start()}catch(d){throw d instanceof Error&&"code"in d&&d.code==="EADDRINUSE"?new N(s):d}let f=Number(l.getServerConn().split(":").at(1));return o&&(t[e==="database"?"databasePort":"shadowDatabasePort"]=f),$r(e,t,{db:i,port:f,server:l})}function $r(e,t,r){let{debug:n}=t,{db:s,port:o,server:a}=r||{},i=new Map;return n&&console.debug(`[${e}] server started on port ${o}`),{...S,attachWalEventBridge:async()=>{if(e!=="database"||!s)throw new Error("WAL bridge is only available for the primary database server");return await nt(s)},attachQueryInsightsBridge:()=>{if(e!=="database"||!a)throw new Error("Query insights are only available for the primary database server");return Promise.resolve(mr(a))},close:async()=>{let c=[];try{await a?.stop(),n&&console.debug(`[${e}] server stopped on port ${o}`)}catch(u){console.error(`[${e}] server stop error`,u),c.push(u)}if(e==="database"){try{a&&await pr(a),n&&console.debug(`[${e}] closed query insights bridge`)}catch(u){console.error(`[${e}] query insights bridge close error`,u),c.push(u)}try{s&&await vr(s),n&&console.debug(`[${e}] closed WAL bridge`)}catch(u){console.error(`[${e}] WAL bridge close error`,u),c.push(u)}try{await s?.syncToFs(),n&&console.debug(`[${e}] synced to filesystem`)}catch(u){console.error(`[${e}] sync error`,u),c.push(u)}}try{await s?.close(),n&&console.debug(`[${e}] closed`)}catch(u){console.error(`[${e}] close error`,u),c.push(u)}if(c.length>0)throw new AggregateError(c,`Failed to close ${e} properly`)},connectionString:Re(o,at),dump:async c=>{e==="shadow_database"||!s||await no({db:s,debug:n,destinationPath:c})},getPrimaryKeyColumns:async(c,u)=>{if(e==="shadow_database"||!s)throw new Error("Primary key resolution is only available for the primary database server");let l=`${c}.${u}`,f=i.get(l);return f||(f=ro(s,c,u).catch(d=>{throw i.delete(l),d}),i.set(l,f)),await f},port:o,prismaORMConnectionString:Re(o,Mr),terminalCommand:`PGPASSWORD=${S.password} PGSSLMODE=${S.sslMode} psql -h localhost -p ${o} -U ${S.username} -d ${S.database}`}}function Re(e,t){return`${Ys}:${e}/${S.database}?${t.toString()}`}async function kr(e,t){let{PGlite:r}=await import("@electric-sql/pglite"),n=await Ze(),s=e==="memory://"||!await z((0,Dr.join)(e,"PG_VERSION")),o=await r.create({database:S.database,dataDir:e,debug:t?5:void 0,extensions:n.extensions,fsBundle:n.fsBundle,initialMemory:Or,loadDataDir:s?n.loadDataDir:void 0,relaxedDurability:!1,startParams:[...r.defaultStartParams,...Nr],wasmModule:n.wasmModule});return await Br(o),o}async function Zs(e,t){return await new Promise((r,n)=>{let s=i=>{if(a(),i.code==="EADDRINUSE"){n(new N(t));return}n(i)},o=()=>{let i=e.address();if(a(),!i||typeof i=="string"){n(new Error("Failed to determine TCP server port"));return}r(i.port)},a=()=>{e.off("error",s),e.off("listening",o)};e.once("error",s),e.once("listening",o),e.listen(t,_r)})}async function eo(e){await new Promise((t,r)=>{e.close(n=>{let s=n;if(s&&s.code!=="ERR_SERVER_NOT_RUNNING"){r(s);return}t()})})}async function to(e,t){let{PGlite:r}=await import("@electric-sql/pglite"),n=await Ze(),s=await r.create({database:S.database,dataDir:"memory://",debug:t?5:void 0,extensions:n.extensions,fsBundle:n.fsBundle,initialMemory:Or,loadDataDir:n.loadDataDir,relaxedDurability:!1,startParams:[...r.defaultStartParams,...Nr],wasmModule:n.wasmModule});return await Br(s),s}async function ro(e,t,r){let{rows:n}=await e.query(`
|
|
104
104
|
SELECT attribute.attname AS column_name
|
|
105
105
|
FROM pg_constraint pk_constraint
|
|
106
106
|
INNER JOIN pg_class relation
|
|
@@ -113,9 +113,9 @@ Received data: ${l}`));n({childProcess:a,url:`http://${p}:${f}`})},c=l=>{this.#t
|
|
|
113
113
|
ON attribute.attrelid = relation.oid
|
|
114
114
|
AND attribute.attnum = keys.attnum
|
|
115
115
|
WHERE pk_constraint.contype = 'p'
|
|
116
|
-
AND namespace.nspname = ${
|
|
117
|
-
AND relation.relname = ${
|
|
116
|
+
AND namespace.nspname = ${Ir(t)}
|
|
117
|
+
AND relation.relname = ${Ir(r)}
|
|
118
118
|
ORDER BY keys.ordinality
|
|
119
|
-
`);return n.map(s=>s.column_name)}function
|
|
120
|
-
${JSON.stringify(i,null,2)}`),new Error(`Invalid Prisma Dev state for "${n}".`);return new
|
|
121
|
-
`,{encoding:"utf-8"})}};async function Do(e,t){let{debug:r,onlyMetadata:n}=t||{},s=typeof e=="string"?e:e.name,o=typeof e!="string"?e:void 0,a={databasePort:o?.databasePort??-1,experimental:o?.experimental,exports:o?.exports,name:s,pid:o?.pid,port:o?.port??-1,shadowDatabasePort:o?.shadowDatabasePort??-1,version:"1"};try{let i=o||await A.fromServerDump({debug:r,name:s});if(!i)return r&&console.debug(`[State] no server state found for name: ${s}`),{...a,status:"no_such_server"};a.databasePort=i.databasePort,a.experimental=i.experimental,a.exports=i.exports,a.pid=i.pid,a.port=i.port,a.shadowDatabasePort=i.shadowDatabasePort;let{exports:c,pid:u}=i;if(n)return{...a,status:"unknown"};if(!hn(u,r))return r&&console.debug(`[State] server state for "${s}" has no running process with PID: ${u}`),{...a,status:"not_running"};let l=Y(s);try{if(!await(0,z.check)(l,{lockfilePath:(0,W.join)(l,".lock")}))return r&&console.debug(`[State] server state for "${s}" is not locked, indicating it is not running.`),{...a,status:"not_running"}}catch(E){r&&console.error(`[State] server state for "${s}" failed to check lock:`,E)}if(!c)return{...a,status:"starting_up"};let{http:h}=c,{hc:d}=await import("hono/client"),p=await d(h.url).health.$get();if(!p.ok)return r&&console.debug(`[State] server state for "${s}" is not live: ${JSON.stringify(p)}`),{...a,status:"not_running"};let f=await p.json();return f.name!==e?(r&&console.debug(`[State] server state for "${s}" has mismatched health response: ${JSON.stringify(f)}`),{...a,status:"unknown"}):(r&&console.debug(`[State] server state for "${e}" is live: ${JSON.stringify(f)}`),{...a,status:"running"})}catch(i){return r&&console.error(`[State] failed to get server status for "${s}":`,i),{...a,status:"error"}}}var xt=class extends Error{name="ServerStateAlreadyExistsError";constructor(t){super(`A Prisma Dev server with the name "${t}" is already running.`)}},De=class extends xt{#r;name="ServerAlreadyRunningError";constructor(t){super(t.name),this.#r=t}get server(){return A.fromServerDump({debug:this.#r.debug,name:this.#r.name})}};m();var En=require("crypto"),Dt=require("timers/promises"),_t=require("util"),vn=require("std-env");K();var _o="application/json",se={connection:"close","content-type":_o},Ao={apiVersion:"durable.streams/profile/v1",profile:{kind:"state-protocol",touch:{enabled:!0,onMissingBefore:"coarse"}}},At={apiVersion:"durable.streams/schema-registry/v1",schema:{additionalProperties:!0,properties:{headers:{properties:{operation:{type:"string"},timestamp:{format:"date-time",type:"string"}},required:["timestamp","operation"],type:"object"},key:{type:"string"},type:{type:"string"}},required:["type","key","headers"],type:"object"},search:{aliases:{rowKey:"key",table:"type"},fields:{eventTime:{bindings:[{jsonPointer:"/headers/timestamp",version:1}],column:!0,exact:!0,exists:!0,kind:"date",sortable:!0},key:{bindings:[{jsonPointer:"/key",version:1}],exact:!0,exists:!0,kind:"keyword"},operation:{bindings:[{jsonPointer:"/headers/operation",version:1}],exact:!0,exists:!0,kind:"keyword"},type:{bindings:[{jsonPointer:"/type",version:1}],exact:!0,exists:!0,kind:"keyword"}},primaryTimestampField:"eventTime"}};async function Rn(e){let{dbServer:t,debug:r,name:n,persistenceMode:s,port:o,queryInsightsBridge:a,walBridge:i}=e,c=s==="stateless",u=c?Fo(n):n,l=Re(u),h=!c&&await H(l);vn.process.env.DS_LOCAL_DATA_ROOT=bt(),c&&await j(l);let d=await Oo({debug:r,hadExistingStreamsData:h,name:u,port:o}),p={serverUrl:d.exports.http.url,sqlitePath:d.exports.sqlite.path,streamName:ht,url:xe(d.exports.http.url)};try{await Lo(p);let f=await gn({bridge:a,debug:r,serverUrl:d.exports.http.url,sqlitePath:d.exports.sqlite.path}),E=new Nt({dbServer:t,debug:r,streamUrl:p.url}),J=i.subscribe(_e=>{E.enqueue(_e)});return{close:async()=>{J(),await E.close(),await f.close(),await d.close(),await(0,Dt.setTimeout)(100),c&&await j(l)},experimental:p,experimentalQueryInsights:f.experimental}}catch(f){throw await d.close().catch(()=>{}),await(0,Dt.setTimeout)(100),c&&await j(l).catch(()=>{}),f}}var No=["database disk image is malformed","duplicate column name:","file is not a database","malformed database schema","no such column:","no such table:","schema_version row missing after migration","unexpected schema version:"];async function Oo(e){let{debug:t,hadExistingStreamsData:r,name:n,port:s}=e,{startLocalDurableStreamsServer:o}=await import("@prisma/streams-local"),a=()=>o({hostname:"127.0.0.1",name:n,port:s});try{return await a()}catch(i){if(!r||!Mo(i))throw i;return console.warn(`[streams] resetting incompatible durable streams data for "${n}"`),t&&console.debug(`[streams] original durable streams startup error for "${n}"`,i),await j(Re(n)),await a()}}function Mo(e){return Bo(e).map(r=>r.toLowerCase()).some(r=>No.some(n=>r.includes(n)))}function Bo(e){let t=[],r=[e],n=new Set;for(;r.length>0;){let s=r.shift();if(!(s==null||n.has(s))){if(n.add(s),typeof s=="string"){t.push(s);continue}if(s instanceof AggregateError)for(let o of s.errors)r.push(o);if(s instanceof Error){t.push(s.message);let o=s.cause;o!==void 0&&r.push(o)}}}return t}var Nt=class{#r;#e;#t;#s;#o;constructor(t){this.#r=t.dbServer,this.#e=t.debug,this.#t=Promise.resolve(),this.#s=t.streamUrl,this.#o=new Set}enqueue(t){t.length!==0&&(this.#t=this.#t.then(async()=>{let r=await this.#a(t);r.length!==0&&(await Co(this.#s,r),this.#e&&console.debug(`[streams] appended ${r.length} state-protocol record(s) to ${this.#s}`))}).catch(r=>{console.error("[streams] failed to ingest WAL events into prisma-wal",r)}))}async close(){await this.#t}async#a(t){let r=[],n=new Date().toISOString();for(let s of t)r.push(...await this.#n(s,n));return r}async#n(t,r){let n=`${t.schema}.${t.table}`,s=await this.#r.getPrimaryKeyColumns(t.schema,t.table),o=wn(t.record),a=wn(t.oldRecord),i=this.#i(n,s,a),c=this.#i(n,s,o),u=t.txid===""?void 0:t.txid;return t.type==="insert"?o&&c?[{headers:{operation:"insert",timestamp:r,txid:u},key:c,old_value:null,type:n,value:o}]:[]:t.type==="delete"?a&&i?[{headers:{operation:"delete",timestamp:r,txid:u},key:i,old_value:a,type:n,value:null}]:[]:!o||!a||!i||!c?[]:i!==c?[{headers:{operation:"delete",timestamp:r,txid:u},key:i,old_value:a,type:n,value:null},{headers:{operation:"insert",timestamp:r,txid:u},key:c,old_value:null,type:n,value:o}]:[{headers:{operation:"update",timestamp:r,txid:u},key:c,old_value:a,type:n,value:o}]}#i(t,r,n){if(!n)return null;let s=Uo(n,r);return s||(this.#o.has(t)||(this.#o.add(t),console.warn(`[streams] falling back to full-row keys for ${t} because no primary key could be resolved`)),Qo(n))}};async function Lo(e){let t=await fetch(e.url,{headers:se,method:"PUT"});if(!t.ok)throw await oe(t,`Failed to create ${e.streamName}`);let r=await fetch(`${e.url}/_profile`,{body:JSON.stringify(Ao),headers:se,method:"POST"});if(!r.ok)throw await oe(r,`Failed to configure ${e.streamName}`);let n=await $o(e);if(ko(n,e.streamName))return;if(n.currentVersion>0)throw new Error(`Failed to install schema for ${e.streamName}: existing schema registry is incompatible and requires a lens migration`);let s=await fetch(`${e.url}/_schema`,{body:JSON.stringify(At),headers:se,method:"POST"});if(!s.ok)throw await oe(s,`Failed to install schema for ${e.streamName}`)}async function $o(e){let t=await fetch(`${e.url}/_schema`,{headers:se,method:"GET"});if(!t.ok)throw await oe(t,`Failed to inspect schema for ${e.streamName}`);return await t.json()}function ko(e,t){if(e.currentVersion<=0||e.schema!==t)return!1;let r=e.schemas[String(e.currentVersion)];return(0,_t.isDeepStrictEqual)(r,At.schema)&&(0,_t.isDeepStrictEqual)(e.search,At.search)}async function Co(e,t){let r=await fetch(e,{body:JSON.stringify(t),headers:se,method:"POST"});if(!r.ok)throw await oe(r,"Failed to append to prisma-wal")}async function oe(e,t){let r=await e.text().catch(()=>"");return new Error(`${t}: HTTP ${e.status}${r?` ${r}`:""}`)}function Uo(e,t){if(t.length===0)return null;let r=[];for(let n of t){if(!Object.prototype.hasOwnProperty.call(e,n))return null;let s=qo(e[n]);if(s==null)return null;r.push(t.length===1?s:`${n}=${s}`)}return r.join("|")}function Qo(e){return JSON.stringify(Ot(e))}function Ot(e){return Array.isArray(e)?e.map(t=>Ot(t)):e&&typeof e=="object"?Object.fromEntries(Object.entries(e).sort(([t],[r])=>t.localeCompare(r)).map(([t,r])=>[t,Ot(r)])):e}function wn(e){return e?structuredClone(e):null}function qo(e){if(e===null)return"null";if(e===void 0)return"undefined";if(typeof e=="string")return e;if(typeof e=="number")return Number.isFinite(e)?String(e):null;if(typeof e=="bigint")return e.toString();if(typeof e=="boolean")return e?"true":"false";try{return JSON.stringify(e)}catch{return null}}function Fo(e){return`${e}.${(0,En.randomUUID)().replaceAll("-","")}`}async function xn(e){let t=await A.createExclusively(e),r=null,n=null,s=null,o=null;try{[r,s]=await Promise.all([tt("database",t),tt("shadow_database",t)]);let a,i;t.dryRun?(a=jo(),i=Ko(),o=Vo()):(a=await r.attachWalEventBridge(),i=await r.attachQueryInsightsBridge(),o=await Rn({dbServer:r,debug:t.debug,name:t.name,port:t.streamsPort,persistenceMode:t.persistenceMode,queryInsightsBridge:i,walBridge:a})),n=await mn(r,t);let c=Wo(r,s,n,t);await t.writeServerDump(c,t.dryRun?{}:{queryInsights:o.experimentalQueryInsights,streams:o.experimental});let u=Ho(a),l=pn(o.experimentalQueryInsights),h=r,d=s,p=n,f=o,E=async()=>{u.close(),await Tn(t,[p,f,h,d])};return{close:E,dbServer:r,httpServer:n,server:{...c,close:E,experimental:{queryInsights:l,streams:o.experimental,wal:u.api},name:t.name},serverState:t,shadowDbServer:s,streamsServer:o,queryInsightsBridge:i,walBridge:a}}catch(a){return await Go(t,[n,o,r,s],a)}}function Wo(e,t,r,n){let s=`prisma+postgres://localhost:${r.port}/?${new URLSearchParams({api_key:Lt({databaseUrl:e.prismaORMConnectionString,name:n.name,shadowDatabaseUrl:t.prismaORMConnectionString})}).toString()}`;return{database:{connectionString:e.connectionString,prismaORMConnectionString:e.prismaORMConnectionString,terminalCommand:e.terminalCommand},http:{url:r.url},ppg:{url:s},shadowDatabase:{connectionString:t.prismaORMConnectionString,prismaORMConnectionString:t.prismaORMConnectionString,terminalCommand:t.terminalCommand}}}async function Tn(e,t){let r=[];for(let n of t)try{await n.close()}catch(s){r.push(s)}try{await e.close()}catch(n){r.push(n)}if(r.length>0)throw new AggregateError(r,"Failed to close some servers")}async function Go(e,t,r){try{await Tn(e,t.filter(n=>n!==null))}catch(n){throw new AggregateError([r,n],"Failed to start Prisma Dev server cleanly")}throw r}function Ho(e){let t=new Set;return{api:{stream:()=>{let r=()=>{},n=zo(e,()=>{t.delete(r)});return r=()=>n.close(),t.add(r),n.stream},subscribe:r=>e.subscribe(r)},close:()=>{for(let r of[...t])r();t.clear()}}}function jo(){return{async close(){},async poll(){},subscribe(){return()=>{}}}}function Ko(){return{async close(){},subscribe(){return()=>{}}}}function Vo(){return{async close(){},experimental:{serverUrl:"",sqlitePath:"",streamName:"",url:""},experimentalQueryInsights:{serverUrl:"",sqlitePath:"",streamName:"",url:""}}}function zo(e,t){let r=[],n=!1,s=null,o=e.subscribe(i=>{if(!n){if(s){let c=s;s=null,c.resolve({done:!1,value:i});return}r.push(i)}}),a=()=>{if(!n&&(n=!0,o(),r.length=0,t(),s)){let i=s;s=null,i.resolve({done:!0,value:void 0})}};return{close:a,stream:{[Symbol.asyncIterator](){return this},next(){return r.length>0?Promise.resolve({done:!1,value:r.shift()}):n?Promise.resolve({done:!0,value:void 0}):new Promise((i,c)=>{s={reject:c,resolve:i}})},return(){return a(),Promise.resolve({done:!0,value:void 0})},throw(i){let c=s;return a(),c&&c.reject(i),Promise.reject(i instanceof Error?i:new Error(String(i)))}}}}async function In(e){let{server:t}=await xn(e);return t}var N;process.once("SIGTERM",()=>{console.log("SIGTERM received, shutting down..."),process.removeAllListeners("SIGINT"),process.exitCode=143,N?.close().finally(()=>process.exit())});process.once("SIGINT",()=>{console.log("SIGINT received, shutting down..."),process.removeAllListeners("SIGTERM"),process.exitCode=130,N?.close().finally(()=>process.exit())});async function Jo(){let[,,e]=process.argv;if(!e)return process.send?.({type:"error",error:'Missing "name" argument, server cannot be started'},void 0),process.exit(1);try{N=await In({debug:!0,persistenceMode:"stateful",name:e});let t=N.experimental.queryInsights,r={database:N.database,experimental:{queryInsights:{serverUrl:t.serverUrl,sqlitePath:t.sqlitePath,streamName:t.streamName,url:t.url},streams:N.experimental.streams},http:N.http,name:N.name,ppg:N.ppg,shadowDatabase:N.shadowDatabase};process.send?.({type:"started",server:r},void 0)}catch(t){console.error(t);let r=t instanceof Error?t.message:String(t);process.send?.({type:"error",error:r},void 0),await(0,Dn.setTimeout)(1e3),process.exit(1)}}Jo();
|
|
119
|
+
`);return n.map(s=>s.column_name)}function Ir(e){return`'${e.replaceAll("'","''")}'`}async function no(e){let{dataDir:t,db:r,debug:n,destinationPath:s}=e,o=r||await kr(t,n),{pgDump:a}=await import("@electric-sql/pglite-tools/pg_dump"),i=await a({args:["--schema-only","--no-owner"],fileName:s?(0,Ar.filename)(s):void 0,pg:await o.clone()});return s?(n&&console.debug(`[DB] Dumping database to ${s}`),await Jt(i,s)):(n&&console.debug("[DB] Dumping database to memory"),await i.text())}m();var Tn=D(require("find-my-way"),1);C();async function xn(e,t){let{port:r}=t;if(t.dryRun)return{async close(){},port:r,url:`http://localhost:${r}`};let n=!!t.debug,[{registerAccelerateRoutes:s},{registerUtilityRoutes:o},{createHTTPServer:a}]=await Promise.all([Promise.resolve().then(()=>(En(),wn)),Promise.resolve().then(()=>(Rn(),vn)),Promise.resolve().then(()=>(Ie(),Zr))]),i={databaseDumpPath:t.databaseDumpPath,db:e,debug:n,name:t.name,port:r,shadowDBPort:t.shadowDatabasePort},c=(0,Tn.default)({defaultRoute(l,f){x(f,"Not Found",404)},ignoreTrailingSlash:!1});s(c,i,n),o(c,i,n);let u=await a({router:c}).listen(r);return t.port=u.port,i.port=u.port,{async close(){let{Engine:l}=await Promise.resolve().then(()=>(bt(),St));await Promise.allSettled([u.close(),l.stopAll()])},port:u.port,url:u.url}}m();var It=require("util");m();var vt=require("pathe");Y();var Rt="prisma-wal",Tt="prisma-queries";function xt(){return(0,vt.join)(he.data,"durable-streams")}function _e(e){return(0,vt.join)(xt(),e)}function Oe(e,t=Rt){return new URL(`/v1/stream/${encodeURIComponent(t)}`,e).toString()}var No="application/json",Ne={connection:"close","content-type":No},Dt={apiVersion:"durable.streams/schema-registry/v1",schema:{additionalProperties:!0,properties:{applicationName:{type:["string","null"]},durationMs:{type:"number"},groupKey:{type:["string","null"]},query:{type:"string"},queryId:{type:"string"},reads:{type:"number"},rowsReturned:{type:"number"},tables:{items:{type:"string"},type:"array"},timestamp:{format:"date-time",type:"string"}},required:["durationMs","query","queryId","reads","rowsReturned","tables","timestamp"],type:"object"},search:{aliases:{applicationName:"applicationName",groupKey:"groupKey",queryId:"queryId"},fields:{applicationName:{bindings:[{jsonPointer:"/applicationName",version:1}],exact:!0,exists:!0,kind:"keyword"},eventTime:{bindings:[{jsonPointer:"/timestamp",version:1}],column:!0,exact:!0,exists:!0,kind:"date",sortable:!0},groupKey:{bindings:[{jsonPointer:"/groupKey",version:1}],exact:!0,exists:!0,kind:"keyword"},queryId:{bindings:[{jsonPointer:"/queryId",version:1}],exact:!0,exists:!0,kind:"keyword"}},primaryTimestampField:"eventTime"}};function In(e){return{...e,snapshot:async t=>await Mo(e.url,t)}}async function Dn(e){let t={serverUrl:e.serverUrl,sqlitePath:e.sqlitePath,streamName:Tt,url:Oe(e.serverUrl,Tt)};await Lo(t);let r=new At({debug:e.debug,streamUrl:t.url}),n=e.bridge.subscribe(s=>{r.enqueue(s)});return{close:async()=>{n(),await r.close()},experimental:t}}async function Mo(e,t){if(!e)return sr();let r=await Bo(e);return ur(r,t)}async function Bo(e){let t=await fetch(`${e}?offset=-1&format=json`,{headers:{connection:"close"}});if(!t.ok)throw new Error(`Failed to read ${e}: HTTP ${t.status}`);return await t.json()}var At=class{#r;#e;#t;constructor(t){this.#r=t.debug,this.#e=Promise.resolve(),this.#t=t.streamUrl}enqueue(t){t.length!==0&&(this.#e=this.#e.then(async()=>{await Co(this.#t,t),this.#r&&console.debug(`[streams] appended ${t.length} query insight record(s) to ${this.#t}`)}).catch(r=>{console.error("[streams] failed to ingest query insights into prisma-queries",r)}))}async close(){await this.#e}};async function Lo(e){let t=await fetch(e.url,{headers:Ne,method:"PUT"});if(!t.ok)throw await Me(t,`Failed to create ${e.streamName}`);let r=await ko(e);if($o(r,e.streamName))return;if(r.currentVersion>0)throw new Error(`Failed to install schema for ${e.streamName}: existing schema registry is incompatible and requires a lens migration`);let n=await fetch(`${e.url}/_schema`,{body:JSON.stringify(Dt),headers:Ne,method:"POST"});if(!n.ok)throw await Me(n,`Failed to install schema for ${e.streamName}`)}function $o(e,t){if(e.currentVersion<=0||e.schema!==t)return!1;let r=e.schemas[String(e.currentVersion)];return(0,It.isDeepStrictEqual)(r,Dt.schema)&&(0,It.isDeepStrictEqual)(e.search,Dt.search)}async function ko(e){let t=await fetch(`${e.url}/_schema`,{headers:Ne,method:"GET"});if(!t.ok)throw await Me(t,`Failed to inspect schema for ${e.streamName}`);return await t.json()}async function Co(e,t){let r=await fetch(e,{body:JSON.stringify(t),headers:Ne,method:"POST"});if(!r.ok)throw await Me(r,"Failed to append to prisma-queries")}async function Me(e,t){let r=await e.text().catch(()=>"");return new Error(`${t}: HTTP ${e.status}${r?` ${r}`:""}`)}m();var Bn=require("fs/promises"),V=require("pathe"),ee=require("proper-lockfile"),Bt=require("std-env"),g=require("valibot");Y();m();var Uo=require("timers/promises"),An=require("std-env");function _n(e,t){if(e==null)return!1;try{return An.process.kill?.(e,0)??!0}catch(r){return t&&console.error(`Error checking if process with PID ${e} exists:`,r),!1}}se();var ue=(0,g.pipe)((0,g.string)(),(0,g.url)()),On=(0,g.object)({connectionString:ue,prismaORMConnectionString:(0,g.optional)(ue),terminalCommand:(0,g.optional)((0,g.string)())}),Nn=(0,g.object)({url:ue}),Mn=(0,g.object)({serverUrl:ue,sqlitePath:(0,g.pipe)((0,g.string)(),(0,g.minLength)(1)),streamName:(0,g.pipe)((0,g.string)(),(0,g.minLength)(1)),url:ue}),Qo=(0,g.object)({queryInsights:(0,g.optional)(Mn),streams:(0,g.optional)(Mn)}),_t=(0,g.pipe)((0,g.number)(),(0,g.integer)(),(0,g.minValue)(1)),qo=(0,g.object)({database:On,http:Nn,ppg:Nn,shadowDatabase:On}),Ho=(0,g.object)({databasePort:_t,experimental:(0,g.optional)(Qo),exports:(0,g.optional)(qo),name:(0,g.pipe)((0,g.string)(),(0,g.minLength)(1)),pid:(0,g.optional)((0,g.pipe)((0,g.number)(),(0,g.integer)(),(0,g.minValue)(0))),port:_t,shadowDatabasePort:_t,version:(0,g.literal)("1")}),Lt=Symbol("initialize"),Ot="default",Fo=new Set(["durable-streams"]),B=class{_databasePort;databaseConnectTimeoutMillis;databaseIdleTimeoutMillis;debug;dryRun;name;persistenceMode;pid;shadowDatabaseConnectTimeoutMillis;shadowDatabaseIdleTimeoutMillis;_port;_shadowDatabasePort;_streamsPort;constructor(t){this._databasePort=t.databasePort??_,this.databaseConnectTimeoutMillis=t.databaseConnectTimeoutMillis??6e4,this.databaseIdleTimeoutMillis=t.databaseIdleTimeoutMillis??1/0,this.debug=t.debug??!1,this.dryRun=t.dryRun??!1,this.name=t.name??Ot,this.persistenceMode=t.persistenceMode,this.pid=t.pid??Bt.process.pid,this.shadowDatabaseConnectTimeoutMillis=t.shadowDatabaseConnectTimeoutMillis??this.databaseConnectTimeoutMillis,this.shadowDatabaseIdleTimeoutMillis=t.shadowDatabaseIdleTimeoutMillis??this.databaseIdleTimeoutMillis,this._port=t.port??_,this._shadowDatabasePort=t.shadowDatabasePort??_,this._streamsPort=t.streamsPort??_}static async createExclusively(t){let r=t?.dryRun!==!0&&t?.persistenceMode==="stateful"?new ce(t):new Nt(t);return await r[Lt](),r}static async fromServerDump(t){let{debug:r,name:n=Ot}=t??{},s=ne(n),o=ce.getServerDumpPath(s),a=await Yt(o);if(a==null)return r&&console.debug(`[State] No server dump file found at: ${o}`),null;r&&(console.debug(`[State] server dump file found at "${o}":`),console.debug(a));let{issues:i,output:c,success:u}=(0,g.safeParse)((0,g.pipe)((0,g.string)(),(0,g.parseJson)(),Ho),a);if(!u)throw r&&console.debug(`[State] Invalid server dump file at "${o}":
|
|
120
|
+
${JSON.stringify(i,null,2)}`),new Error(`Invalid Prisma Dev state for "${n}".`);return new ce({databasePort:c.databasePort,debug:r,dryRun:!1,name:n,pid:c.pid,port:c.port,serverDump:c,shadowDatabasePort:c.shadowDatabasePort})}static async scan(t){let{debug:r,globs:n}=t??{},s=(0,V.join)(ne(Ot),"..");r&&console.debug(`[State] scanning for server states in: ${s}`);let o=(await Zt(s,n)).filter(a=>!Fo.has(a));return r&&console.debug(`[State] found server names: ${JSON.stringify(o)}`),await Promise.all(o.map(a=>Wo(a,t)))}get databasePort(){return this._databasePort}set databasePort(t){this.#r("databasePort",t)}get port(){return this._port}set port(t){this.#r("port",t)}get shadowDatabasePort(){return this._shadowDatabasePort}get streamsPort(){return this._streamsPort}set shadowDatabasePort(t){this.#r("shadowDatabasePort",t)}#r(t,r){if(r<0||!Number.isInteger(r))throw new Error(`Invalid port number: ${r}`);let n=`_${t}`;if(this[n]!==j&&this[n]!==r)throw new Error(`\`${t}\` is already set to ${this[n]}, cannot change it to ${r}`);this[n]=r}},Nt=class extends B{constructor(t){super({...t,databasePort:t?.databasePort||j,persistenceMode:"stateless",port:t?.port||j,shadowDatabasePort:t?.shadowDatabasePort||j,streamsPort:t?.streamsPort||j})}get databaseDumpPath(){return"<DUMP_PATH>"}get pgliteDataDirPath(){return"memory://"}async[Lt](){let t;try{t=await B.scan({debug:this.debug,onlyMetadata:!0})}catch(n){this.debug&&console.warn("[State] failed to scan for existing servers, assuming filesystem does not exist or other reasons.",n),t=[]}let r=await Ke({debug:this.debug,name:this.dryRun?this.name:"",requestedPorts:{databasePort:this.databasePort,port:this.port,shadowDatabasePort:this.shadowDatabasePort,streamsPort:this.streamsPort},servers:t});this._databasePort=r.databasePort,this._port=r.port,this._shadowDatabasePort=r.shadowDatabasePort,this._streamsPort=r.streamsPort}async close(){}async writeServerDump(){}},ce=class e extends B{#r;#e;#t;#s;#o;#a;#n;constructor(t){super({...t,persistenceMode:"stateful"}),this.#a=!1,this.#e=ne(this.name),this.#r=(0,V.join)(this.#e,"db_dump.bak"),this.#t=(0,V.join)(this.#e,".lock"),this.#s=(0,V.join)(this.#e,".pglite"),this.#n=t?.serverDump??null,this.#o=e.getServerDumpPath(this.#e)}static getServerDumpPath(t){return(0,V.join)(t,"server.json")}get databaseDumpPath(){return this.#r}get exports(){return this.#n?.exports}get experimental(){return this.#n?.experimental}get pgliteDataDirPath(){return this.#s}async[Lt](){await Xt(this.#e),this.debug&&console.debug(`[State] using data directory: ${this.#e}`);try{await(0,ee.lock)(this.#e,{lockfilePath:this.#t}),this.debug&&console.debug(`[State] obtained lock on: ${this.#e}`);let t=await B.scan({debug:this.debug,onlyMetadata:!0}),r=await Ke({debug:this.debug,name:this.name,requestedPorts:{databasePort:this.databasePort,port:this.port,shadowDatabasePort:this.shadowDatabasePort,streamsPort:this.streamsPort},servers:t});this._databasePort=r.databasePort,this._port=r.port,this._shadowDatabasePort=r.shadowDatabasePort,this._streamsPort=r.streamsPort,await this.writeServerDump()}catch(t){throw t instanceof Error&&"code"in t&&t.code==="ELOCKED"?new Be(this):t}}async close(){if(!this.#a)try{await(0,ee.unlock)(this.#e,{lockfilePath:this.#t}),this.#a=!0,this.debug&&console.debug(`[State] released lock on: ${this.#e}`)}catch(t){throw this.debug&&console.error(`[State] failed to release lock on: ${this.#e}`,t),t}}async writeServerDump(t,r){this.#n={name:this.name,version:"1",pid:Bt.process.pid,port:this.port,databasePort:this.databasePort,experimental:r,shadowDatabasePort:this.shadowDatabasePort,exports:t},await(0,Bn.writeFile)(this.#o,`${JSON.stringify(this.#n,null,2)}
|
|
121
|
+
`,{encoding:"utf-8"})}};async function Wo(e,t){let{debug:r,onlyMetadata:n}=t||{},s=typeof e=="string"?e:e.name,o=typeof e!="string"?e:void 0,a={databasePort:o?.databasePort??-1,experimental:o?.experimental,exports:o?.exports,name:s,pid:o?.pid,port:o?.port??-1,shadowDatabasePort:o?.shadowDatabasePort??-1,version:"1"};try{let i=o||await B.fromServerDump({debug:r,name:s});if(!i)return r&&console.debug(`[State] no server state found for name: ${s}`),{...a,status:"no_such_server"};a.databasePort=i.databasePort,a.experimental=i.experimental,a.exports=i.exports,a.pid=i.pid,a.port=i.port,a.shadowDatabasePort=i.shadowDatabasePort;let{exports:c,pid:u}=i;if(n)return{...a,status:"unknown"};if(!_n(u,r))return r&&console.debug(`[State] server state for "${s}" has no running process with PID: ${u}`),{...a,status:"not_running"};let l=ne(s);try{if(!await(0,ee.check)(l,{lockfilePath:(0,V.join)(l,".lock")}))return r&&console.debug(`[State] server state for "${s}" is not locked, indicating it is not running.`),{...a,status:"not_running"}}catch(y){r&&console.error(`[State] server state for "${s}" failed to check lock:`,y)}if(!c)return{...a,status:"starting_up"};let{http:f}=c,d=await fetch(`${f.url}/health`,{headers:{connection:"close"}});if(!d.ok)return r&&console.debug(`[State] server state for "${s}" is not live: ${JSON.stringify(d)}`),{...a,status:"not_running"};let p=await d.json();return p.name!==e?(r&&console.debug(`[State] server state for "${s}" has mismatched health response: ${JSON.stringify(p)}`),{...a,status:"unknown"}):(r&&console.debug(`[State] server state for "${e}" is live: ${JSON.stringify(p)}`),{...a,status:"running"})}catch(i){return r&&console.error(`[State] failed to get server status for "${s}":`,i),{...a,status:"error"}}}var Mt=class extends Error{name="ServerStateAlreadyExistsError";constructor(t){super(`A Prisma Dev server with the name "${t}" is already running.`)}},Be=class extends Mt{#r;name="ServerAlreadyRunningError";constructor(t){super(t.name),this.#r=t}get server(){return B.fromServerDump({debug:this.#r.debug,name:this.#r.name})}};m();var $n=require("crypto"),$t=require("timers/promises"),kt=require("util"),kn=require("std-env");Y();var Go="application/json",le={connection:"close","content-type":Go},jo={apiVersion:"durable.streams/profile/v1",profile:{kind:"state-protocol",touch:{enabled:!0,onMissingBefore:"coarse"}}},Ct={apiVersion:"durable.streams/schema-registry/v1",schema:{additionalProperties:!0,properties:{headers:{properties:{operation:{type:"string"},timestamp:{format:"date-time",type:"string"}},required:["timestamp","operation"],type:"object"},key:{type:"string"},type:{type:"string"}},required:["type","key","headers"],type:"object"},search:{aliases:{rowKey:"key",table:"type"},fields:{eventTime:{bindings:[{jsonPointer:"/headers/timestamp",version:1}],column:!0,exact:!0,exists:!0,kind:"date",sortable:!0},key:{bindings:[{jsonPointer:"/key",version:1}],exact:!0,exists:!0,kind:"keyword"},operation:{bindings:[{jsonPointer:"/headers/operation",version:1}],exact:!0,exists:!0,kind:"keyword"},type:{bindings:[{jsonPointer:"/type",version:1}],exact:!0,exists:!0,kind:"keyword"}},primaryTimestampField:"eventTime"}};async function Cn(e){let{dbServer:t,debug:r,name:n,persistenceMode:s,port:o,queryInsightsBridge:a,walBridge:i}=e,c=s==="stateless",u=c?sa(n):n,l=_e(u),f=!c&&await z(l);kn.process.env.DS_LOCAL_DATA_ROOT=xt(),c&&await J(l);let d=await Ko({debug:r,hadExistingStreamsData:f,name:u,port:o}),p={serverUrl:d.exports.http.url,sqlitePath:d.exports.sqlite.path,streamName:Rt,url:Oe(d.exports.http.url)};try{await Yo(p);let y=await Dn({bridge:a,debug:r,serverUrl:d.exports.http.url,sqlitePath:d.exports.sqlite.path}),E=new Ut({dbServer:t,debug:r,streamUrl:p.url}),te=i.subscribe(Le=>{E.enqueue(Le)});return{close:async()=>{te(),await E.close(),await y.close(),await d.close(),await(0,$t.setTimeout)(100),c&&await J(l)},experimental:p,experimentalQueryInsights:y.experimental}}catch(y){throw await d.close().catch(()=>{}),await(0,$t.setTimeout)(100),c&&await J(l).catch(()=>{}),y}}var Vo=["database disk image is malformed","duplicate column name:","file is not a database","malformed database schema","no such column:","no such table:","schema_version row missing after migration","unexpected schema version:"];async function Ko(e){let{debug:t,hadExistingStreamsData:r,name:n,port:s}=e,{startLocalDurableStreamsServer:o}=await import("@prisma/streams-local"),a=()=>o({hostname:"127.0.0.1",name:n,port:s});try{return await a()}catch(i){if(!r||!zo(i))throw i;return console.warn(`[streams] resetting incompatible durable streams data for "${n}"`),t&&console.debug(`[streams] original durable streams startup error for "${n}"`,i),await J(_e(n)),await a()}}function zo(e){return Jo(e).map(r=>r.toLowerCase()).some(r=>Vo.some(n=>r.includes(n)))}function Jo(e){let t=[],r=[e],n=new Set;for(;r.length>0;){let s=r.shift();if(!(s==null||n.has(s))){if(n.add(s),typeof s=="string"){t.push(s);continue}if(s instanceof AggregateError)for(let o of s.errors)r.push(o);if(s instanceof Error){t.push(s.message);let o=s.cause;o!==void 0&&r.push(o)}}}return t}var Ut=class{#r;#e;#t;#s;#o;constructor(t){this.#r=t.dbServer,this.#e=t.debug,this.#t=Promise.resolve(),this.#s=t.streamUrl,this.#o=new Set}enqueue(t){t.length!==0&&(this.#t=this.#t.then(async()=>{let r=await this.#a(t);r.length!==0&&(await ea(this.#s,r),this.#e&&console.debug(`[streams] appended ${r.length} state-protocol record(s) to ${this.#s}`))}).catch(r=>{console.error("[streams] failed to ingest WAL events into prisma-wal",r)}))}async close(){await this.#t}async#a(t){let r=[],n=new Date().toISOString();for(let s of t)r.push(...await this.#n(s,n));return r}async#n(t,r){let n=`${t.schema}.${t.table}`,s=await this.#r.getPrimaryKeyColumns(t.schema,t.table),o=Ln(t.record),a=Ln(t.oldRecord),i=this.#i(n,s,a),c=this.#i(n,s,o),u=t.txid===""?void 0:t.txid;return t.type==="insert"?o&&c?[{headers:{operation:"insert",timestamp:r,txid:u},key:c,old_value:null,type:n,value:o}]:[]:t.type==="delete"?a&&i?[{headers:{operation:"delete",timestamp:r,txid:u},key:i,old_value:a,type:n,value:null}]:[]:!o||!a||!i||!c?[]:i!==c?[{headers:{operation:"delete",timestamp:r,txid:u},key:i,old_value:a,type:n,value:null},{headers:{operation:"insert",timestamp:r,txid:u},key:c,old_value:null,type:n,value:o}]:[{headers:{operation:"update",timestamp:r,txid:u},key:c,old_value:a,type:n,value:o}]}#i(t,r,n){if(!n)return null;let s=ta(n,r);return s||(this.#o.has(t)||(this.#o.add(t),console.warn(`[streams] falling back to full-row keys for ${t} because no primary key could be resolved`)),ra(n))}};async function Yo(e){let t=await fetch(e.url,{headers:le,method:"PUT"});if(!t.ok)throw await de(t,`Failed to create ${e.streamName}`);let r=await fetch(`${e.url}/_profile`,{body:JSON.stringify(jo),headers:le,method:"POST"});if(!r.ok)throw await de(r,`Failed to configure ${e.streamName}`);let n=await Xo(e);if(Zo(n,e.streamName))return;if(n.currentVersion>0)throw new Error(`Failed to install schema for ${e.streamName}: existing schema registry is incompatible and requires a lens migration`);let s=await fetch(`${e.url}/_schema`,{body:JSON.stringify(Ct),headers:le,method:"POST"});if(!s.ok)throw await de(s,`Failed to install schema for ${e.streamName}`)}async function Xo(e){let t=await fetch(`${e.url}/_schema`,{headers:le,method:"GET"});if(!t.ok)throw await de(t,`Failed to inspect schema for ${e.streamName}`);return await t.json()}function Zo(e,t){if(e.currentVersion<=0||e.schema!==t)return!1;let r=e.schemas[String(e.currentVersion)];return(0,kt.isDeepStrictEqual)(r,Ct.schema)&&(0,kt.isDeepStrictEqual)(e.search,Ct.search)}async function ea(e,t){let r=await fetch(e,{body:JSON.stringify(t),headers:le,method:"POST"});if(!r.ok)throw await de(r,"Failed to append to prisma-wal")}async function de(e,t){let r=await e.text().catch(()=>"");return new Error(`${t}: HTTP ${e.status}${r?` ${r}`:""}`)}function ta(e,t){if(t.length===0)return null;let r=[];for(let n of t){if(!Object.prototype.hasOwnProperty.call(e,n))return null;let s=na(e[n]);if(s==null)return null;r.push(t.length===1?s:`${n}=${s}`)}return r.join("|")}function ra(e){return JSON.stringify(Qt(e))}function Qt(e){return Array.isArray(e)?e.map(t=>Qt(t)):e&&typeof e=="object"?Object.fromEntries(Object.entries(e).sort(([t],[r])=>t.localeCompare(r)).map(([t,r])=>[t,Qt(r)])):e}function Ln(e){return e?structuredClone(e):null}function na(e){if(e===null)return"null";if(e===void 0)return"undefined";if(typeof e=="string")return e;if(typeof e=="number")return Number.isFinite(e)?String(e):null;if(typeof e=="bigint")return e.toString();if(typeof e=="boolean")return e?"true":"false";try{return JSON.stringify(e)}catch{return null}}function sa(e){return`${e}.${(0,$n.randomUUID)().replaceAll("-","")}`}async function Un(e){let t=await B.createExclusively(e),r=null,n=null,s=null,o=null;try{[r,s]=await Promise.all([it("database",t),it("shadow_database",t)]);let a,i;t.dryRun?(a=ca(),i=ua(),o=la()):(a=await r.attachWalEventBridge(),i=await r.attachQueryInsightsBridge(),o=await Cn({dbServer:r,debug:t.debug,name:t.name,port:t.streamsPort,persistenceMode:t.persistenceMode,queryInsightsBridge:i,walBridge:a})),n=await xn(r,t);let c=oa(r,s,n,t);await t.writeServerDump(c,t.dryRun?{}:{queryInsights:o.experimentalQueryInsights,streams:o.experimental});let u=ia(a),l=In(o.experimentalQueryInsights),f=r,d=s,p=n,y=o,E=async()=>{u.close(),await Qn(t,[p,y,f,d])};return{close:E,dbServer:r,httpServer:n,server:{...c,close:E,experimental:{queryInsights:l,streams:o.experimental,wal:u.api},name:t.name},serverState:t,shadowDbServer:s,streamsServer:o,queryInsightsBridge:i,walBridge:a}}catch(a){return await aa(t,[n,o,r,s],a)}}function oa(e,t,r,n){let s=`prisma+postgres://localhost:${r.port}/?${new URLSearchParams({api_key:Ft({databaseUrl:e.prismaORMConnectionString,name:n.name,shadowDatabaseUrl:t.prismaORMConnectionString})}).toString()}`;return{database:{connectionString:e.connectionString,prismaORMConnectionString:e.prismaORMConnectionString,terminalCommand:e.terminalCommand},http:{url:r.url},ppg:{url:s},shadowDatabase:{connectionString:t.prismaORMConnectionString,prismaORMConnectionString:t.prismaORMConnectionString,terminalCommand:t.terminalCommand}}}async function Qn(e,t){let r=[];for(let n of t)try{await n.close()}catch(s){r.push(s)}try{await e.close()}catch(n){r.push(n)}if(r.length>0)throw new AggregateError(r,"Failed to close some servers")}async function aa(e,t,r){try{await Qn(e,t.filter(n=>n!==null))}catch(n){throw new AggregateError([r,n],"Failed to start Prisma Dev server cleanly")}throw r}function ia(e){let t=new Set;return{api:{stream:()=>{let r=()=>{},n=da(e,()=>{t.delete(r)});return r=()=>n.close(),t.add(r),n.stream},subscribe:r=>e.subscribe(r)},close:()=>{for(let r of[...t])r();t.clear()}}}function ca(){return{async close(){},async poll(){},subscribe(){return()=>{}}}}function ua(){return{async close(){},subscribe(){return()=>{}}}}function la(){return{async close(){},experimental:{serverUrl:"",sqlitePath:"",streamName:"",url:""},experimentalQueryInsights:{serverUrl:"",sqlitePath:"",streamName:"",url:""}}}function da(e,t){let r=[],n=!1,s=null,o=e.subscribe(i=>{if(!n){if(s){let c=s;s=null,c.resolve({done:!1,value:i});return}r.push(i)}}),a=()=>{if(!n&&(n=!0,o(),r.length=0,t(),s)){let i=s;s=null,i.resolve({done:!0,value:void 0})}};return{close:a,stream:{[Symbol.asyncIterator](){return this},next(){return r.length>0?Promise.resolve({done:!1,value:r.shift()}):n?Promise.resolve({done:!0,value:void 0}):new Promise((i,c)=>{s={reject:c,resolve:i}})},return(){return a(),Promise.resolve({done:!0,value:void 0})},throw(i){let c=s;return a(),c&&c.reject(i),Promise.reject(i instanceof Error?i:new Error(String(i)))}}}}se();async function qn(e){let{server:t}=await Un(e);return t}var L;process.once("SIGTERM",()=>{console.log("SIGTERM received, shutting down..."),process.removeAllListeners("SIGINT"),process.exitCode=143,L?.close().finally(()=>process.exit())});process.once("SIGINT",()=>{console.log("SIGINT received, shutting down..."),process.removeAllListeners("SIGTERM"),process.exitCode=130,L?.close().finally(()=>process.exit())});async function ma(){let[,,e]=process.argv;if(!e)return process.send?.({type:"error",error:'Missing "name" argument, server cannot be started'},void 0),process.exit(1);try{L=await qn({debug:!0,persistenceMode:"stateful",name:e});let t=L.experimental.queryInsights,r={database:L.database,experimental:{queryInsights:{serverUrl:t.serverUrl,sqlitePath:t.sqlitePath,streamName:t.streamName,url:t.url},streams:L.experimental.streams},http:L.http,name:L.name,ppg:L.ppg,shadowDatabase:L.shadowDatabase};process.send?.({type:"started",server:r},void 0)}catch(t){console.error(t);let r=t instanceof Error?t.message:String(t);process.send?.({type:"error",error:r},void 0),await(0,Hn.setTimeout)(1e3),process.exit(1)}}ma();
|
package/dist/daemon.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a}from"./chunk-
|
|
1
|
+
import{a}from"./chunk-FB4QA6EA.js";import"./chunk-662IKR3V.js";import"./chunk-PP43TGA5.js";import"./chunk-KWCQYPJI.js";import"./chunk-HFONW2ZS.js";import"./chunk-ANHBRJRZ.js";import"./chunk-EDFHV3AK.js";import"./chunk-DWY47FQV.js";import"./chunk-DOJAPHLY.js";import{setTimeout as o}from"timers/promises";var e;process.once("SIGTERM",()=>{console.log("SIGTERM received, shutting down..."),process.removeAllListeners("SIGINT"),process.exitCode=143,e?.close().finally(()=>process.exit())});process.once("SIGINT",()=>{console.log("SIGINT received, shutting down..."),process.removeAllListeners("SIGTERM"),process.exitCode=130,e?.close().finally(()=>process.exit())});async function n(){let[,,t]=process.argv;if(!t)return process.send?.({type:"error",error:'Missing "name" argument, server cannot be started'},void 0),process.exit(1);try{e=await a({debug:!0,persistenceMode:"stateful",name:t});let r=e.experimental.queryInsights,s={database:e.database,experimental:{queryInsights:{serverUrl:r.serverUrl,sqlitePath:r.sqlitePath,streamName:r.streamName,url:r.url},streams:e.experimental.streams},http:e.http,name:e.name,ppg:e.ppg,shadowDatabase:e.shadowDatabase};process.send?.({type:"started",server:s},void 0)}catch(r){console.error(r);let s=r instanceof Error?r.message:String(r);process.send?.({type:"error",error:s},void 0),await o(1e3),process.exit(1)}}n();
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import{b as f,d as w,e as y}from"./chunk-DWY47FQV.js";import{a as E,b as v,c as b}from"./chunk-DOJAPHLY.js";import{spawn as $}from"child_process";import{once as H}from"events";import{mkdir as C}from"fs/promises";import{join as A}from"path";import{setTimeout as j}from"timers/promises";function R(r){let e,t,s=new Promise((i,a)=>{e=i,t=a}),n=i=>{n=o=null,t(i),r?.onRejected?.(i),r?.onFulfilled?.()},o=i=>{o=n=null,e(i),r?.onResolved?.(i),r?.onFulfilled?.()};return{isFulfilled:()=>o===n,promise:s,reject:i=>n?.(i),resolve:i=>o?.(i)}}import{process as B}from"std-env";var{PRISMA_DEV_FORCE_ENGINE_BINARY_DOWNLOAD:L,PRISMA_DEV_FORCE_ENGINE_BINARY_PATH:N,PRISMA_DEV_FORCE_NETWORK_DELAY_MS:P}=B.env,S=class r{static#t=new Map;#e;#n;constructor(e){this.#e=e,this.#n=null}static async get(e){let{debug:t}=e,s=`${e.schemaHash}:${e.clientVersion}`;try{let n=r.#t.get(s);if(n)return n;let o=new r(e);return r.#t.set(s,o),t&&console.debug("[Query Engine] starting...",e),await o.start(),t&&console.debug("[Query Engine] started!"),o}finally{r.stopAll(s)}}static async stopAll(e){let s=(await Promise.allSettled(Array.from(r.#t.entries()).filter(([n])=>n!==e).map(async([n,o])=>{try{await o.stop()}finally{r.#t.delete(n)}}))).filter(n=>n.status==="rejected").map(n=>n.reason);if(s.length>0)throw new AggregateError(s,"Failed to stop engines")}async commitTransaction(e,t){return await this.#s(e,t,"commit")}async request(e,t){let{url:s}=await this.start(),n=this.#i(t),o=await fetch(s,{body:typeof e=="string"?e:JSON.stringify(e),headers:{...n,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await l.fromResponse(o);return await o.text()}async rollbackTransaction(e,t){return await this.#s(e,t,"rollback")}async startTransaction(e,t){let{url:s}=await this.start(),n=this.#i(t),o=await fetch(`${s}/transaction/start`,{body:JSON.stringify(e),headers:{...n,"Content-Type":"application/json"},method:"POST"});if(!o.ok)throw await l.fromResponse(o);return await o.json()}async start(){if(this.#n!=null)return await this.#n;let{promise:e,reject:t,resolve:s}=R();this.#n=e;let n=N||await this.#o();this.#e.debug&&console.debug("[Query Engine] spinning up at path...",n);let{proxySignals:o}=await import("foreground-child/proxy-signals"),i=$(n,["--enable-raw-queries","--enable-telemetry-in-response","--port","0"],{env:{LOG_QUERIES:"y",PRISMA_DML:this.#e.base64Schema,QE_LOG_LEVEL:"TRACE",RUST_BACKTRACE:"1",RUST_LOG:"info"},stdio:["ignore","pipe","pipe"],windowsHide:!0});o(i),i.stderr.setEncoding("utf8"),i.stdout.setEncoding("utf8");let a=c=>{let u=c.split(`
|
|
2
|
+
`).find(k=>k.includes("Started query engine http server"));if(!u)return;i.stdout.removeListener("data",a);let{fields:p}=JSON.parse(u);if(p==null)return t(new Error(`Unexpected data during initialization, "fields" are missing: ${c}`));let{ip:m,port:h}=p;if(m==null||h==null)return t(new Error(`This version of query-engine is not compatible with minippg, "ip" and "port" are missing in the startup log entry.
|
|
3
|
+
Received data: ${c}`));s({childProcess:i,url:`http://${m}:${h}`})},T=c=>{this.#n=null,t(new d(String(c))),i.removeListener("exit",g),i.kill()};i.once("error",T);let g=(c,u)=>{this.#n=null,t(new d(`Query Engine exited with code ${c} and signal ${u}`))};return i.once("exit",g),i.stdout.on("data",a),this.#e.debug&&(i.stderr.on("data",console.error.bind(console,"[Query Engine]")),i.stdout.on("data",console.debug.bind(console,"[Query Engine]"))),await this.#n}async stop(){if(this.#n==null)return;let{childProcess:e}=await this.#n;e.exitCode==null&&e.signalCode==null&&(this.#n=null,e.kill(),await H(e,"exit"))}async#o(){this.#e.debug&&console.debug("[Query Engine] getting engine commit hash...");let e=await this.#r();this.#e.debug&&console.debug("[Query Engine] got engine commit hash",e);let t=f(this.#e.clientVersion,e);this.#e.debug&&console.debug("[Query Engine] cache directory path",t),await C(t,{recursive:!0});let{binaryTarget:s}=this.#e.platform,n=s==="windows"?".exe":"",o=A(t,`query-engine-${s}${n}`);return this.#e.debug&&console.debug("[Query Engine] binary path",o),(L==="1"||await w(o)===!1)&&await this.#a({commitHash:e,extension:n,engineBinaryPath:o}),o}async#r(){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 s=(await e.json()).devDependencies?.["@prisma/engines-version"];if(!s)throw new Error("Couldn't find engines version in package.json");let n=s.split(".").at(-1);if(!n)throw new Error("Couldn't find commit hash in engines version");return n}async#a(e){let{commitHash:t,extension:s,engineBinaryPath:n}=e,{binaryTarget:o}=this.#e.platform,i=`https://binaries.prisma.sh/all_commits/${t}/${o}/query-engine${s}.gz`;this.#e.debug&&console.debug("[Query Engine] downloading engine from url",i);let a=await fetch(i);if(!a.ok)throw new Error(`Couldn't download engine. URL: ${i}, status code: ${a.status}`);P&&await j(Number(P)),await y(await a.arrayBuffer(),n),this.#e.debug&&console.debug("[Query Engine] downloaded and saved at",n)}#i(e){let t={};for(let[s,n]of Object.entries(e))n!=null&&(t[s]=n);return t}async#s(e,t,s){let{url:n}=await this.#n,o=this.#i(t),i=await fetch(`${n}/transaction/${e}/${s}`,{headers:{...o,"Content-Type":"application/json"},method:"POST"});if(!i.ok)throw await l.fromResponse(i);try{return await i.json()}catch{return{}}}};function G(r,e){if(console.error(r),r instanceof d){E(e,{EngineNotStarted:{reason:{EngineStartupError:{logs:[],msg:r.message}}}},500);return}if(r instanceof l){v(e,r.responseBody,r.statusCode);return}b(e,500)}var d=class extends Error{name="EngineStartError"},l=class r extends Error{constructor(t,s,n){super(`${t}: Query Engine response status ${s}, body: ${n}`);this.action=t;this.statusCode=s;this.responseBody=n}name="EngineHttpError";static async fromResponse(t){let s=new URL(t.url),n=await t.text();return new r(s.pathname,t.status,n)}};export{S as Engine,G as handleEngineError};
|