@prisma/cli-dev 0.6.0 → 0.7.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.
Files changed (2) hide show
  1. package/dist/index.js +20 -20
  2. package/package.json +2 -2
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 $e}from"citty";import{unstable_startServer as Se}from"@prisma/dev";import{defineCommand as Pe}from"citty";function E(e){let r,t,o=new Promise((n,p)=>{r=n,t=p}),i=n=>{i=d=null,t(n),e?.onRejected?.(n),e?.onFulfilled?.()},d=n=>{d=i=null,r(n),e?.onResolved?.(n),e?.onFulfilled?.()};return{isFulfilled:()=>d===i,promise:o,reject:n=>i?.(n),resolve:n=>d?.(n)}}import{consola as K,LogLevels as we}from"consola";import{process as ye}from"std-env";var O="0.6.0";import{DEFAULT_DATABASE_PORT as _,DEFAULT_SERVER_PORT as I,DEFAULT_SHADOW_DATABASE_PORT as D}from"@prisma/dev";var a={database:"db-port",server:"port",shadow_database:"shadow-db-port"},N={[a.database]:{alias:"P",description:`Port number the database server will listen on. Defaults to \`${_}\`.`,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"},[a.server]:{alias:"p",description:`Main port number the Prisma Dev server will listen on. Defaults to \`${I}\`.`,required:!1,type:"string"},[a.shadow_database]:{description:`Port number the shadow database server will listen on. Defaults to \`${D}\`.`,required:!1,type:"string"}},re=/^[a-zA-Z0-9-_]+$/;function k(e){let{[a.server]:r,[a.database]:t,[a.shadow_database]:o,debug:i,name:d}=e.args,n=t?Number(t):_,p=r?Number(r):I,l=o?Number(o):D;return r&&isNaN(p)?(console.error(`Invalid server port number provided. Please provide a valid port number in \`--${a.server}\`.`),process.exit(1)):t&&isNaN(n)?(console.error(`Invalid database port number provided. Please provide a valid port number in \`--${a.database}\`.`),process.exit(1)):o&&isNaN(l)?(console.error(`Invalid shadow database port number provided. Please provide a valid port number in \`--${a.shadow_database}\`.`),process.exit(1)):p===n?(console.error(`The server port and database port cannot be the same. Please provide different port numbers in \`--${a.server}\` and/or \`--${a.database}\`.`),process.exit(1)):n===l?(console.error(`The database port and shadow database port cannot be the same. Please provide different port numbers in \`--${a.database}\` and/or \`--${a.shadow_database}\`.`),process.exit(1)):p===l?(console.error(`The server port and shadow database port cannot be the same. Please provide different port numbers in \`--${a.server}\` and/or \`--${a.shadow_database}\`.`),process.exit(1)):re.test(d)?{databasePort:n,debug:i,name:d,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 be,ServerAlreadyRunningError as he}from"@prisma/dev";import{consola as Q}from"consola";import{process as W}from"std-env";import{setTimeout as de}from"timers/promises";import{consola as f}from"consola";import{colorize as c,stripAnsi as pe}from"consola/utils";import{hasTTY as ce,isCI as le,process as M}from"std-env";import ue 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 S}from"std-env";var ie=[{value:"q",label:"uit"},{value:"h",label:"ttp url"},{value:"t",label:"cp urls"}],P=4;function L(e){let r=new oe({options:ie,render:ae,signal:e?.abortSignal});return{clearPrompt(){S.stdout.moveCursor(0,-P),S.stdout.cursorTo(0),S.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}})}var v=c("white",c("bgBlack"," prisma dev ")),j=!le&&ce;function H(e){let r=ue();return{renderContent:me,renderIntro:()=>fe(e,r),renderOutro:()=>Promise.resolve(ve(e)),spinner:r}}async function me(e){let{abortSignal:r,isClosed:t,onQuit:o,server:i,spinner:d}=e;if(d.success(` Great Success! \u{1F609}\u{1F44D}
2
+ import{runMain as Pe}from"citty";import{unstable_startServer as ge}from"@prisma/dev";import{defineCommand as be}from"citty";function A(e){let r,t,n=new Promise((s,p)=>{r=s,t=p}),o=s=>{o=d=null,t(s),e?.onRejected?.(s),e?.onFulfilled?.()},d=s=>{d=o=null,r(s),e?.onResolved?.(s),e?.onFulfilled?.()};return{isFulfilled:()=>d===o,promise:n,reject:s=>o?.(s),resolve:s=>d?.(s)}}import{consola as Y,LogLevels as he}from"consola";import{process as Se}from"std-env";var E="0.7.0";var a={database:"db-port",server:"port",shadow_database:"shadow-db-port"},I={[a.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"},[a.server]:{alias:"p",description:"Main port number the Prisma Dev server will listen on.",required:!1,type:"string"},[a.shadow_database]:{description:"Port number the shadow database server will listen on.",required:!1,type:"string"}},J=/^[a-zA-Z0-9-_]+$/;function _(e){let{[a.server]:r,[a.database]:t,[a.shadow_database]:n,debug:o,name:d}=e.args,s=t?Number(t):void 0,p=r?Number(r):void 0,l=n?Number(n):void 0;return r&&Number.isNaN(p)?(console.error(`Invalid server port number provided. Please provide a valid port number in \`--${a.server}\`.`),process.exit(1)):t&&Number.isNaN(s)?(console.error(`Invalid database port number provided. Please provide a valid port number in \`--${a.database}\`.`),process.exit(1)):n&&Number.isNaN(l)?(console.error(`Invalid shadow database port number provided. Please provide a valid port number in \`--${a.shadow_database}\`.`),process.exit(1)):p!=null&&p===s?(console.error(`The server port and database port cannot be the same. Please provide different port numbers in \`--${a.server}\` and/or \`--${a.database}\`.`),process.exit(1)):s!=null&&s===l?(console.error(`The database port and shadow database port cannot be the same. Please provide different port numbers in \`--${a.database}\` and/or \`--${a.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 \`--${a.server}\` and/or \`--${a.shadow_database}\`.`),process.exit(1)):J.test(d)?{databasePort:s,debug:o,name:d,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 fe,ServerAlreadyRunningError as ve}from"@prisma/dev";import{consola as F}from"consola";import{process as q}from"std-env";import{setTimeout as se}from"timers/promises";import{consola as f}from"consola";import{colorize as c,stripAnsi as ie}from"consola/utils";import{hasTTY as ae,isCI as de,process as k}from"std-env";import pe from"yocto-spinner";import{isCancel as Z,SelectKeyPrompt as ee}from"@clack/core";import{box as re,colorize as te}from"consola/utils";import{process as S}from"std-env";var oe=[{value:"q",label:"uit"},{value:"h",label:"ttp url"},{value:"t",label:"cp urls"}],w=4;function N(e){let r=new ee({options:oe,render:ne,signal:e?.abortSignal});return{clearPrompt(){S.stdout.moveCursor(0,-w),S.stdout.cursorTo(0),S.stdout.clearScreenDown()},prompt:r,respond:async t=>{if(Z(t)||t==="q")return await e?.onQuit?.();e?.onOption?.[t]?.()}}}function ne(){let e=`${this.options.map(r=>`[${te("cyan",r.value)}]${r.label}`).join(" ")}`;return re(e,{style:{borderColor:"blackBright",padding:0}})}var v=c("white",c("bgBlack"," prisma dev ")),L=!de&&ae;function B(e){let r=pe();return{renderContent:ce,renderIntro:()=>le(e,r),renderOutro:()=>Promise.resolve(ue(e)),spinner:r}}async function ce(e){let{abortSignal:r,isClosed:t,onQuit:n,server:o,spinner:d}=e;if(d.success(` Great Success! \u{1F609}\u{1F44D}
3
3
 
4
- Your ${v} server ${s(i.name)} is ready and listening on ports ${T([new URL(i.http.url).port,new URL(i.database.connectionString).port,new URL(i.shadowDatabase.connectionString).port])}.`),!j){f.log(G(i)),f.log(U(i));return}for(;!t();){let{clearPrompt:n,prompt:p,respond:l}=L({abortSignal:r,onOption:{h:()=>f.log(G(i)),t:()=>f.log(U(i))},onQuit:o}),h=await p.prompt();n(),await l(h)}}async function fe(e,r){r.start(` Starting ${v} server ${s(e)}...${`
5
- `.repeat(P+3)}`),j&&await de(250)}function ve(e){f.log(`\u{1F44B} Buh Bye!
4
+ Your ${v} server ${i(o.name)} is ready and listening on ports ${$([new URL(o.http.url).port,new URL(o.database.connectionString).port,new URL(o.shadowDatabase.connectionString).port])}.`),!L){f.log(D(o)),f.log(M(o));return}for(;!t();){let{clearPrompt:s,prompt:p,respond:l}=N({abortSignal:r,onOption:{h:()=>f.log(D(o)),t:()=>f.log(M(o))},onQuit:n}),h=await p.prompt();s(),await l(h)}}async function le(e,r){r.start(` Starting ${v} server ${i(e)}...${`
5
+ `.repeat(w+3)}`),L&&await se(250)}function ue(e){f.log(`\u{1F44B} Buh Bye!
6
6
 
7
- Your ${v} server ${s(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 ${v} server ${i(e)} has been closed successfully.
8
+ `)}function D(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(`${V("\u{1F4C4} .env:")}
11
+ ${H(`${j("\u{1F4C4} .env:")}
12
12
 
13
- ${y("DATABASE_URL",ge(e.ppg.url))}`)}
13
+ ${P("DATABASE_URL",me(e.ppg.url))}`)}
14
14
 
15
- \u2728 The ${s("api_key")} above does not contain any sensitive information.`}function U(e){return`\u{1F50C} To connect to your local Prisma Postgres database via TCP + Prisma ORM
15
+ \u2728 The ${i("api_key")} above does not contain any sensitive information.`}function M(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(`${V("\u{1F4C4} .env:")}
18
+ ${H(`${j("\u{1F4C4} .env:")}
19
19
 
20
- ${y("DATABASE_URL",B(e.database.prismaORMConnectionString))}
20
+ ${P("DATABASE_URL",G(e.database.prismaORMConnectionString))}
21
21
 
22
- ${y("SHADOW_DATABASE_URL",B(e.shadowDatabase.prismaORMConnectionString))}`)}
22
+ ${P("SHADOW_DATABASE_URL",G(e.shadowDatabase.prismaORMConnectionString))}`)}
23
23
 
24
- \u{1F418} You can also use the TCP ${s("DATABASE_URL")} with the ${s("pg")} or ${s("postgres.js")} JavaScript drivers!
24
+ \u{1F418} You can also use the TCP ${i("DATABASE_URL")} with the ${i("pg")} or ${i("postgres.js")} JavaScript drivers!
25
25
 
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 T(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 y(e,r){return c("bgBlack",`${s(e)}="${r}"`)}function ge(e){return e=new URL(e),`${F(e.protocol)}//${s(e.hostname)}:${s(e.port)}${m(e.pathname)}${m(e.search)}`}function B(e){return e=new URL(e),`${F(e.protocol)}${m(`//${e.username}:${e.password}@`)}${s(e.hostname)}${m(":")}${s(e.port)}${m(e.pathname)}${m(e.search)}`}function s(e){return c("cyan",e)}function F(e){return c("magenta",e)}function m(e){return c("white",e)}function V(e){return c("italic",c("dim",c("greenBright",`# ${e}`)))}function q(e){return c("bgBlack",`${w()}
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 $(e){if(e.length===0)return"";let r=[...e].map(Number).sort();return r.length>1&&r.every((t,n)=>n===0||t===r[n-1]+1)?`${i(r[0])}-${i(r.at(-1))}`:e.map(i).join(", ")}function P(e,r){return c("bgBlack",`${i(e)}="${r}"`)}function me(e){return e=new URL(e),`${U(e.protocol)}//${i(e.hostname)}:${i(e.port)}${m(e.pathname)}${m(e.search)}`}function G(e){return e=new URL(e),`${U(e.protocol)}${m(`//${e.username}:${e.password}@`)}${i(e.hostname)}${m(":")}${i(e.port)}${m(e.pathname)}${m(e.search)}`}function i(e){return c("cyan",e)}function U(e){return c("magenta",e)}function m(e){return c("white",e)}function j(e){return c("italic",c("dim",c("greenBright",`# ${e}`)))}function H(e){return c("bgBlack",`${y()}
28
28
  ${e.split(`
29
- `).map(r=>` ${r}${w(pe(r).length+1)}`).join(`
29
+ `).map(r=>` ${r}${y(ie(r).length+1)}`).join(`
30
30
  `)}
31
- ${w()}`)}function w(e=0){return e%=M.stdout.columns," ".repeat(M.stdout.columns-e)}async function g(e,r){if(e instanceof he)try{let t=await e.server;if(!t)return await g("Something went wrong, try again!",r);r.warning(` Skipped! \u{1F60C}
31
+ ${y()}`)}function y(e=0){return e%=k.stdout.columns," ".repeat(k.stdout.columns-e)}async function g(e,r,t){if(e instanceof ve)try{let o=await e.server;if(!o)return await g("Something went wrong, try again!",r,t);r.warning(` Skipped! \u{1F60C}
32
32
 
33
- Your ${v} server ${s(t.name)} is already running and listening on ports ${T([t.port,t.databasePort,t.shadowDatabasePort])}.
33
+ Your ${v} server ${i(o.name)} is already running and listening on ports ${$([o.port,o.databasePort,o.shadowDatabasePort])}.
34
34
 
35
- To start a different server, use the ${`${s("-n")}/${s("--name")}`} flag with another name.
36
- `);return}catch(t){return await g(t,r)}throw Q.error(e instanceof be?`Prisma Dev Error: port number \`${e.port}\` is already in use. Please pass a different port number in the \`--${a[e.service]}\` option.`:e),W.exitCode||=1,e}function X(e){W.on?.("uncaughtException",r=>{if("code"in r&&r.code==="ECONNRESET"){e?.debug&&Q.error("uncaught ECONNRESET");return}e?.onError?.(r)})}function z(e){let r={shutdownAlreadyStarted:!1};process.once("SIGINT",Y("SIGINT",e,r)),process.once("SIGTERM",Y("SIGTERM",e,r))}function Y(e,r,t){let{debug:o,onFailure:i,onSuccess:d,server:n}=r;return()=>{if(t.shutdownAlreadyStarted){o&&console.debug(`Received ${e} signal, ignoring.`);return}t.shutdownAlreadyStarted=!0,o&&console.debug(`${e} signal receieved.`),console.log(`
35
+ To start a different server, use the ${`${i("-n")}/${i("--name")}`} flag with another name.
36
+ `);return}catch(o){return await g(o,r,t)}let{args:n}=t;throw F.error(e instanceof fe?`Prisma Dev Error: port number \`${e.port}\` is already in use. Please pass a different port number in the \`--${n.port===String(e.port)?"port":n.databasePort===String(e.port)?"database":"shadow_database"}\` option.`:e),q.exitCode||=1,e}function V(e){q.on?.("uncaughtException",r=>{if("code"in r&&r.code==="ECONNRESET"){e?.debug&&F.error("uncaught ECONNRESET");return}e?.onError?.(r)})}function X(e){let r={shutdownAlreadyStarted:!1};process.once("SIGINT",Q("SIGINT",e,r)),process.once("SIGTERM",Q("SIGTERM",e,r))}function Q(e,r,t){let{debug:n,onFailure:o,onSuccess:d,server:s}=r;return()=>{if(t.shutdownAlreadyStarted){n&&console.debug(`Received ${e} signal, ignoring.`);return}t.shutdownAlreadyStarted=!0,n&&console.debug(`${e} signal receieved.`),console.log(`
37
37
  Closing Prisma Dev...
38
- `),process.exitCode=e==="SIGINT"?130:143,n.close().then(()=>{o&&console.debug("Prisma Dev server closed."),e==="SIGINT"&&(process.exitCode=0),d()}).catch(i)}}var Te={description:"Spin up a local Prisma Postgres database",name:"dev",version:O},b="\v",R=Pe({args:N,meta:Te,run:async e=>{let{subCommands:r}=e.cmd,t=r?e.rawArgs.find(u=>!u.startsWith("-")):void 0;if(t&&t!==b&&t in r)return;let{debug:o,name:i,serverPort:d,...n}=k(e),{renderContent:p,renderIntro:l,renderOutro:h,spinner:$}=H(i);try{let u=await Re({...n,debug:o,name:i,port:d,renderIntro:l}),x=new AbortController,{isFulfilled:J,promise:Z,reject:C,resolve:A}=E({onRejected:()=>x.abort()});z({debug:o,onFailure:C,onSuccess:A,server:u}),X({debug:o,onError:C}),await p({abortSignal:x.signal,isClosed:J,onQuit:async()=>{await u.close(),A()},server:u,spinner:$}),await Z,await h(),ye.exitCode||=0}catch(u){await g(u,$)}},setup(e){e.args.debug&&(K.level=we.debug),K.options.formatOptions.date=!1},subCommands:{[b]:{},ls:()=>import("./list-4ABJMPY2.js").then(e=>e.ListCommand)}});async function Re(e){let{renderIntro:r,...t}=e,[,o]=await Promise.allSettled([e.renderIntro(),Se({...t,persistenceMode:"stateful"})]);if(o.status==="rejected")throw o.reason;return o.value}async function ar(e,r){let[t]=e;t==="-v"&&(e[0]="--version"),t&&!(t in R.subCommands)&&t!=="--help"&&t!=="-h"&&t!=="--version"&&t!=="-v"&&e.unshift(b),await $e(R,{rawArgs:e})}export{ar as run};
38
+ `),process.exitCode=e==="SIGINT"?130:143,s.close().then(()=>{n&&console.debug("Prisma Dev server closed."),e==="SIGINT"&&(process.exitCode=0),d()}).catch(o)}}var we={description:"Spin up a local Prisma Postgres database",name:"dev",version:E},b="\v",R=be({args:I,meta:we,run:async e=>{let{subCommands:r}=e.cmd,t=r?e.rawArgs.find(u=>!u.startsWith("-")):void 0;if(t&&t!==b&&t in r)return;let{debug:n,name:o,serverPort:d,...s}=_(e),{renderContent:p,renderIntro:l,renderOutro:h,spinner:T}=B(o);try{let u=await ye({...s,debug:n,name:o,port:d,renderIntro:l}),C=new AbortController,{isFulfilled:W,promise:z,reject:x,resolve:O}=A({onRejected:()=>C.abort()});X({debug:n,onFailure:x,onSuccess:O,server:u}),V({debug:n,onError:x}),await p({abortSignal:C.signal,isClosed:W,onQuit:async()=>{await u.close(),O()},server:u,spinner:T}),await z,await h(),Se.exitCode||=0}catch(u){await g(u,T,e)}},setup(e){e.args.debug&&(Y.level=he.debug),Y.options.formatOptions.date=!1},subCommands:{[b]:{},ls:()=>import("./list-4ABJMPY2.js").then(e=>e.ListCommand)}});async function ye(e){let{renderIntro:r,...t}=e,[,n]=await Promise.allSettled([e.renderIntro(),ge({...t,persistenceMode:"stateful"})]);if(n.status==="rejected")throw n.reason;return n.value}async function tr(e,r){let[t]=e;t==="-v"&&(e[0]="--version"),t&&!(t in R.subCommands)&&t!=="--help"&&t!=="-h"&&t!=="--version"&&t!=="-v"&&e.unshift(b),await Pe(R,{rawArgs:e})}export{tr as run};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@prisma/cli-dev",
3
- "version": "0.6.0",
3
+ "version": "0.7.0",
4
4
  "description": "Dev CLI for Prisma",
5
5
  "type": "module",
6
6
  "sideEffects": false,
@@ -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.8.0"
49
+ "@prisma/dev": "0.9.0"
50
50
  },
51
51
  "scripts": {
52
52
  "build": "tsup",