@prisma/cli-dev 0.7.2 → 0.8.0

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.
@@ -0,0 +1,12 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import{a as o,c as a,f as c}from"./chunk-ZKMEOIRF.js";function $(e){return` - ${e.map(t=>`${o(t.name)}`).join(`
3
+ - `)}`}import{TextPrompt as f}from"@clack/core";import{colorize as r}from"consola/utils";async function C(e){let{confirmationText:t,debug:m}=e;return c?typeof await new f({debug:m,render(){switch(this.state){case"active":case"error":case"initial":{let s=`
4
+ \u{1F9F7} To confirm, type ${a(t)} and press ${r("inverse"," \u23CE ")}:`,h=this.value?.length<=t.length&&t.startsWith(this.value),i=!this.error&&u(this.value,t),n=t.charAt(this.cursor)?r("inverse",t.charAt(this.cursor)):this.valueWithCursor.charAt(this.cursor),p=r("dim",t.slice(this.valueWithCursor.length)),l=i?`${t}${r("reset",r("strikethrough",r("dim",this.value.slice(t.length))))}${n}`:`${this.value}${n}`;return`${s}
5
+
6
+ ${r(i?"greenBright":h?"reset":"redBright",`${r("hidden","_")}> ${l}`)}${p}
7
+ `}case"cancel":return`
8
+ Aborted!
9
+
10
+ `;case"submit":return`
11
+ `;default:return this.state,`
12
+ `}},validate:s=>u(s,t)?void 0:"!"}).prompt()=="string":!0}function u(e,t){return typeof e=="string"&&e.startsWith(t)}export{$ as a,C as b};
@@ -0,0 +1,2 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ var e={debug:{default:!1,description:"Enable debug logging. Defaults to `false`.",required:!1,type:"boolean"}};export{e as a};
@@ -0,0 +1,2 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import{colorize as n}from"consola/utils";function u(r){return n("cyan",r)}function p(r){return n("magenta",r)}function c(r){return n("yellow",r)}function m(r){return n("white",r)}import{colorize as o}from"consola/utils";var f=o("inverse",`${t()}prisma dev${t()}`);function t(r=1){return r<1?"":o("hidden","_".repeat(r))}import{hasTTY as e,isCI as i}from"std-env";var C=!i&&e;export{u as a,p as b,c,m as d,f as e,C as f};
package/dist/index.js CHANGED
@@ -1,38 +1,38 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
- import{runMain as Te}from"citty";import{unstable_startServer as he}from"@prisma/dev";import{defineCommand as Se}from"citty";function I(e){let r,t,o=new Promise((n,p)=>{r=n,t=p}),s=n=>{s=a=null,t(n),e?.onRejected?.(n),e?.onFulfilled?.()},a=n=>{a=s=null,r(n),e?.onResolved?.(n),e?.onFulfilled?.()};return{isFulfilled:()=>a===s,promise:o,reject:n=>s?.(n),resolve:n=>a?.(n)}}import{consola as W,LogLevels as Pe}from"consola";import{process as ye}from"std-env";var N="0.7.2";var d={database:"db-port",server:"port",shadow_database:"shadow-db-port"},_={[d.database]:{alias:"P",description:"Port number the database server will listen on.",required:!1,type:"string"},debug:{default:!1,description:"Enable debug logging. Defaults to `false`.",required:!1,type:"boolean"},name:{alias:"n",default:"default",description:"Name of the server. Helps keep state isolated between different projects. Defaults to `default`.",required:!1,type:"string"},[d.server]:{alias:"p",description:"Main port number the Prisma Dev server will listen on.",required:!1,type:"string"},[d.shadow_database]:{description:"Port number the shadow database server will listen on.",required:!1,type:"string"}},ee=/^[a-zA-Z0-9-_]+$/;function k(e){let{[d.server]:r,[d.database]:t,[d.shadow_database]:o,debug:s,name:a}=e.args,n=t?Number(t):void 0,p=r?Number(r):void 0,c=o?Number(o):void 0;return r&&Number.isNaN(p)?(console.error(`Invalid server port number provided. Please provide a valid port number in \`--${d.server}\`.`),process.exit(1)):t&&Number.isNaN(n)?(console.error(`Invalid database port number provided. Please provide a valid port number in \`--${d.database}\`.`),process.exit(1)):o&&Number.isNaN(c)?(console.error(`Invalid shadow database port number provided. Please provide a valid port number in \`--${d.shadow_database}\`.`),process.exit(1)):p!=null&&p===n?(console.error(`The server port and database port cannot be the same. Please provide different port numbers in \`--${d.server}\` and/or \`--${d.database}\`.`),process.exit(1)):n!=null&&n===c?(console.error(`The database port and shadow database port cannot be the same. Please provide different port numbers in \`--${d.database}\` and/or \`--${d.shadow_database}\`.`),process.exit(1)):p!=null&&p===c?(console.error(`The server port and shadow database port cannot be the same. Please provide different port numbers in \`--${d.server}\` and/or \`--${d.shadow_database}\`.`),process.exit(1)):ee.test(a)?{databasePort:n,debug:s,name:a,serverPort:p,shadowDatabasePort:c}:(console.error("Invalid name provided. The name can only contain letters, numbers, dashes, and underscores. Please provide a valid name in `--name`."),process.exit(1))}import{PortNotAvailableError as ge,ServerAlreadyRunningError as be}from"@prisma/dev";import{consola as V}from"consola";import{process as Q}from"std-env";import{setTimeout as ae}from"timers/promises";import{consola as f}from"consola";import{colorize as l,stripAnsi as de}from"consola/utils";import{hasTTY as pe,isCI as le,process as M}from"std-env";import ce from"yocto-spinner";import{isCancel as re,SelectKeyPrompt as te}from"@clack/core";import{box as oe,colorize as ne}from"consola/utils";import{process as w}from"std-env";var se=[{value:"q",label:"uit"},{value:"h",label:"ttp url"},{value:"t",label:"cp urls"}],$=4;function D(e){let r=new te({debug:e?.debug,options:se,render:ie,signal:e?.abortSignal});return{clearPrompt(){w.stdout.moveCursor(0,-$),w.stdout.cursorTo(0),w.stdout.clearScreenDown()},prompt:r,respond:async t=>{if(re(t)||t==="q")return await e?.onQuit?.();e?.onOption?.[t]?.()}}}function ie(){let e=`${this.options.map(r=>`[${ne("cyan",r.value)}]${r.label}`).join(" ")}`;return oe(e,{style:{borderColor:"blackBright",padding:0}})}var v=l("white",l("bgBlack"," prisma dev ")),U=!le&&pe;function j(e){let r=ce();return{renderContent:ue,renderIntro:()=>me(e,r),renderOutro:()=>Promise.resolve(fe(e)),spinner:r}}async function ue(e){let{abortSignal:r,debug:t,isClosed:o,onQuit:s,server:a,spinner:n}=e;if(n.success(` Great Success! \u{1F609}\u{1F44D}
2
+ import{a as s,b as w,d as c,e as u,f as $}from"./chunk-ZKMEOIRF.js";import{a as _}from"./chunk-XOIFSEIB.js";import{runMain as $e}from"citty";import{unstable_startServer as be}from"@prisma/dev";import{defineCommand as he}from"citty";function M(e){let r,t,o=new Promise((n,p)=>{r=n,t=p}),i=n=>{i=a=null,t(n),e?.onRejected?.(n),e?.onFulfilled?.()},a=n=>{a=i=null,r(n),e?.onResolved?.(n),e?.onFulfilled?.()};return{isFulfilled:()=>a===i,promise:o,reject:n=>i?.(n),resolve:n=>a?.(n)}}import{consola as z,LogLevels as Se}from"consola";import{process as Pe}from"std-env";var k="0.8.0";var d={database:"db-port",server:"port",shadow_database:"shadow-db-port"},D={..._,[d.database]:{alias:"P",description:"Port number the database server will listen on.",required:!1,type:"string"},name:{alias:"n",default:"default",description:"Name of the server. Helps keep state isolated between different projects. Defaults to `default`.",required:!1,type:"string"},[d.server]:{alias:"p",description:"Main port number the Prisma Dev server will listen on.",required:!1,type:"string"},[d.shadow_database]:{description:"Port number the shadow database server will listen on.",required:!1,type:"string"}},re=/^[a-zA-Z0-9-_]+$/;function G(e){let{[d.server]:r,[d.database]:t,[d.shadow_database]:o,debug:i,name:a}=e.args,n=t?Number(t):void 0,p=r?Number(r):void 0,l=o?Number(o):void 0;return r&&Number.isNaN(p)?(console.error(`Invalid server port number provided. Please provide a valid port number in \`--${d.server}\`.`),process.exit(1)):t&&Number.isNaN(n)?(console.error(`Invalid database port number provided. Please provide a valid port number in \`--${d.database}\`.`),process.exit(1)):o&&Number.isNaN(l)?(console.error(`Invalid shadow database port number provided. Please provide a valid port number in \`--${d.shadow_database}\`.`),process.exit(1)):p!=null&&p===n?(console.error(`The server port and database port cannot be the same. Please provide different port numbers in \`--${d.server}\` and/or \`--${d.database}\`.`),process.exit(1)):n!=null&&n===l?(console.error(`The database port and shadow database port cannot be the same. Please provide different port numbers in \`--${d.database}\` and/or \`--${d.shadow_database}\`.`),process.exit(1)):p!=null&&p===l?(console.error(`The server port and shadow database port cannot be the same. Please provide different port numbers in \`--${d.server}\` and/or \`--${d.shadow_database}\`.`),process.exit(1)):re.test(a)?{databasePort:n,debug:i,name:a,serverPort:p,shadowDatabasePort:l}:(console.error("Invalid name provided. The name can only contain letters, numbers, dashes, and underscores. Please provide a valid name in `--name`."),process.exit(1))}import{PortNotAvailableError as ve,ServerAlreadyRunningError as ge}from"@prisma/dev";import{consola as Q}from"consola";import{process as X}from"std-env";import{setTimeout as de}from"timers/promises";import{consola as f}from"consola";import{colorize as v,stripAnsi as pe}from"consola/utils";import{process as U}from"std-env";import le from"yocto-spinner";import{isCancel as te,SelectKeyPrompt as oe}from"@clack/core";import{box as ne,colorize as se}from"consola/utils";import{process as R}from"std-env";var ie=[{value:"q",label:"uit"},{value:"h",label:"ttp url"},{value:"t",label:"cp urls"}],C=4;function L(e){let r=new oe({debug:e?.debug,options:ie,render:ae,signal:e?.abortSignal});return{clearPrompt(){R.stdout.moveCursor(0,-C),R.stdout.cursorTo(0),R.stdout.clearScreenDown()},prompt:r,respond:async t=>{if(te(t)||t==="q")return await e?.onQuit?.();e?.onOption?.[t]?.()}}}function ae(){let e=`${this.options.map(r=>`[${se("cyan",r.value)}]${r.label}`).join(" ")}`;return ne(e,{style:{borderColor:"blackBright",padding:0}})}function F(e){let r=le();return{renderContent:me,renderIntro:()=>ce(e,r),renderOutro:()=>Promise.resolve(ue(e)),spinner:r}}async function me(e){let{abortSignal:r,debug:t,isClosed:o,onQuit:i,server:a,spinner:n}=e;if(n.success(` Great Success! \u{1F609}\u{1F44D}
3
3
 
4
- Your ${v} server ${i(a.name)} is ready and listening on ports ${C([new URL(a.http.url).port,new URL(a.database.connectionString).port,new URL(a.shadowDatabase.connectionString).port])}.`),!U){f.log(G(a)),f.log(L(a));return}for(;!o();){let{clearPrompt:p,prompt:c,respond:y}=D({abortSignal:r,debug:t,onOption:{h:()=>f.log(G(a)),t:()=>f.log(L(a))},onQuit:s}),g=await c.prompt();p(),r.aborted||await y(g)}}async function me(e,r){r.start(` Starting ${v} server ${i(e)}...${`
5
- `.repeat($+3)}`),U&&await ae(250)}function fe(e){f.log(`\u{1F44B} Buh Bye!
4
+ Your ${u} server ${s(a.name)} is ready and listening on ports ${O([new URL(a.http.url).port,new URL(a.database.connectionString).port,new URL(a.shadowDatabase.connectionString).port])}.`),!$){f.log(B(a)),f.log(j(a));return}for(;!o();){let{clearPrompt:p,prompt:l,respond:y}=L({abortSignal:r,debug:t,onOption:{h:()=>f.log(B(a)),t:()=>f.log(j(a))},onQuit:i}),g=await l.prompt();p(),r.aborted||await y(g)}}async function ce(e,r){r.start(` Starting ${u} server ${s(e)}...${`
5
+ `.repeat(C+3)}`),$&&await de(250)}function ue(e){f.log(`\u{1F44B} Buh Bye!
6
6
 
7
- Your ${v} server ${i(e)} has been closed successfully.
8
- `)}function G(e){return`\u{1F50C} To connect to your local Prisma Postgres database via HTTP + Prisma ORM
7
+ Your ${u} server ${s(e)} has been closed successfully.
8
+ `)}function B(e){return`\u{1F50C} To connect to your local Prisma Postgres database via HTTP + Prisma ORM
9
9
  use the following connection string:
10
10
 
11
- ${q(`${F("\u{1F4C4} .env:")}
11
+ ${V(`${q("\u{1F4C4} .env:")}
12
12
 
13
- ${R("DATABASE_URL",ve(e.ppg.url))}`)}
13
+ ${x("DATABASE_URL",fe(e.ppg.url))}`)}
14
14
 
15
- \u2728 The ${i("api_key")} above does not contain any sensitive information.`}function L(e){return`\u{1F50C} To connect to your local Prisma Postgres database via TCP + Prisma ORM
15
+ \u2728 The ${s("api_key")} above does not contain any sensitive information.`}function j(e){return`\u{1F50C} To connect to your local Prisma Postgres database via TCP + Prisma ORM
16
16
  use the following connection strings:
17
17
 
18
- ${q(`${F("\u{1F4C4} .env:")}
18
+ ${V(`${q("\u{1F4C4} .env:")}
19
19
 
20
- ${R("DATABASE_URL",B(e.database.prismaORMConnectionString))}
20
+ ${x("DATABASE_URL",H(e.database.prismaORMConnectionString))}
21
21
 
22
- ${R("SHADOW_DATABASE_URL",B(e.shadowDatabase.prismaORMConnectionString))}`)}
22
+ ${x("SHADOW_DATABASE_URL",H(e.shadowDatabase.prismaORMConnectionString))}`)}
23
23
 
24
- \u{1F418} You can also use the TCP ${i("DATABASE_URL")} with the ${i("pg")} or ${i("postgres.js")} JavaScript drivers!
24
+ \u{1F418} You can also use the TCP ${s("DATABASE_URL")} with the ${s("pg")} or ${s("postgres.js")} JavaScript drivers!
25
25
 
26
- Set the maximum number of connections to ${i(1)}, connect timeout to ${i(0)} and
27
- idle timeout to the smallest positive value supported.`}function C(e){if(e.length===0)return"";let r=[...e].map(Number).sort();return r.length>1&&r.every((t,o)=>o===0||t===r[o-1]+1)?`${i(r[0])}-${i(r.at(-1))}`:e.map(i).join(", ")}function R(e,r){return l("bgBlack",`${i(e)}="${r}"`)}function ve(e){return e=new URL(e),`${H(e.protocol)}//${i(e.hostname)}:${i(e.port)}${m(e.pathname)}${m(e.search)}`}function B(e){return e=new URL(e),`${H(e.protocol)}${m(`//${e.username}:${e.password}@`)}${i(e.hostname)}${m(":")}${i(e.port)}${m(e.pathname)}${m(e.search)}`}function i(e){return l("cyan",e)}function H(e){return l("magenta",e)}function m(e){return l("white",e)}function F(e){return l("italic",l("dim",l("greenBright",`# ${e}`)))}function q(e){return l("bgBlack",`${T()}
26
+ Set the maximum number of connections to ${s(1)}, connect timeout to ${s(0)} and
27
+ idle timeout to the smallest positive value supported.`}function O(e){if(e.length===0)return"";let r=[...e].map(Number).sort();return r.length>1&&r.every((t,o)=>o===0||t===r[o-1]+1)?`${s(r[0])}-${s(r.at(-1))}`:e.map(s).join(", ")}function x(e,r){return v("bgBlack",`${s(e)}="${r}"`)}function fe(e){return e=new URL(e),`${w(e.protocol)}//${s(e.hostname)}:${s(e.port)}${c(e.pathname)}${c(e.search)}`}function H(e){return e=new URL(e),`${w(e.protocol)}${c(`//${e.username}:${e.password}@`)}${s(e.hostname)}${c(":")}${s(e.port)}${c(e.pathname)}${c(e.search)}`}function q(e){return v("italic",v("dim",v("greenBright",`# ${e}`)))}function V(e){return v("bgBlack",`${T()}
28
28
  ${e.split(`
29
- `).map(r=>` ${r}${T(de(r).length+1)}`).join(`
29
+ `).map(r=>` ${r}${T(pe(r).length+1)}`).join(`
30
30
  `)}
31
- ${T()}`)}function T(e=0){return e%=M.stdout.columns," ".repeat(M.stdout.columns-e)}async function b(e,r,t){if(e instanceof be)try{let s=await e.server;if(!s)return await b("Something went wrong, try again!",r,t);r.warning(` Skipped! \u{1F60C}
31
+ ${T()}`)}function T(e=0){return e%=U.stdout.columns," ".repeat(U.stdout.columns-e)}async function b(e,r,t){if(e instanceof ge)try{let i=await e.server;if(!i)return await b("Something went wrong, try again!",r,t);r.warning(` Skipped! \u{1F60C}
32
32
 
33
- Your ${v} server ${i(s.name)} is already running and listening on ports ${C([s.port,s.databasePort,s.shadowDatabasePort])}.
33
+ Your ${u} server ${s(i.name)} is already running and listening on ports ${O([i.port,i.databasePort,i.shadowDatabasePort])}.
34
34
 
35
- To start a different server, use the ${`${i("-n")}/${i("--name")}`} flag with another name.
36
- `);return}catch(s){return await b(s,r,t)}let{args:o}=t;throw V.error(e instanceof ge?`Prisma Dev Error: port number \`${e.port}\` is already in use. Please pass a different port number in the \`--${o.port===String(e.port)?"port":o.databasePort===String(e.port)?"database":"shadow_database"}\` option.`:e),Q.exitCode||=1,e}function X(e){Q.on?.("uncaughtException",r=>{if("code"in r&&r.code==="ECONNRESET"){e?.debug&&V.error("uncaught ECONNRESET");return}e?.onError?.(r)})}import{consola as h}from"consola";import{process as S}from"std-env";function K(e){let r={shutdownAlreadyStarted:!1};S.once?.("SIGINT",Y("SIGINT",e,r)),S.once?.("SIGTERM",Y("SIGTERM",e,r))}function Y(e,r,t){let{debug:o,onFailure:s,onSuccess:a,server:n}=r;return()=>{if(t.shutdownAlreadyStarted){o&&h.debug(`Received ${e} signal, ignoring.`);return}t.shutdownAlreadyStarted=!0,o&&h.debug(`${e} signal receieved.`),o&&h.log(`
35
+ To start a different server, use the ${`${s("-n")}/${s("--name")}`} flag with another name.
36
+ `);return}catch(i){return await b(i,r,t)}let{args:o}=t;throw Q.error(e instanceof ve?`Prisma Dev Error: port number \`${e.port}\` is already in use. Please pass a different port number in the \`--${o.port===String(e.port)?"port":o.databasePort===String(e.port)?"database":"shadow_database"}\` option.`:e),X.exitCode||=1,e}function K(e){X.on?.("uncaughtException",r=>{if("code"in r&&r.code==="ECONNRESET"){e?.debug&&Q.error("uncaught ECONNRESET");return}e?.onError?.(r)})}import{consola as h}from"consola";import{process as S}from"std-env";function Y(e){let r={shutdownAlreadyStarted:!1};S.once?.("SIGINT",W("SIGINT",e,r)),S.once?.("SIGTERM",W("SIGTERM",e,r))}function W(e,r,t){let{debug:o,onFailure:i,onSuccess:a,server:n}=r;return()=>{if(t.shutdownAlreadyStarted){o&&h.debug(`Received ${e} signal, ignoring.`);return}t.shutdownAlreadyStarted=!0,o&&h.debug(`${e} signal receieved.`),o&&h.log(`
37
37
  Closing Prisma Dev...
38
- `),S.exitCode=e==="SIGINT"?130:143,n.close().then(()=>{o&&h.debug("Prisma Dev server closed."),e==="SIGINT"&&(S.exitCode=0),a()}).catch(s)}}var we={description:"Spin up a local Prisma Postgres database",name:"dev",version:N},P="\v",x=Se({args:_,meta:we,run:async e=>{let{subCommands:r}=e.cmd,t=r?e.rawArgs.find(u=>!u.startsWith("-")):void 0;if(t&&t!==P&&t in r)return;let{debug:o,name:s,serverPort:a,...n}=k(e),{renderContent:p,renderIntro:c,renderOutro:y,spinner:g}=j(s);try{let u=await $e({...n,debug:o,name:s,port:a,renderIntro:c}),O=new AbortController,{isFulfilled:z,promise:J,reject:A,resolve:E}=I({onFulfilled:()=>O.abort()});K({debug:o,onFailure:A,onSuccess:E,server:u}),X({debug:o,onError:A}),await p({abortSignal:O.signal,debug:o,isClosed:z,onQuit:async()=>{await u.close(),E()},server:u,spinner:g}),await J,await y(),ye.exitCode||=0}catch(u){await b(u,g,e)}},setup(e){e.args.debug&&(W.level=Pe.debug),W.options.formatOptions.date=!1},subCommands:{[P]:{},ls:()=>import("./list-4ABJMPY2.js").then(e=>e.ListCommand)}});async function $e(e){let{renderIntro:r,...t}=e,[,o]=await Promise.allSettled([e.renderIntro(),he({...t,persistenceMode:"stateful"})]);if(o.status==="rejected")throw o.reason;return o.value}async function ir(e,r){let[t]=e;t==="-v"&&(e[0]="--version"),t&&!(t in x.subCommands)&&t!=="--help"&&t!=="-h"&&t!=="--version"&&t!=="-v"&&e.unshift(P),await Te(x,{rawArgs:e})}export{ir as run};
38
+ `),S.exitCode=e==="SIGINT"?130:143,n.close().then(()=>{o&&h.debug("Prisma Dev server closed."),e==="SIGINT"&&(S.exitCode=0),a()}).catch(i)}}var ye={description:"Spin up a local Prisma Postgres database",name:"prisma dev",version:k},P="\v",A=he({args:D,meta:ye,run:async e=>{let{subCommands:r}=e.cmd,t=r?e.rawArgs.find(m=>!m.startsWith("-")):void 0;if(t&&t!==P&&t in r)return;let{debug:o,name:i,serverPort:a,...n}=G(e),{renderContent:p,renderIntro:l,renderOutro:y,spinner:g}=F(i);try{let m=await we({...n,debug:o,name:i,port:a,renderIntro:l}),E=new AbortController,{isFulfilled:J,promise:Z,reject:I,resolve:N}=M({onFulfilled:()=>E.abort()});Y({debug:o,onFailure:I,onSuccess:N,server:m}),K({debug:o,onError:I}),await p({abortSignal:E.signal,debug:o,isClosed:J,onQuit:async()=>{await m.close(),N()},server:m,spinner:g}),await Z,await y(),Pe.exitCode||=0}catch(m){await b(m,g,e)}},setup(e){e.args.debug&&(z.level=Se.debug),z.options.formatOptions.date=!1},subCommands:{[P]:{},ls:()=>import("./list-K5DAVLAS.js").then(e=>e.ListCommand),rm:()=>import("./remove-6QJTZ5SK.js").then(e=>e.RemoveCommand),stop:()=>import("./stop-CRL2UWAK.js").then(e=>e.StopCommand)}});async function we(e){let{renderIntro:r,...t}=e,[,o]=await Promise.allSettled([e.renderIntro(),be({...t,persistenceMode:"stateful"})]);if(o.status==="rejected")throw o.reason;return o.value}async function mr(e,r){let[t]=e;t==="-v"&&(e[0]="--version"),t&&!(t in A.subCommands)&&t!=="--help"&&t!=="-h"&&t!=="--version"&&t!=="-v"&&e.unshift(P),await $e(A,{rawArgs:e})}export{mr as run};
@@ -0,0 +1,3 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import{a}from"./chunk-XOIFSEIB.js";import{ServerState as i}from"@prisma/dev/internal/state";import{defineCommand as m}from"citty";function o(t,n=t){return`\x1B]8;;${t.toString()}\x07${n.toString()}\x1B]8;;\x07`}import{consola as c}from"consola";import u from"table-layout";var l={...a},p={description:"List available servers",name:"ls"},U=m({args:l,meta:p,run:async t=>{let n=await i.scan({debug:t.args.debug}),e=new u([{name:s("name"),status:s("status"),urls:s("urls")},...n.map(r=>({name:r.name,status:r.status,urls:g(r)}))]);c.log(e.toString())}});function s(t){return`\x1B[1m${t}\x1B[0m`}function g(t){if(t.status!=="running")return"";let n=f(t),e=S(t),r=d(t);return[n?`${s("DATABASE_URL")}: ${n}`:null,e?`${s("TCP")}: ${e}`:null,r?`${s("Terminal")}: ${r}`:null].filter(Boolean).join(`
3
+ `)}function f(t){let{url:n}=t.exports?.ppg||{};if(!n)return"";let e=new URL(n),r=e.searchParams.get("api_key");return e.searchParams.set("api_key",`${r.slice(0,4)}...${r.slice(-4)}`),o(n,e)}function S(t){let{connectionString:n,prismaORMConnectionString:e}=t.exports?.database||{};if(!e&&!n)return"";let r=new URL(e||n);return o(r,`${r.protocol}//...@${r.host}/...`)}function d(t){let{connectionString:n,terminalCommand:e}=t.exports?.database||{};if(!n||!e)return"";let r=new URL(n);return o(e,`...psql -h ${r.hostname} -p ${r.port} ...`)}export{U as ListCommand};
@@ -0,0 +1,9 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import{a as s,b as f}from"./chunk-D5MRRGDK.js";import{a as m,b as l,e}from"./chunk-ZKMEOIRF.js";import{a}from"./chunk-XOIFSEIB.js";import{deleteServer as u,isServerRunning as d,ServerState as C}from"@prisma/dev/internal/state";import{defineCommand as y}from"citty";import{consola as r}from"consola";import{process as c}from"std-env";var S={...a,force:{default:!1,description:"Stops any running servers before removing them. Default is `false`, which would fail the command if any server is running.",required:!1,type:"boolean"},name:{description:"Name(s)/pattern(s) of the server(s) to remove",required:!0,type:"positional",valueHint:"glob"}},h={description:"Remove servers",name:"rm"},P=y({args:S,meta:h,run:async n=>{let{debug:i,force:p,name:g}=n.args,v=g.split(","),o=await C.scan({debug:i,globs:v});if(o.length===0)return r.log(`\u26A0\uFE0F No ${e} servers found to remove.
3
+ `);if(!p&&o.some(d)){r.log(`\u{1F6AB} Some ${e} servers are currently running:
4
+
5
+ ${s(o.filter(d))}
6
+
7
+ Use the ${l("--force")} flag to stop and remove them.`),c.exitCode||=1;return}if(r.log(`\u{1F5D1}\uFE0F Removing the following ${e} servers:
8
+
9
+ ${s(o)}`),!await f({confirmationText:"i will lose local data",debug:n.args.debug}))return;(await Promise.allSettled(o.map(async t=>{await u(t,i),r.log(`\u{1F9F9} Removed ${e} server ${m(t.name)}.`)}))).some(t=>t.status==="rejected")&&(r.error(`Potentially failed to remove some ${e} servers.`),c.exitCode||=1),r.log("")}});export{P as RemoveCommand};
@@ -0,0 +1,5 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import{a,b as m}from"./chunk-D5MRRGDK.js";import{a as n,e}from"./chunk-ZKMEOIRF.js";import{a as i}from"./chunk-XOIFSEIB.js";import{isServerRunning as c,killServer as d,ServerState as g}from"@prisma/dev/internal/state";import{defineCommand as S}from"citty";import{consola as o}from"consola";var u={...i,name:{description:"Name(s)/pattern(s) of the server(s) to stop",required:!0,type:"positional",valueHint:"glob"}},v={description:"Stop servers",name:"stop"},D=S({args:u,meta:v,run:async p=>{let{debug:t,name:l}=p.args,f=l.split(","),s=(await g.scan({debug:t,globs:f})).filter(c);if(s.length===0)return o.log(`\u26A0\uFE0F No ${e} servers found to stop.
3
+ `);if(o.log(`\u26B0\uFE0F Stopping the following ${e} servers:
4
+
5
+ ${a(s)}`),!await m({confirmationText:"i will interrupt sessions",debug:t}))return;(await Promise.allSettled(s.map(async r=>{await d(r,t),o.log(`\u{1F480} Stopped ${e} server ${n(r.name)}.`)}))).some(r=>r.status==="rejected")&&(o.error(`Potentially failed to stop some ${e} servers.`),process.exitCode||=1),o.log("")}});export{D as StopCommand};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@prisma/cli-dev",
3
- "version": "0.7.2",
3
+ "version": "0.8.0",
4
4
  "description": "Dev CLI for Prisma",
5
5
  "type": "module",
6
6
  "sideEffects": false,
@@ -36,8 +36,8 @@
36
36
  "tsup": "8.5.0",
37
37
  "typescript": "5.8.3",
38
38
  "vitest": "3.1.4",
39
- "common-stuff": "^0.0.0",
40
- "common-cli-utils": "^0.0.0"
39
+ "common-cli-utils": "^0.0.0",
40
+ "common-stuff": "^0.0.0"
41
41
  },
42
42
  "dependencies": {
43
43
  "@clack/core": "0.5.0",
@@ -46,7 +46,7 @@
46
46
  "std-env": "3.9.0",
47
47
  "table-layout": "4.1.1",
48
48
  "yocto-spinner": "1.0.0",
49
- "@prisma/dev": "0.10.0"
49
+ "@prisma/dev": "0.11.0"
50
50
  },
51
51
  "scripts": {
52
52
  "build": "tsup",
@@ -1,3 +0,0 @@
1
- import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
- import{ServerState as a}from"@prisma/dev/internal/state";import{defineCommand as i}from"citty";function o(t,n=t){return`\x1B]8;;${t.toString()}\x07${n.toString()}\x1B]8;;\x07`}import l from"table-layout";var c={debug:{default:!1,description:"Enable debug logging. Defaults to `false`.",required:!1,type:"boolean"}},u={description:"List available servers",name:"list"},L=i({args:c,meta:u,run:async t=>{let n=await a.scan({debug:t.args.debug}),r=new l([{name:s("name"),status:s("status"),urls:s("urls")},...n.map(e=>({name:e.name,status:e.status,urls:m(e)}))]);console.log(r.toString())}});function s(t){return`\x1B[1m${t}\x1B[0m`}function m(t){if(t.status!=="running")return"";let n=g(t),r=p(t),e=f(t);return[n?`${s("DATABASE_URL")}: ${n}`:null,r?`${s("TCP")}: ${r}`:null,e?`${s("Terminal")}: ${e}`:null].filter(Boolean).join(`
3
- `)}function g(t){let{url:n}=t.exports?.ppg||{};if(!n)return"";let r=new URL(n),e=r.searchParams.get("api_key");return r.searchParams.set("api_key",`${e.slice(0,4)}...${e.slice(-4)}`),o(n,r)}function p(t){let{connectionString:n,prismaORMConnectionString:r}=t.exports?.database||{};if(!r&&!n)return"";let e=new URL(r||n);return o(e,`${e.protocol}//...@${e.host}/...`)}function f(t){let{connectionString:n,terminalCommand:r}=t.exports?.database||{};if(!n||!r)return"";let e=new URL(n);return o(r,`...psql -h ${e.hostname} -p ${e.port} ...`)}export{L as ListCommand};