@willbooster/wb 12.0.1 → 13.0.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.
- package/dist/index.js +3 -3
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import e from"node:fs";import t from"node:path";import n from"tree-kill";import r from"yargs";import{hideBin as s}from"yargs/helpers";import o,{spawn as i,spawnSync as a}from"node:child_process";import{createHash as c}from"node:crypto";import d from"chalk";import{globby as l}from"globby";import{config as u}from"dotenv";import{expand as p}from"dotenv-expand";import f from"kill-port";import{PromisePool as m}from"minimal-promise-pool";import h from"node:fs/promises";import g from"node:os";import{createServer as b}from"node:net";const v=new Map;function y(e){const n=v.get(e);if(n)return n;const r=u({path:t.resolve(e),processEnv:{}}).parsed??{};return v.set(e,r),r}async function w(e,t,r){return new Promise((s,o)=>{try{const a=i(e,t??[],r??{});a.stdout?.setEncoding?.("utf8"),a.stderr?.setEncoding?.("utf8");let c="",d="";a.stdout?.on("data",e=>{c+=e,r?.printingStdout&&process.stdout.write(e)}),a.stderr?.on("data",e=>{r?.mergeOutAndError?c+=e:d+=e,r?.printingStderr&&process.stderr.write(e)});let l=!1;const u=()=>{!l&&a.pid&&(l=!0,r?.verbose&&console.info(`treeKill(${a.pid})`),n(a.pid))};r?.killOnExit&&(process.on("beforeExit",u),process.on("SIGINT",u)),a.on("error",e=>{process.removeListener("beforeExit",u),process.removeListener("SIGINT",u),a.removeAllListeners("close"),o(e)}),a.on("close",(e,t)=>{process.removeListener("beforeExit",u),process.removeListener("SIGINT",u),void 0===a.pid?o(new Error("Process has no pid.")):s({pid:a.pid,stdout:c,stderr:d,status:e,signal:t})}),r?.input&&(a.stdin?.write(r.input),a.stdin?.end())}catch(e){o(e)}})}function k(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?typeof e:"null"));return e}function
|
|
1
|
+
import e from"node:fs";import t from"node:path";import n from"tree-kill";import r from"yargs";import{hideBin as s}from"yargs/helpers";import o,{spawn as i,spawnSync as a}from"node:child_process";import{createHash as c}from"node:crypto";import d from"chalk";import{globby as l}from"globby";import{config as u}from"dotenv";import{expand as p}from"dotenv-expand";import f from"kill-port";import{PromisePool as m}from"minimal-promise-pool";import h from"node:fs/promises";import g from"node:os";import{createServer as b}from"node:net";const v=new Map;function y(e){const n=v.get(e);if(n)return n;const r=u({path:t.resolve(e),processEnv:{}}).parsed??{};return v.set(e,r),r}async function w(e,t,r){return new Promise((s,o)=>{try{const a=i(e,t??[],r??{});a.stdout?.setEncoding?.("utf8"),a.stderr?.setEncoding?.("utf8");let c="",d="";a.stdout?.on("data",e=>{c+=e,r?.printingStdout&&process.stdout.write(e)}),a.stderr?.on("data",e=>{r?.mergeOutAndError?c+=e:d+=e,r?.printingStderr&&process.stderr.write(e)});let l=!1;const u=()=>{!l&&a.pid&&(l=!0,r?.verbose&&console.info(`treeKill(${a.pid})`),n(a.pid))};r?.killOnExit&&(process.on("beforeExit",u),process.on("SIGINT",u)),a.on("error",e=>{process.removeListener("beforeExit",u),process.removeListener("SIGINT",u),a.removeAllListeners("close"),o(e)}),a.on("close",(e,t)=>{process.removeListener("beforeExit",u),process.removeListener("SIGINT",u),void 0===a.pid?o(new Error("Process has no pid.")):s({pid:a.pid,stdout:c,stderr:d,status:e,signal:t})}),r?.input&&(a.stdin?.write(r.input),a.stdin?.end())}catch(e){o(e)}})}function k(e){if(Object(e)!==e)throw TypeError("right-hand side of 'in' should be an object, got "+(null!==e?typeof e:"null"));return e}function E(e,t,n){"symbol"==typeof t&&(t=(t=t.description)?"["+t+"]":"");try{Object.defineProperty(e,"name",{configurable:!0,value:n?n+" "+t:t})}catch(e){}return e}function A(e){var t=function(e,t){if("object"!=typeof e||!e)return e;var n=e[Symbol.toPrimitive];if(void 0!==n){var r=n.call(e,t);if("object"!=typeof r)return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}(e,"string");return"symbol"==typeof t?t:t+""}
|
|
2
2
|
/**
|
|
3
3
|
* [js-sha3]{@link https://github.com/emn178/js-sha3}
|
|
4
4
|
*
|
|
@@ -6,5 +6,5 @@ import e from"node:fs";import t from"node:path";import n from"tree-kill";import
|
|
|
6
6
|
* @author Chen, Yi-Cyuan [emn178@gmail.com]
|
|
7
7
|
* @copyright Chen, Yi-Cyuan 2015-2023
|
|
8
8
|
* @license MIT
|
|
9
|
-
*/const $=[..."0123456789abcdef"],R=[6,1536,393216,100663296],P=[0,8,16,24],S=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];const x=e=>{const t=[];for(const[n,r]of e.entries())t[n]=r;return t};class N{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(e,t,n){this.padding=t,this.outputBits=n,this.blockCount=1600-(e<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=n>>5,this.extraBytes=(31&n)>>3;for(let e=0;e<50;++e)this.s[e]=0}update(e){if(this.finalized)throw new Error("finalize already called");const t=this.blocks,n=this.byteCount,r=e.length,s=this.blockCount,o=this.s;let i,a,c=0;for(;c<r;){if(this.reset)for(this.reset=!1,t[0]=this.block,i=1;i<s+1;++i)t[i]=0;for(i=this.start;c<r&&i<n;++c)a=e.codePointAt(c)||0,a<128?t[i>>2]|=a<<P[3&i++]:a<2048?(t[i>>2]|=(192|a>>6)<<P[3&i++],t[i>>2]|=(128|63&a)<<P[3&i++]):a<55296||a>=57344?(t[i>>2]|=(224|a>>12)<<P[3&i++],t[i>>2]|=(128|a>>6&63)<<P[3&i++],t[i>>2]|=(128|63&a)<<P[3&i++]):(a=65536+((1023&a)<<10|1023&(e.codePointAt(++c)||0)),t[i>>2]|=(240|a>>18)<<P[3&i++],t[i>>2]|=(128|a>>12&63)<<P[3&i++],t[i>>2]|=(128|a>>6&63)<<P[3&i++],t[i>>2]|=(128|63&a)<<P[3&i++]);if(this.lastByteIndex=i,i>=n){for(this.start=i-n,this.block=t[s],i=0;i<s;++i)o[i]^=t[i];j(o),this.reset=!0}else this.start=i}return this}finalize(){if(this.finalized)return;this.finalized=!0;const e=this.blocks;let t=this.lastByteIndex;const n=this.blockCount,r=this.s;if(e[t>>2]|=this.padding[3&t],this.lastByteIndex===this.byteCount)for(e[0]=e[n],t=1;t<n+1;++t)e[t]=0;for(e[n-1]|=2147483648,t=0;t<n;++t)r[t]^=e[t];j(r)}hex(){this.finalize();const e=this.blockCount;let t=this.s;const n=this.outputBlocks,r=this.extraBytes;let s,o=0,i=0,a="";for(;i<n;){for(o=0;o<e&&i<n;++o,++i)s=t[o],a+=$[s>>4&15]+$[15&s]+$[s>>12&15]+$[s>>8&15]+$[s>>20&15]+$[s>>16&15]+$[s>>28&15]+$[s>>24&15];i%e===0&&(t=x(t),j(t),o=0)}return r&&(s=t[o],a+=$[s>>4&15]+$[15&s],r>1&&(a+=$[s>>12&15]+$[s>>8&15]),r>2&&(a+=$[s>>20&15]+$[s>>16&15])),a}}const j=function(e){let t,n,r,s,o,i,a,c,d,l,u,p,f,m,h,g,b,v,y,w,k,A,E,$,R,P,x,N,j,D,_,T,O,I,C,B,L,F,J,U,W,z,M,Y,V,q,G,K,H,Q,X,Z,ee,te,ne,re,se,oe,ie,ae,ce,de,le;for(r=0;r<48;r+=2)s=e[0]^e[10]^e[20]^e[30]^e[40],o=e[1]^e[11]^e[21]^e[31]^e[41],i=e[2]^e[12]^e[22]^e[32]^e[42],a=e[3]^e[13]^e[23]^e[33]^e[43],c=e[4]^e[14]^e[24]^e[34]^e[44],d=e[5]^e[15]^e[25]^e[35]^e[45],l=e[6]^e[16]^e[26]^e[36]^e[46],u=e[7]^e[17]^e[27]^e[37]^e[47],p=e[8]^e[18]^e[28]^e[38]^e[48],f=e[9]^e[19]^e[29]^e[39]^e[49],t=p^(i<<1|a>>>31),n=f^(a<<1|i>>>31),e[0]^=t,e[1]^=n,e[10]^=t,e[11]^=n,e[20]^=t,e[21]^=n,e[30]^=t,e[31]^=n,e[40]^=t,e[41]^=n,t=s^(c<<1|d>>>31),n=o^(d<<1|c>>>31),e[2]^=t,e[3]^=n,e[12]^=t,e[13]^=n,e[22]^=t,e[23]^=n,e[32]^=t,e[33]^=n,e[42]^=t,e[43]^=n,t=i^(l<<1|u>>>31),n=a^(u<<1|l>>>31),e[4]^=t,e[5]^=n,e[14]^=t,e[15]^=n,e[24]^=t,e[25]^=n,e[34]^=t,e[35]^=n,e[44]^=t,e[45]^=n,t=c^(p<<1|f>>>31),n=d^(f<<1|p>>>31),e[6]^=t,e[7]^=n,e[16]^=t,e[17]^=n,e[26]^=t,e[27]^=n,e[36]^=t,e[37]^=n,e[46]^=t,e[47]^=n,t=l^(s<<1|o>>>31),n=u^(o<<1|s>>>31),e[8]^=t,e[9]^=n,e[18]^=t,e[19]^=n,e[28]^=t,e[29]^=n,e[38]^=t,e[39]^=n,e[48]^=t,e[49]^=n,m=e[0],h=e[1],q=e[11]<<4|e[10]>>>28,G=e[10]<<4|e[11]>>>28,N=e[20]<<3|e[21]>>>29,j=e[21]<<3|e[20]>>>29,ae=e[31]<<9|e[30]>>>23,ce=e[30]<<9|e[31]>>>23,z=e[40]<<18|e[41]>>>14,M=e[41]<<18|e[40]>>>14,I=e[2]<<1|e[3]>>>31,C=e[3]<<1|e[2]>>>31,g=e[13]<<12|e[12]>>>20,b=e[12]<<12|e[13]>>>20,K=e[22]<<10|e[23]>>>22,H=e[23]<<10|e[22]>>>22,D=e[33]<<13|e[32]>>>19,_=e[32]<<13|e[33]>>>19,de=e[42]<<2|e[43]>>>30,le=e[43]<<2|e[42]>>>30,te=e[5]<<30|e[4]>>>2,ne=e[4]<<30|e[5]>>>2,B=e[14]<<6|e[15]>>>26,L=e[15]<<6|e[14]>>>26,v=e[25]<<11|e[24]>>>21,y=e[24]<<11|e[25]>>>21,Q=e[34]<<15|e[35]>>>17,X=e[35]<<15|e[34]>>>17,T=e[45]<<29|e[44]>>>3,O=e[44]<<29|e[45]>>>3,$=e[6]<<28|e[7]>>>4,R=e[7]<<28|e[6]>>>4,re=e[17]<<23|e[16]>>>9,se=e[16]<<23|e[17]>>>9,F=e[26]<<25|e[27]>>>7,J=e[27]<<25|e[26]>>>7,w=e[36]<<21|e[37]>>>11,k=e[37]<<21|e[36]>>>11,Z=e[47]<<24|e[46]>>>8,ee=e[46]<<24|e[47]>>>8,Y=e[8]<<27|e[9]>>>5,V=e[9]<<27|e[8]>>>5,P=e[18]<<20|e[19]>>>12,x=e[19]<<20|e[18]>>>12,oe=e[29]<<7|e[28]>>>25,ie=e[28]<<7|e[29]>>>25,U=e[38]<<8|e[39]>>>24,W=e[39]<<8|e[38]>>>24,A=e[48]<<14|e[49]>>>18,E=e[49]<<14|e[48]>>>18,e[0]=m^~g&v,e[1]=h^~b&y,e[10]=$^~P&N,e[11]=R^~x&j,e[20]=I^~B&F,e[21]=C^~L&J,e[30]=Y^~q&K,e[31]=V^~G&H,e[40]=te^~re&oe,e[41]=ne^~se&ie,e[2]=g^~v&w,e[3]=b^~y&k,e[12]=P^~N&D,e[13]=x^~j&_,e[22]=B^~F&U,e[23]=L^~J&W,e[32]=q^~K&Q,e[33]=G^~H&X,e[42]=re^~oe&ae,e[43]=se^~ie&ce,e[4]=v^~w&A,e[5]=y^~k&E,e[14]=N^~D&T,e[15]=j^~_&O,e[24]=F^~U&z,e[25]=J^~W&M,e[34]=K^~Q&Z,e[35]=H^~X&ee,e[44]=oe^~ae&de,e[45]=ie^~ce&le,e[6]=w^~A&m,e[7]=k^~E&h,e[16]=D^~T&$,e[17]=_^~O&R,e[26]=U^~z&I,e[27]=W^~M&C,e[36]=Q^~Z&Y,e[37]=X^~ee&V,e[46]=ae^~de&te,e[47]=ce^~le&ne,e[8]=A^~m&g,e[9]=E^~h&b,e[18]=T^~$&P,e[19]=O^~R&x,e[28]=z^~I&B,e[29]=M^~C&L,e[38]=Z^~Y&q,e[39]=ee^~V&G,e[48]=de^~te&re,e[49]=le^~ne&se,e[0]^=S[r],e[1]^=S[r+1]},D=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,r,s])=>{e.name=t,e.message=n,void 0===r?delete e.stack:e.stack=r,void 0!==s&&(e.cause=s)}},t={instance:Uint8Array,from:e=>[btoa(T.decode(e))],create:([e])=>_.encode(atob(e))},n={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,r]of t)e.set(n,r)}},r={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},s={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},o={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},i={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,n,r,s,o,i].map(e=>[e.instance.name,e]))}(),_=new TextEncoder,T=new TextDecoder("utf-8");function O(e=void 0,t=D){return JSON.stringify(B(e,t))}function I(e){if(void 0===e)return-1;if("number"==typeof e){if(Number.isNaN(e))return-3;if(!Number.isFinite(e))return e<0?-5:-4}return null}const C=[];function B(e,t=D){const n=I(e);if(null!==n)return n;const r=[],s=new Map;return function e(n){const o=I(n);if(null!==o)return o;let i=s.get(n);if(void 0!==i)return i;switch(i=r.length,typeof n){case"number":case"string":case"boolean":r[i]=n,s.set(n,i);break;case"bigint":r[i]=[-6,n.toString(16)],s.set(n,i);break;case"object":if(null===n)r[i]=n,s.set(n,i);else if(Array.isArray(n)){const t=function(e){if(C.length<e){const t=C.length;C.length=e,C.fill(-2,t,e)}return C.slice(0,e)}(n.length);r[i]=t,s.set(n,i);for(const[r,s]of n.entries())t[r]=e(s)}else{const[o,a]=function(e,t){const n=e.constructor;if("function"==typeof n){const r=n.name,s=t.get(r);if(void 0!==s)return[r,s.from(e)]}const r=Object.entries(e),s=r.length,o=Array.from({length:s+s});for(let e=0;e<s;e++){const t=r[e],n=e+e;o[n]=t[0],o[n+1]=t[1]}return["",o]}(n,t),c=a.length,d=Array.from({length:c+1});d[0]=o,r[i]=d,s.set(n,i);for(let t=0;t<c;t++)d[t+1]=e(a[t])}}return i}(e),r}function L(e,t){return function(e){return new N(512,R,512).update(e).hex()}(O([e,t]))}const F=function({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:t=L}={}){return function(n,r){let s,o,i;return"getter"===r?.kind?function(){const r=t(this,[]),a=Date.now();return(i!==r||a-o>e)&&(i=r,s=n.call(this),o=a),s}:function(...a){const c=t(this,a),d=Date.now();return(i!==c||d-o>e)&&(i=c,s=r?n.call(this,...a):n(...a),o=d),s}}}({getCacheKey:L});function J(e){return!!e&&"0"!==e&&"false"!==e}let U;class W{static{[U]=function(e,t,n,r,s){var o,i,a,c,d,l,u,p=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,m=Object.create,h=[m(null),m(null)],g=t.length;function b(t,n,r){return function(s,o){n&&(o=s,s=e);for(var i=0;i<t.length;i++)o=t[i].apply(s,r?[o]:[]);return r?o:s}}function v(e,t,n,r){if("function"!=typeof e&&(r||void 0!==e))throw new TypeError(t+" must "+(n||"be")+" a function"+(r?"":" or undefined"));return e}function y(e,t,n,r,s,a,c,d,l,u,p){function m(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),y=t[3],w=!c,k=1===s,E=3===s,$=4===s,R=2===s;function P(t,n,r){return function(s,o){return n&&(o=s,s=e),r&&r(s),S[t].call(s,o)}}if(!w){var S={},x=[],N=E?"get":$||k?"set":"value";if(l?(u||k?S={get:A(function(){return y(this)},r,"get"),set:function(e){t[4](this,e)}}:S[N]=y,u||A(S[N],r,R?"":N)):u||(S=Object.getOwnPropertyDescriptor(e,r)),!u&&!l){if((i=h[+d][r])&&7!==(i^s))throw Error("Decorating two elements with the same name ("+S[N].name+") is not supported yet");h[+d][r]=s<3?1:s}}for(var j=e,D=g.length-1;D>=0;D-=n?2:1){var _=v(g[D],"A decorator","be",!0),T=n?g[D-1]:void 0,O={},I={kind:["field","accessor","method","getter","setter","class"][s],name:r,metadata:o,addInitializer:function(e,t){if(e.v)throw new TypeError("attempted to call addInitializer after decoration was finished");v(t,"An initializer","be",!0),a.push(t)}.bind(null,O)};if(w)i=_.call(T,j,I),O.v=1,v(i,"class decorators","return")&&(j=i);else if(I.static=d,I.private=l,i=I.access={has:l?p.bind():function(e){return r in e}},$||(i.get=l?R?function(e){return m(e),S.value}:P("get",0,m):function(e){return e[r]}),R||E||(i.set=l?P("set",0,m):function(e,t){e[r]=t}),j=_.call(T,k?{get:S.get,set:S.set}:S[N],I),O.v=1,k){if("object"==typeof j&&j)(i=v(j.get,"accessor.get"))&&(S.get=i),(i=v(j.set,"accessor.set"))&&(S.set=i),(i=v(j.init,"accessor.init"))&&x.unshift(i);else if(void 0!==j)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else v(j,(u?"field":"method")+" decorators","return")&&(u?x.unshift(j):S[N]=j)}return s<2&&c.push(b(x,d,1),b(a,d,0)),u||w||(l?k?c.splice(-1,0,P("get",d),P("set",d)):c.push(R?S[N]:v.call.bind(S[N])):f(e,r,S)),j}function w(e){return f(e,p,{configurable:!0,enumerable:!0,value:o})}return o=m(null==o?null:o),d=[],l=function(e){e&&d.push(b(e))},u=function(t,r){for(var o=0;o<n.length;o++){var i=n[o],l=i[1],u=7&l;if((8&l)==t&&!u==r){var p=i[2],f=!!i[3],m=16&l;y(t?e:e.prototype,i,m,f?"#"+p:E(p),u,u<2?[]:t?c=c||[]:a=a||[],d,!!t,f,r,t&&f?function(t){return k(t)===e}:s)}}},u(8,0),u(0,0),u(8,1),u(0,1),l(a),l(c),i=d,g||w(e),{e:i,get c(){var n=[];return g&&[w(e=y(e,[t],r,e.name,5,n)),b(n,1)]}}}(this,[],[[F,3,"isBunAvailable"],[F,3,"buildCommand"],[F,3,"rootDirPath"],[F,3,"dockerfile"],[F,3,"hasDockerfile"],[F,3,"hasSourceCode"],[F,3,"name"],[F,3,"dockerImageName"],[F,3,"env"],[F,3,"packageJson"],[F,3,"packageJsonPath"],[F,3,"hasPrisma"],[F,3,"hasVitest"],[F,3,"skipLaunchingServerForPlaywright"],[F,3,"dockerPackageJson"],[F,3,"binExists"]]).e}argv=void U(this);pathByName=new Map;constructor(e,n,r){this._dirPath=t.resolve(e),this.argv=n,this.loadEnv=r}get isBunAvailable(){try{return/(^|\n)bun\s/.test(e.readFileSync(t.join(this.rootDirPath,".tool-versions"),"utf8"))}catch{return!1}}get buildCommand(){return this.packageJson.scripts?.build?.includes("buildIfNeeded")?"YARN run build":this.packageJson.scripts?.build?"YARN wb buildIfNeeded "+(this.argv.verbose?"--verbose":""):"echo 'No build script'"}get dirPath(){return this._dirPath}get rootDirPath(){return e.existsSync(t.join(this.dirPath,"..","..","package.json"))?t.resolve(this.dirPath,"..",".."):this.dirPath}get dockerfile(){return e.readFileSync(this.findFile("Dockerfile"),"utf8")}get hasDockerfile(){try{return!!this.findFile("Dockerfile")}catch{return!1}}get hasSourceCode(){return e.existsSync(t.join(this.dirPath,"src"))}get name(){return this.packageJson.name||"unknown"}get dockerImageName(){return(this.packageJson.name||"unknown").replaceAll("@","").replaceAll("/","-")}get env(){if(!this.loadEnv)return process.env;const[n,r]=function(n,r){let s=(n.env??[]).map(e=>t.resolve(r,e.toString()));const o=n.cascadeEnv??(n.cascadeNodeEnv?process.env.NODE_ENV||"development":n.autoCascadeEnv?process.env.WB_ENV||process.env.NODE_ENV||"development":void 0);if("string"==typeof o){if(0===s.length&&(s.push(t.join(r,".env")),n.includeRootEnv)){const n=t.resolve(r,"..","..");e.existsSync(t.join(n,"package.json"))&&s.push(t.join(n,".env"))}s=s.flatMap(e=>o?[`${e}.${o}.local`,`${e}.local`,`${e}.${o}`,e]:[`${e}.local`,e])}s=s.filter(t=>e.existsSync(t)).map(e=>t.relative(r,e)),n.verbose&&(console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`),console.info("Reading env files:",s.join(", ")));const i=[],a={};for(const e of s){let s=0;for(const[n,o]of Object.entries(y(t.join(r,e))))n in a||(a[n]=o,s++);i.push([e,s]),n.verbose&&s>0&&console.info(`Read ${s} environment variables from ${e}`)}if(n.checkEnv){const e=Object.keys(y(t.join(r,n.checkEnv))).filter(e=>!(e in a));if(e.length>0)throw new Error(`Missing environment variables in [${s.join(", ")}]: [${e.join(", ")}]`)}return[p({parsed:a,processEnv:{}}).parsed??a,i]}(this.argv,this.dirPath);for(const[e,t]of r)console.info(`Loaded ${t} environment variables from ${e}`);return{...n,...process.env}}get packageJson(){return JSON.parse(e.readFileSync(this.packageJsonPath,"utf8"))}get packageJsonPath(){return t.join(this.dirPath,"package.json")}get hasPrisma(){return!!(this.packageJson.dependencies?.prisma??this.packageJson.devDependencies?.prisma)}get hasVitest(){return!!(this.packageJson.dependencies?.vitest??this.packageJson.devDependencies?.vitest)}get skipLaunchingServerForPlaywright(){if(J(this.env.CI))return!1;try{const t=this.findFile("playwright.config.ts");return/\bwebServer\b/.test(e.readFileSync(t,"utf8"))}catch{return!1}}get dockerPackageJson(){return t.dirname(this.findFile("Dockerfile"))===this.dirPath?this.packageJson:JSON.parse(e.readFileSync(t.join(t.dirname(this.findFile("Dockerfile")),"package.json"),"utf8"))}get binExists(){let n=!1,r=this.dirPath;for(;;){const s=t.join(r,"node_modules",".bin");if(e.existsSync(s)&&(this.env.PATH=`${s}:${this.env.PATH}`,n=!0),e.existsSync(t.join(r,".git")))break;const o=t.dirname(r);if(r===o)break;r=o}return n}findFile(n){let r=this.pathByName.get(n);if(r)return r;if(r=[n,t.join("..","..",n)].map(e=>t.resolve(this.dirPath,e)).find(t=>e.existsSync(t)),!r)throw new Error(`File not found: ${n}`);return this.pathByName.set(n,r),r}}function z(n,r=!0,s){if(s??=process.cwd(),e.existsSync(t.join(s,"package.json")))return new W(s,n,r)}async function M(n,r=!0,s){const o=function(n,r=!0,s){if(s??=process.cwd(),!e.existsSync(t.join(s,"package.json")))return;const o=new W(s,n,r);let i=o;if(!o.packageJson.workspaces&&t.dirname(s).endsWith("/packages")){const o=t.resolve(s,"..","..");e.existsSync(t.join(o,"package.json"))&&(i=new W(o,n,r))}return{root:i,self:o}}(n,r,s);if(o)return{...o,descendants:o.root===o.self?await Y(n,o.root,r):[o.self]}}async function Y(n,r,s){const o=[r],i=r.packageJson.workspaces;if(!Array.isArray(i))return o;const a=[],c=[];for(const n of i.map(e=>t.join(r.dirPath,e)))e.existsSync(n)?c.push(n):a.push(n);c.push(...await l(a,{dot:!0,onlyDirectories:!0}));for(const r of c)e.existsSync(t.join(r,"package.json"))&&o.push(new W(r,n,s));return o}const V=process.versions.bun||process.argv[0]?.endsWith("/bun")||process.env.npm_execpath?.endsWith("/bun"),q=V?"bun --bun run":"node",G=V?"bun":"yarn",K=V?"bun --bun run":"yarn",H={command:"buildIfNeeded",describe:"Build code if changes are detected",builder:{command:{description:"A build command (default: yarn|bun build)",type:"string",alias:"c"}},async handler(n){await async function(n,r){const s=z(n,!0,r);if(!s)return console.error(d.red("No project found.")),!0;if(n={...n,command:n.command??(V?"bun run build":"yarn build")},!e.existsSync(t.join(s.rootDirPath,".git")))return Q(s,n),!0;const[i,a,l]=await async function(n,r){const s=t.resolve(n.dirPath,"node_modules",".cache","build"),i=t.resolve(s,"last-build");await e.promises.mkdir(s,{recursive:!0});const a=c("sha256"),d=o.execSync("git rev-parse HEAD",{cwd:n.dirPath}).toString().trim();a.update(d);const l=JSON.stringify(Object.entries(n.env).filter(([e])=>!X.has(e)).toSorted(([e],[t])=>e.localeCompare(t)));a.update(l),await async function(e,t,n){return new Promise(r=>{const s=o.spawnSync("git",["status","--porcelain"],{cwd:e.dirPath,env:e.env,stdio:"pipe",encoding:"utf8"}).stdout.trim().split("\n").filter(e=>e.length>0).map(e=>e.slice(2).trim()).map(t=>"test"===e.env.WB_ENV?t.replace(/packages\/wb\/test\/fixtures\/[^/]+\//,""):t).filter(e=>(Z.some(t=>e.includes(t))||ee.some(t=>e.endsWith(t)))&&!te.some(t=>e.includes(t)));t.verbose&&console.info(`Changed files: ${s.join(", ")}`);const i=o.spawn("git",["diff","--",...s],{cwd:e.rootDirPath});i.stdout.on("data",e=>{n.update(e),t.verbose&&(console.info("Data:",e),console.info("Hash:",n.copy().digest("hex")))}),i.on("close",()=>{r()})})}(n,r,a);const u=a.digest("hex"),p=await async function(e){try{return await e()}catch(e){if("object"==typeof e&&e&&"code"in e&&"ENOENT"===e.code)return;throw e}}(()=>e.promises.readFile(i,"utf8"));return[p===u,i,u]}(s,n);if(i)return console.info(d.green(`Skip to run '${n.command}' 💫`)),!1;if(!Q(s,n))return;n.dryRun||await e.promises.writeFile(a,l,"utf8");return!0}(n)}};function Q(e,t){if(console.info(d.green(`Run '${t.command}'`)),!t.dryRun){const n=o.spawnSync(t.command??"",{cwd:e.dirPath,env:e.env,shell:!0,stdio:"inherit"});if(0!==n.status)return process.exitCode=n.status??1,!1}return!0}const X=new Set(["CI","PWDEBUG","TMPDIR"]);const Z=["src/","public/"],ee=[".js",".cjs",".mjs",".jsx",".ts",".cts",".mts",".tsx",".json",".browserslistrc","package.json","yarn.lock"],te=["test/","tests/","__tests__/","test-fixtures/","test/fixtures/"];const ne={command:"kill-port-if-non-ci",describe:"Kill the port specified by PORT environment variable if non-CI.",builder:{},async handler(e){await async function(e){const t=z(e);t||(console.error(d.red("No project found.")),process.exit(1));if(J(t.env.CI))return void console.info(`Skip killing port due to CI: ${t.env.CI}`);const n=t.env.PORT,r=Number(n);(!Number.isInteger(r)||r<=0)&&(console.error(d.red(`PORT environment variable is invalid: ${n}`)),process.exit(1));console.info(`Killing the port: ${r}`);try{await f(r)}catch{}}(e)}};const re=new m,se={exitIfFailed:!0};async function oe(e,t,n,r=se){const s=ae(e,t);if(ce(s.printable,t),n.verbose&&ce(s.runnable,t,"Start (raw)",!0),n.dryRun)return de(s.printable,0,r),0;const o=await w(s.runnable,void 0,{cwd:t.dirPath,env:le(t.env,r),shell:!0,stdio:"inherit",timeout:r.timeout,killOnExit:!0,verbose:n.verbose});return r.onSignal?.(o.signal),de(s.printable,o.status,r),o.status??1}function ie(e,t,n,r=se){return re.runAndWaitForReturnValue(async()=>{const s=ae(e,t);if(ce(s.printable,t,"Start (parallel)",!0),n.dryRun)return ce(s.printable,t,"Started (log)"),n.verbose&&ce(s.runnable,t,"Started (raw)",!0),de(s.printable,0,r),0;const o=await w(s.runnable,void 0,{cwd:t.dirPath,env:le(t.env,r),shell:!0,stdio:"pipe",timeout:r.timeout,mergeOutAndError:!0,killOnExit:!0,verbose:n.verbose});r.onSignal?.(o.signal),ce(s.printable,t,"Started (log)"),n.verbose&&ce(s.runnable,t,"Started (raw)",!0);const i=o.stdout.trim();return i&&(process.stdout.write(i),process.stdout.write("\n")),de(s.printable,o.status,r),o.status??1})}function ae(e,t){let n=e.replaceAll("\n","").replaceAll(/\s\s+/g," ").replaceAll("PRISMA generate ",t.packageJson.dependencies?.blitz?"PRISMA generate ":"PRISMA generate --no-hints ").replaceAll("PRISMA ",t.packageJson.dependencies?.blitz?"YARN blitz prisma ":"YARN prisma ").replaceAll("BUN ",t.isBunAvailable?"bun --bun run ":"YARN ").replaceAll("YARN run ",V?"bun --bun run ":"yarn run ");V&&(n=n.replaceAll("YARN build-ts run","bun --bun run").replaceAll("bun --bun run bun --bun run","bun --bun run").replaceAll("dist/index.js","src/index.ts").replaceAll(/(?:YARN )?vitest run/g,"bun test").replaceAll(/ --color --passWithNoTests(?: --allowOnly)?/g,"")),n=n.trim();const r=ue(n.replaceAll("YARN ",`${K} `)),s=ue(n.replaceAll("YARN playwright ",`${K} playwright `).replaceAll("YARN ",!V&&t.binExists?"":`${K} `)),o=t.env.WB_ENV?` -c=${t.env.WB_ENV||"development"}`:"";return{printable:`${K} dotenv${o} -- ${r}`,runnable:s}}function ce(e,t,n="Start",r=!1){console.info("\n"+(r?d.gray:d.cyan)(d.bold(`${n}:`),e)+d.gray(` at ${t.dirPath}`))}function de(e,t,n){0===t?console.info(d.green(d.bold("Finished:"),e)):(console.info(d.red(d.bold(`Failed (exit code ${t}): `),e)),!1!==n.exitIfFailed&&process.exit(t??1))}function le(e,t){const n={...e};return t.ci&&(n.CI="1"),t.forceColor&&(n.FORCE_COLOR="3"),n}function ue(e){return e.includes("next dev")||e.includes("playwright")||e.includes("prisma")||e.includes("test/e2e-additional")?e.replaceAll("bun --bun","bun"):e}const pe=new Set(["cjs","cts","js","json","jsonc","jsx","mjs","mts","ts","tsx"]),fe=new Set(["cjs","cts","htm","html","js","json","jsonc","jsx","md","mjs","mts","scss","ts","tsx","vue","yaml","yml"]),me=new Set([...fe].filter(e=>!pe.has(e))),he={command:"lint [files...]",describe:"Lint code on Bun",builder:{fix:{description:"Fix the linting errors",type:"boolean"},format:{description:"Format the code",type:"boolean"}},async handler(e){V||(console.error(d.red("This command is only available on Bun.")),process.exit(1));const n=await M(e,!1);n||(console.error(d.red("No project found.")),process.exit(1));const r=e.files??[];let s,o,i;if(r.length>0){const e=[],n=[],a=[];for(const s of r){const r=t.resolve(String(s));if(r.endsWith("/test/fixtures")||r.includes("/test/fixtures/")||r.endsWith("/test-fixtures")||r.includes("/test-fixtures/"))continue;const o=t.extname(r).slice(1);r.endsWith("/package.json")?a.push(r):pe.has(o)?e.push(r):fe.has(o)&&n.push(r)}s=e.map(e=>`"${e}"`).join(" "),o=n.map(e=>`"${e}"`).join(" "),i=a.map(e=>`"${e}"`).join(" ")}else s="",o=`"**/{.*/,}*.{${[...me].join(",")}}" "!**/test{-,/}fixtures/**"`,i=n.descendants.map(e=>`"${e.packageJsonPath}"`).join(" ");const a=e.fix&&e.format?"check --fix":e.fix?"lint --fix":e.format?"format --fix":"lint";let c;(s||0===r.length)&&(c=ie(`bun --bun biome ${a} --colors=force --no-errors-on-unmatched --files-ignore-unknown=true ${s}`,n.self,e,{forceColor:!0})),e.format&&(o&&ie(`bun --bun prettier --cache --color --no-error-on-unmatched-pattern --write ${o}`,n.self,e,{forceColor:!0}),i&&(await c,ie(`bun --bun sort-package-json ${i}`,n.self,e,{forceColor:!0})))}};function*ge(e,t){for(const n of t)console.info(`Running "${e}" for ${n.name} ...`),yield n}const be={command:"optimizeForDockerBuild",describe:"Optimize configuration when building a Docker image",builder:{outside:{description:"Whether the optimization is executed outside a docker container or not",type:"boolean",alias:"o"}},async handler(n){const r=await M(n);r||(console.error(d.red("No project found.")),process.exit(1));for(const s of ge("optimizeForDockerBuild",r.descendants)){const r=s.packageJson,o=["dependencies","devDependencies"];for(const e of o){const t=r[e]??{};for(const[e,n]of Object.entries(t))n?.startsWith("git@github.com:")&&(t[e]=`./${e}`)}if(ve(n,r),ye(r),we(r),n.dryRun)continue;const i=n.outside?t.join(s.dirPath,"dist"):s.dirPath;await e.promises.mkdir(i,{recursive:!0}),await e.promises.writeFile(t.join(i,"package.json"),JSON.stringify(r),"utf8")}n.dryRun||n.outside||(o.spawnSync(G,["install"],{stdio:"inherit"}),console.info("Installed dependencies."))}};function ve(e,t){if(!e.outside)return delete t.devDependencies,void console.info("Removed all devDependencies.");const n=t.devDependencies??{},r=["artillery","biome","concurrently","conventional-changelog-conventionalcommits","eslint","husky","imagemin","jest","kill-port","lint-staged","open-cli","playwright","prettier","pinst","railway","semantic-release","sort-package-json","wait-on","vitest"],s=[];for(const e of Object.keys(n))(r.some(t=>e.includes(t))||e.includes("willbooster")&&e.includes("config"))&&(delete n[e],s.push(e));console.info("Removed devDependencies:",s.join(", ")||"none")}function ye(e){const t=["check","deploy","format","lint","start","test"],n=["pinst ","husky "],r=e.scripts??{},s=[];for(const[e,o]of Object.entries(r))(t.some(t=>e.startsWith(t))||n.some(e=>o.includes(e)||o.trim()===e.trim()))&&(delete r[e],s.push(e));console.info("Removed scripts:",s.join(", ")||"none")}function we(e){delete e.private,delete e.publishConfig,delete e.prettier}function ke(e){return e.packageJson.dependencies?.blitz?"db/mount":"prisma/mount"}const Ae=new class{cleanUpLitestream(e){const t=ke(e);return`rm -Rf ${t}/prod.sqlite3-*; rm -Rf ${t}/prod.sqlite3.*; rm -Rf ${t}/.prod.sqlite3* || true`}deploy(e,t=""){return`PRISMA migrate deploy ${t}`}deployForce(e){const t=ke(e);return`PRISMA migrate reset --force --skip-seed && rm -Rf ${t}/prod.sqlite3*\n && litestream restore -config litestream.yml -o ${t}/prod.sqlite3 ${t}/prod.sqlite3 && ls -ahl ${t}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`}listBackups(e){return`litestream ltx -config litestream.yml ${ke(e)}/prod.sqlite3`}migrate(e,t=""){return`PRISMA migrate deploy ${t} && PRISMA generate && ${this.seed(e)}`}migrateDev(e,t=""){return`PRISMA migrate dev ${t}`}reset(e,t=""){const n=`PRISMA migrate reset --force ${t.trim()}`;return`${e.packageJson.dependencies?.blitz?`${n} && ${this.seed(e)}`:n} && ${e.packageJson.dependencies?.blitz?String.raw`find db \( -name "test.db*" -o -name "test.sqlite*" \) -delete`:String.raw`find prisma \( -name "test.db*" -o -name "test.sqlite*" \) -delete`}`}restore(e,t){const n=ke(e);return`${this.removeSqliteArtifacts(t)}; litestream restore -config litestream.yml -o ${t} ${n}/prod.sqlite3`}seed(e,t){return e.packageJson.dependencies?.blitz?"YARN blitz db seed"+(t?` -f ${t}`:""):t?`BUN build-ts run ${t}`:e.packageJson.prisma?.seed?"YARN prisma db seed":'if [ -e "prisma/seeds.ts" ]; then BUN build-ts run prisma/seeds.ts; fi'}setUpDBForLitestream(e){return`${q} -e '\nconst { PrismaClient } = require("@prisma/client");\nconst prisma = new PrismaClient();\n(async () => {\n try {\n await prisma.$queryRawUnsafe("PRAGMA busy_timeout = 5000");\n await prisma.$queryRawUnsafe("PRAGMA journal_mode = WAL");\n await prisma.$queryRawUnsafe("PRAGMA synchronous = NORMAL");\n await prisma.$queryRawUnsafe("PRAGMA wal_autocheckpoint = 0");\n } catch (error) {\n console.error("Failed due to:", error);\n process.exit(1);\n } finally {\n await prisma.$disconnect();\n }\n})();\n'`}studio(n,r,s=""){const o="file:";let i="";if(r)try{new URL(r),i=`DATABASE_URL=${r} `}catch{i=`DATABASE_URL=${o}${t.resolve(r)} `}else if(n.env.DATABASE_URL?.startsWith(o)){const r=[{schemaPath:t.join("prisma","schema.prisma"),dbPath:"prisma"},{schemaPath:t.join("prisma","schema"),dbPath:t.join("prisma","schema")},{schemaPath:t.join("db","schema.prisma"),dbPath:"db"}];for(const{dbPath:s,schemaPath:a}of r)if(e.existsSync(t.resolve(n.dirPath,a))){i=`DATABASE_URL=${o}${t.resolve(n.dirPath,s,n.env.DATABASE_URL.slice(5))} `;break}}return`${i}PRISMA studio ${s}`}removeSqliteArtifacts(e){return`rm -Rf ${e} ${e}-shm ${e}-wal ${e}-litestream`}},Ee={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.",type:"string"},"cascade-node-env":{description:'Same with --cascade-env=<NODE_ENV || "development">. Preferred over `auto-cascade-env`.',type:"boolean"},"auto-cascade-env":{description:'Same with --cascade-env=<WB_ENV || NODE_ENV || "development">.',type:"boolean",default:!0},"include-root-env":{description:"Include .env files in root directory if the project is in a monorepo and --env option is not used.",type:"boolean",default:!0},"check-env":{description:"Check whether the keys of the loaded .env files are same with the given .env file.",type:"string",default:".env.example"},verbose:{description:"Whether to show verbose information",type:"boolean",alias:"v"},"working-dir":{description:"A working directory",type:"string",alias:"w"},"dry-run":{description:"Whether to skip actual command execution",type:"boolean",alias:["dry","d"]}},$e={},Re={command:"prisma",describe:"Run prisma commands",builder:e=>e.command(Pe).command(Se).command(xe).command(Ne).command(je).command(Ce).command(De).command(_e).command(Te).command(Oe).command(Ie).command(Be).command(Le).demandCommand().strict(!1),handler(){}},Pe={command:"cleanup-litestream",describe:"Clean up temporal Litestream files",builder:$e,async handler(e){const t=await Je(e);for(const n of ge("prisma cleanup-litestream",t))await oe(Ae.cleanUpLitestream(n),n,e)}},Se={command:"create-litestream-config",describe:"Create Litestream configuration file",builder:$e,async handler(e){const t=await Je(e);for(const e of ge("prisma create-litestream-config",t))Fe(e)}},xe={command:"deploy",describe:"Apply migration to DB without initializing it",builder:$e,async handler(e){const t=await Je(e),n=Ue(e);for(const r of ge("prisma deploy",t))await oe(Ae.deploy(r,n),r,e)}},Ne={command:"deploy-force",describe:"Force to apply migration to DB utilizing Litestream's backup without initializing it",builder:$e,async handler(e){const t=await Je(e);for(const n of ge("prisma deploy-force",t))await oe(Ae.deployForce(n),n,e)}},je={command:"list-backups",describe:"List Litestream backups",builder:$e,async handler(e){const t=await Je(e);for(const n of ge("prisma list-backups",t))await oe(Ae.listBackups(n),n,e)}},De={command:"migrate",describe:"Apply migration to DB with initializing it",builder:$e,async handler(e){const t=await Je(e),n=Ue(e);for(const r of ge("prisma migrate",t))await oe(Ae.migrate(r,n),r,e)}},_e={command:"migrate-dev",describe:"Create a migration file",builder:$e,async handler(e){const t=await Je(e),n=Ue(e);for(const r of ge("prisma migrate-dev",t))await oe(Ae.migrateDev(r,n),r,e)}},Te={command:"reset",describe:"Reset DB",builder:$e,async handler(e){const t=await Je(e),n=Ue(e);for(const r of ge("prisma reset",t))await oe(Ae.reset(r,n),r,e)}},Oe={command:"restore",describe:"Restore DB from Litestream's backup",builder:{...$e,output:{description:'Output path of the restored database. Defaults to "<db|prisma>/restored.sqlite3".',type:"string"}},async handler(e){const t=await Je(e);for(const n of ge("prisma restore",t)){const t=e.output??(n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3");await oe(Ae.restore(n,t),n,e)}}},Ie={command:"seed",describe:"Populate DB with seed data",builder:{...$e,file:{alias:"f",description:"Path of the seed script.",type:"string"}},async handler(e){const t=await Je(e);for(const n of ge("prisma seed",t))await oe(Ae.seed(n,e.file),n,e)}},Ce={command:"setup-db-for-litestream",describe:"Setup DB for Litestream",builder:$e,async handler(e){const t=await Je(e);for(const n of ge("prisma setup-db-for-litestream",t))await oe(Ae.setUpDBForLitestream(n),n,e)}},Be={command:"studio [db-url-or-path]",describe:"Open Prisma Studio",builder:{...$e,"db-url-or-path":{description:"URL or path to the database",type:"string"},restored:{description:"Whether to open the default restored database (<db|prisma>/restored.sqlite3).",type:"boolean"}},async handler(e){if(e.restored&&e.dbUrlOrPath)throw new Error("You cannot specify both --restored and --db-url-or-path.");const t=await Je(e),n=Ue(e,["db-url-or-path","restored"]);for(const r of ge("prisma studio",t)){const t=e.restored?r.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3":e.dbUrlOrPath?.toString();await oe(Ae.studio(r,t,n),r,e)}}},Le={command:"$0 <args..>",describe:"Pass the command and arguments to prisma as is",builder:{args:{type:"array"}},async handler(e){const t=await Je(e),n=[(e.args?.join(" ")??"").trimEnd(),Ue(e,["args"])].filter(Boolean).join(" ");for(const r of ge(`prisma ${n}`,t))await oe(`PRISMA ${n}`,r,e)}};function Fe(t){const n=`${t.packageJson.dependencies?.blitz?"db":"prisma"}/mount/prod.sqlite3`,r={CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME:t.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY:t.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY},s=Object.entries(r).filter(([,e])=>!e).map(([e])=>e);if(s.length>0)throw new Error(`Missing environment variables for Litestream: ${s.join(", ")}`);const o="staging"===t.env.WB_ENV?"5m":"1h",i=`dbs:\n - path: ${n}\n replica:\n type: s3\n endpoint: https://${r.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n bucket: ${r.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n access-key-id: ${r.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n secret-access-key: ${r.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n snapshot-interval: 24h # Create a backup per day\n retention: 72h # Keep backups for 3 days\n retention-check-interval: ${o}\n sync-interval: 60s\n`,a="/etc/litestream.yml";try{e.writeFileSync(a,i),console.info(`Generated ${a}`)}catch(e){const t=e instanceof Error?e.message:String(e);throw new Error(`Failed to write ${a}: ${t}`)}}async function Je(e){const t=await M(e);t||(console.error(d.red("No project found.")),process.exit(1));const n=t.descendants.filter(e=>e.packageJson.dependencies?.prisma??e.packageJson.devDependencies?.prisma);return 0===n.length&&(console.error(d.red("No prisma project found.")),process.exit(1)),n}function Ue(e,t=[]){const n=[],r=Object.keys(Ee),s=Object.values(Ee).flatMap(e=>"alias"in e?Array.isArray(e.alias)?e.alias:[e.alias]:[]).map(String),o=new Set([...t,...r,...s,"_","$0"]);for(const[t,r]of Object.entries(e))if(!o.has(t)){const s=t.replaceAll(/[A-Z]/g,e=>`-${e.toLowerCase()}`);if(s!==t&&void 0!==e[s])continue;if("boolean"==typeof r&&r)n.push(`--${t}`);else if("string"==typeof r||"number"==typeof r)n.push(`--${t}`,String(r));else if(Array.isArray(r))for(const e of r)n.push(`--${t}`,String(e))}return n.join(" ")}const We={command:"retry [command] [args...]",describe:"Retry the given command until it succeeds",builder:{retry:{description:"A maximum retry count",type:"number",alias:"r",default:3}},async handler(e){const t=z(e);t||(console.error(d.red("No project found.")),process.exit(1));const n=[e.command,...e.args??[],...e._.slice(1)].filter(Boolean);let r=0;for(let s=0;s<e.retry;s++)if(s>0&&console.info(`\n${d.yellow(`#${s} Retrying: ${n.join(" ")}`)}`),r=await oe(n.join(" "),t,e,{exitIfFailed:!1,onSignal:e=>{e&&process.exit(1)}}),0===r)return;process.exit(r)}},ze={command:"setup",describe:"Setup development environment. .env files are ignored.",builder:{},async handler(e){await async function(e,t){const n=await M(e,!1,t);n||(console.error(d.red("No project found.")),process.exit(1));for(const t of ge("setup",n.descendants)){const r=await h.readdir(t.dirPath,{withFileTypes:!0});if(t===n.root){if("darwin"===g.platform()){const n=["pstree"];await ie(`brew install ${n.join(" ")}`,t,e)}r.some(e=>e.isFile()&&e.name.includes("-version"))&&await oe("asdf install",t,e,{exitIfFailed:!1})}if(r.some(e=>e.isFile()&&"pyproject.toml"===e.name)){await ie("poetry config virtualenvs.in-project true",t,e);const[,n]=o.execSync("asdf current python").toString().trim().split(/\s+/);await ie(`poetry env use ${n}`,t,e),await re.promiseAll(),await oe("poetry run pip install --upgrade pip",t,e),await oe("poetry install --ansi",t,e)}t!==n.root&&n.root.packageJson.scripts?.["gen-code"]||!t.packageJson.scripts?.["gen-code"]||await oe(`${K} gen-code`,t,e)}const r=n.descendants.find(e=>e.packageJson.devDependencies?.playwright);r&&await oe(`${K} playwright install --with-deps`,r,e)}(e)}};function Me(e){return e.silent?" > /dev/null":""}const Ye=new Set;async function Ve(e,t){const n=await async function(e){for(const t of["127.0.0.1","::"]){if(!await Ke(t,e))return!1}return!0}(e);n||await qe(e,t);const r=async()=>{Ye.has(e)||(Ye.add(e),await qe(e,t))};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,r)}async function qe(e,t){await async function(e,t){await async function(e,t){try{const n=await async function(e,t){const{stdout:n}=await w("docker",["ps","-q",...e],{cwd:t.dirPath,env:t.env});return n.split(/\s+/).map(e=>e.trim()).filter(Boolean)}(e,t);if(0===n.length)return;await w("docker",["rm","-f",...n],{cwd:t.dirPath,env:t.env})}catch{}}(["--filter",`publish=${e}`],t)}(e,t);try{await f(e)}catch{}}async function Ge(e,t){const n=Number(e);if(!n)throw new Error(`The given port (${n}) is invalid.`);return await Ve(n,t),n}async function Ke(e,t){return new Promise(n=>{const r=b();r.once("error",e=>{"EADDRINUSE"!==e.code?"EAFNOSUPPORT"!==e.code?n(!1):n(!0):n(!1)}),r.once("listening",()=>{r.close(()=>{n(!0)})}),r.listen(t,e)})}const He=new class{buildImage(e,n){const r=e.dockerPackageJson.scripts?.["docker/build/prepare"]?"YARN run docker/build/prepare && ":"";return`cd ${t.dirname(e.findFile("Dockerfile"))}\n && ${r}YARN wb optimizeForDockerBuild --outside\n && YARN wb retry -- docker build -t ${e.dockerImageName}\n --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n --build-arg WB_ENV=${e.env.WB_ENV}\n --build-arg WB_VERSION=${n} .`}stopAndStart(e,t="",n=""){return`${this.stop(e)} && ${this.start(e,t,n)}`}start(e,t="",n=""){!function(e,t){const n=()=>{if(Ye.has(e))return;Ye.add(e),ce(e,t);const{status:n}=a(e,{cwd:t.dirPath,shell:!0,stdio:"inherit"});de(e,n,{})};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,n)}(this.stop(e),e);return`docker run --rm ${n.includes("/bin/bash")?"-it ":""}--publish ${e.env.PORT}:8080 --name ${e.dockerImageName} ${t} ${e.dockerImageName} ${n}`}stop(e){return`true $(docker rm -f $(docker container ls -q -f name=${e.dockerImageName}) 2> /dev/null)`}stopAll(){return"true $(docker rm -f $(docker ps -q) 2> /dev/null)"}};class Qe{constructor(e){this.shouldWaitAndOpenApp=e}buildDocker(e,t){return He.buildImage(e,t)}async startDev(e,t){return await Ge(e.env.PORT,e),this.shouldWaitAndOpenApp?`YARN concurrently --raw --kill-others-on-fail\n "${this.startDevProtected(e,t)}"\n "${this.waitAndOpenApp(e)}"`:this.startDevProtected(e,t)}async startProduction(e,t){return await Ge(e.env.PORT,e),this.shouldWaitAndOpenApp?`YARN concurrently --raw --kill-others-on-fail\n "${this.startProductionProtected(e,t)}"\n "${this.waitAndOpenApp(e)}"`:this.startProductionProtected(e,t)}async startTest(e,t){return await Ge(e.env.PORT,e),this.startProductionProtected(e,t)}async startDocker(e,t){return await Ge(e.env.PORT,e),this.shouldWaitAndOpenApp?`${this.buildDocker(e,"development")}\n && YARN concurrently --raw --kill-others-on-fail\n "${He.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}"\n "${this.waitAndOpenApp(e)}"`:`${this.buildDocker(e,"development")}\n && ${He.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProductionProtected(e,t){const n=function(e){try{return e.findFile("ecosystem.config.cjs")}catch{return}}(e),r=void 0===n?[("YARN wb buildIfNeeded "+(t.verbose?"--verbose":"")).trim(),`node dist/index.js ${t.normalizedArgsText??""}`.trim()]:[e.buildCommand,`pm2-runtime start --no-autorestart ${n}`];return[...e.hasPrisma?Ae.migrate(e).split("&&"):[],...r].filter(Boolean).map(e=>`${e} ${Me(t)}`.trim()).join(" && ")}testE2EDev(e,t,n){return this.testE2EProtected(e,t,this.startDevProtected(e,t),n)}testE2EProduction(e,t,n){return this.testE2EProtected(e,t,this.startProductionProtected(e,t),n)}testE2EDocker(e,t,n){return this.testE2EProtected(e,t,He.stopAndStart(e),n)}async testStart(e,t){return await Ge(e.env.PORT,e),`NODE_ENV="" YARN concurrently --kill-others --raw --success first "${this.startDevProtected(e,t)}" "${this.waitApp(e)}"`}async testE2EProtected(e,t,n,{playwrightArgs:r="test test/e2e/"}){const s=await Ge(e.env.PORT,e),o=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"",i=function(e,t){const n="BUN playwright",r=t?.join(" ")||"test/e2e/";if(!e.startsWith("test ")||!t?.length)return`${n} ${e}`;const s=e.slice(5).trim(),o=s.length>0?s.split(/\s+/):[];!o[0]||o[0].startsWith("-")?o.unshift(r):o[0]=r;return`${n} test ${o.join(" ")}`}(r,t.targets);return e.skipLaunchingServerForPlaywright?`${i}${o}`:`YARN concurrently --kill-others --raw --success first\n "${n} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:${s}\n && ${i}${o}"`}testUnit(e,t){const n=t.targets?.join(" ")||"test/unit/";return e.hasVitest?`YARN vitest run ${n} --color --passWithNoTests --allowOnly`:e.isBunAvailable?`bun test ${n}`:'echo "No tests."'}waitApp(e){const t=e.env.PORT;return`wait-on -t 10000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 500 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${t}`}waitAndOpenApp(e){const t=e.env.PORT;return`${this.waitApp(e)} || wait-on http-get://127.0.0.1:${t} && open-cli http://\${HOST:-localhost}:${t}`}}const Xe=new class extends Qe{constructor(){super(!0)}startDevProtected(e,t){return`blitz dev ${t.normalizedArgsText??""}`}};const Ze=new class extends Qe{constructor(){super(!1)}startDevProtected(e,t){return`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`}async testE2EProtected(e,t,n){const r=await Ge(e.env.PORT,e),s=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"";return`YARN concurrently --kill-others --raw --success first\n "${n} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:${r}\n && vitest run ${t.targets&&t.targets.length>0?t.targets.join(" "):"test/e2e/"} --color --passWithNoTests --allowOnly${s}"`}};const et=new class extends Qe{constructor(){super(!0)}startDevProtected(e,t){return`next dev --turbopack ${t.normalizedArgsText??""}`}};const tt=new class extends Qe{constructor(){super(!1)}startDevProtected(e,t){throw new Error("This method should not be called.")}startDev(e,t){return Promise.resolve(`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`)}startProduction(e,t){return Promise.resolve(`${e.buildCommand} && ${q} dist/index.js ${t.normalizedArgsText??""} | tee server.log`)}startTest(){return Promise.resolve("echo 'do nothing.'")}startDocker(e,t){return Promise.resolve(`${this.buildDocker(e,"development")} && ${He.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`)}testE2EDev(){return Promise.resolve("echo 'do nothing.'")}testE2EProduction(){return Promise.resolve("echo 'do nothing.'")}testE2EDocker(){return Promise.resolve("echo 'do nothing.'")}testStart(){return Promise.resolve("echo 'do nothing.'")}};const nt=new class extends Qe{constructor(){super(!0)}startDevProtected(e,t){return`remix dev ${t.normalizedArgsText??""}`}},rt=["express","fastify","elysia","hono"],st={command:"start [args..]",describe:"Start app",builder:{watch:{description:"Whether to watch files",type:"boolean"},args:{description:"Arguments for core command",type:"array",alias:"a",default:[]},"docker-options":{description:'Arguments for "docker run"',type:"array",default:[]},mode:{description:"Start mode: dev[elopment] (default) | staging | docker | docker-debug | test",type:"string",alias:"m"}},async handler(e){!function(e){e.normalizedArgsText=[...e.args??[],...e._?.slice(1)??[]].map(e=>`'${e}'`).join(" "),e.normalizedDockerOptionsText=(e.dockerOptions??[]).map(e=>`'${e}'`).join(" ")}(e);const t=await M(e);t||(console.error(d.red("No project found.")),process.exit(1));for(const n of t.descendants){const t=n.packageJson.dependencies??{},r=n.packageJson.devDependencies??{};let s;if(t.blitz)s=Xe;else if(t.next)s=et;else if(r["@remix-run/dev"])s=nt;else if(rt.some(e=>t[e])&&!t["firebase-functions"]||n.hasDockerfile&&/EXPOSE\s+8080/.test(n.dockerfile))s=Ze;else{if(!t["build-ts"]&&!r["build-ts"])continue;s=tt}switch(console.info(`Running "start" for ${n.name} ...`),e.mode??"dev"){case"dev":case"development":process.env.WB_ENV||="development",await oe(await s.startDev(n,e),n,e);break;case"staging":process.env.WB_ENV||="staging",await oe(await s.startProduction(n,e),n,e);break;case"docker":process.env.WB_ENV||="staging",await oe(await s.startDocker(n,e),n,e);break;case"docker-debug":process.env.WB_ENV||="staging",e.normalizedArgsText="'/bin/bash'",await oe(await s.startDocker(n,e),n,e);break;case"test":{process.env.WB_ENV||="test";const t=await s.startTest(n,e);await oe(t,n,e);break}default:throw new Error(`Unknown start mode: ${e.mode}`)}}}},ot={command:"test [targets...]",describe:"Test project. If you pass no arguments, it will run all tests.",builder:{e2e:{description:"E2e test mode: headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace",type:"string",choices:["headless","headless-dev","headed","headed-dev","docker","docker-debug","debug","generate","trace"],default:"headless"},silent:{description:"Reduce redundant outputs",type:"boolean"},"unit-timeout":{description:"Timeout for unit tests",type:"number"},targets:{description:"Test target paths",type:"array"}},async handler(n){await async function(n){const r=await M(n);r||(console.error(d.red("No project found.")),process.exit(1));r.descendants.length>1&&(process.env.CI="1");process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";const s=n.targets??[],o=0===s.length,i=s.some(e=>e.includes("/e2e")),a=s.some(e=>e.includes("/unit")),c=o||a,l=o||i;for(const o of r.descendants){const r=o.packageJson.dependencies??{},i=o.packageJson.devDependencies??{};let a;if(a=r.blitz?Xe:r.next?et:i["@remix-run/dev"]?nt:rt.some(e=>r[e])&&!r["firebase-functions"]?Ze:tt,console.info(`Running "test" for ${o.name} ...`),c&&e.existsSync(t.join(o.dirPath,"test","unit"))){const e=s.filter(e=>e.includes("/unit")),t={...n,targets:e.length>0?e:void 0};await oe(a.testUnit(o,t),o,n,{timeout:n.unitTimeout})}if(!l||!e.existsSync(t.join(o.dirPath,"test","e2e")))continue;const d=s.filter(e=>e.includes("/e2e")),u={...n,targets:d.length>0?d:void 0};switch(n.e2e){case"headless":await oe(await a.testE2EProduction(o,u,{}),o,n);continue;case"headless-dev":await oe(await a.testE2EDev(o,u,{}),o,n);continue;case"docker":await it(o,u,a);continue;case"docker-debug":{const e=d.length>0?d.join(" "):"test/e2e/";await it(o,u,a,`test ${e} --debug`);continue}}if(r.blitz||r.next||i["@remix-run/dev"]){const e=d.length>0?d.join(" "):"test/e2e/";switch(n.e2e){case"headed":await oe(await a.testE2EProduction(o,u,{playwrightArgs:`test ${e} --headed`}),o,n);break;case"headed-dev":await oe(await a.testE2EDev(o,u,{playwrightArgs:`test ${e} --headed`}),o,n);break;case"debug":await oe(await a.testE2EProduction(o,u,{playwrightArgs:`test ${e} --debug`}),o,n);break;case"generate":await oe(await a.testE2EProduction(o,u,{playwrightArgs:`codegen http://localhost:${o.env.PORT}`}),o,n);break;case"trace":await oe("BUN playwright show-trace",o,n)}}}}(n)}};async function it(e,t,n,r){e.env.WB_DOCKER||="1",await oe(`${n.buildDocker(e,"test")}${Me(t)}`,e,t),process.exitCode=await oe(await n.testE2EDocker(e,t,{playwrightArgs:r}),e,t,{exitIfFailed:!1}),await oe(He.stop(e),e,t)}const at={command:"test-on-ci",describe:"Test project on CI with no options.",builder:{silent:{description:"Reduce redundant outputs",type:"boolean"}},async handler(n){await async function(n){const r=await M(n);r||(console.error(d.red("No project found.")),process.exit(1));process.env.CI||="1",process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";for(const s of r.descendants){const r=s.packageJson.dependencies??{},o=s.packageJson.devDependencies??{};let i;if(i=r.blitz?Xe:r.next?et:o["@remix-run/dev"]?nt:rt.some(e=>r[e])&&!r["firebase-functions"]?Ze:tt,console.info(`Running "test-on-ci" for ${s.name} ...`),await ie(He.stopAll(),s,n),e.existsSync(t.join(s.dirPath,"test","unit"))&&await ie(i.testUnit(s,n).replaceAll(" --allowOnly",""),s,n),await ie(await i.testStart(s,n),s,n),await re.promiseAll(),e.existsSync(t.join(s.dirPath,"test","e2e"))){s.hasDockerfile&&(s.env.WB_DOCKER||="1",await oe(`${i.buildDocker(s,"test")}${Me(n)}`,s,n));const e=s.hasDockerfile?await i.testE2EDocker(s,n,{}):await i.testE2EProduction(s,n,{});process.exitCode=await oe(e.replaceAll(" --allowOnly",""),s,n,{exitIfFailed:!1}),await oe(He.stop(s),s,n)}}}(n)}};const ct={command:"typecheck",describe:"Run type checking. .env files are ignored.",builder:{},async handler(n){const r=await M(n,!1);r||(console.error(d.red("No project found.")),process.exit(1));let s=!1;const o=r.descendants.map(async o=>{const i=[];for(o.packageJson.workspaces?o.hasSourceCode&&(o.packageJson.dependencies?.typescript||o.packageJson.devDependencies?.typescript)&&i.push("BUN tsc --noEmit --Pretty"):((o.packageJson.dependencies?.typescript||o.packageJson.devDependencies?.typescript)&&i.push("BUN tsc --noEmit --Pretty"),o.packageJson.devDependencies?.pyright&&i.push("YARN pyright"));i.length>0;){const a=await ie(i.join(" && "),o,n,{ci:r.descendants.length>1,exitIfFailed:!1,forceColor:!0}),c=t.join(o.dirPath,".next");if(!a||!e.existsSync(c))return a;e.rmSync(c,{force:!0,recursive:!0}),console.info(d.yellow("Removed `.next` directory. We will re-try type checking.")),s=!0}}),i=await Promise.all(o);let a=0;for(const[e,t]of i.entries())if(t){(r.descendants[e]?.packageJson.dependencies??{}).blitz&&console.info(d.yellow('Please try "yarn gen-code" if you face unknown type errors.')),a=t}a||console.info(d.green(s?"-----\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.":"No type errors found.")),process.exit(a)}},dt={...ct,command:"tc"};await r(s(process.argv)).scriptName("wb").options(Ee).middleware(e=>{const n=e["working-dir"];if(n){const e=t.resolve(n);process.chdir(e)}!function(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const t of Object.keys(e)){const n=t.toUpperCase();(n.startsWith("NPM_")||n.startsWith("YARN_")||n.startsWith("BERRY_")||"PROJECT_CWD"===n||"INIT_CWD"===n)&&delete e[t]}}(process.env)}).command(H).command(ne).command(he).command(be).command(Re).command(We).command(ze).command(st).command(ot).command(at).command(ct).command(dt).demandCommand().strict().version(function(){let n=t.dirname(new URL(import.meta.url).pathname);for(;!e.existsSync(t.join(n,"package.json"));)n=t.dirname(n);return JSON.parse(e.readFileSync(t.join(n,"package.json"),"utf8")).version}()).help().argv;for(const e of["SIGINT","SIGTERM","SIGQUIT"])process.on(e,()=>{n(process.pid),process.exit()});
|
|
10
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../../shared-lib-node/src/env.ts","../../shared-lib-node/src/spawn.ts","../../../node_modules/at-decorators/dist/hash.js","../../../node_modules/at-decorators/dist/oson/constructors.js","../../../node_modules/at-decorators/dist/oson/stringify.js","../../../node_modules/at-decorators/dist/getCacheKey.js","../../../node_modules/at-decorators/dist/memoizeOne.js","../src/utils/ci.ts","../src/project.ts","../src/utils/runtime.ts","../src/commands/buildIfNeeded.ts","../../shared-lib/src/error.ts","../src/commands/killPortIfNonCi.ts","../src/utils/promisePool.ts","../src/scripts/run.ts","../src/commands/lint.ts","../src/commands/commandUtils.ts","../src/commands/optimizeForDockerBuild.ts","../src/scripts/prismaScripts.ts","../src/sharedOptionsBuilder.ts","../src/commands/prisma.ts","../src/commands/retry.ts","../src/commands/setup.ts","../src/scripts/builder.ts","../src/utils/process.ts","../src/utils/port.ts","../src/scripts/dockerScripts.ts","../src/scripts/execution/baseScripts.ts","../src/scripts/execution/blitzScripts.ts","../src/scripts/execution/httpServerScripts.ts","../src/scripts/execution/nextScripts.ts","../src/scripts/execution/plainAppScripts.ts","../src/scripts/execution/remixScripts.ts","../src/commands/httpServerPackages.ts","../src/commands/start.ts","../src/commands/test.ts","../src/commands/testOnCi.ts","../src/commands/typecheck.ts","../src/index.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { config } from 'dotenv';\nimport { expand } from 'dotenv-expand';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nexport const yargsOptionsBuilderForEnv = {\n  env: {\n    description: '.env files to be loaded.',\n    type: 'array',\n  },\n  'cascade-env': {\n    description:\n      'Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.',\n    type: 'string',\n  },\n  'cascade-node-env': {\n    description: 'Same with --cascade-env=<NODE_ENV || \"development\">. Preferred over `auto-cascade-env`.',\n    type: 'boolean',\n  },\n  'auto-cascade-env': {\n    description: 'Same with --cascade-env=<WB_ENV || NODE_ENV || \"development\">.',\n    type: 'boolean',\n    default: true,\n  },\n  'include-root-env': {\n    description: 'Include .env files in root directory if the project is in a monorepo and --env option is not used.',\n    type: 'boolean',\n    default: true,\n  },\n  'check-env': {\n    description: 'Check whether the keys of the loaded .env files are same with the given .env file.',\n    type: 'string',\n    default: '.env.example',\n  },\n  verbose: {\n    description: 'Whether to show verbose information',\n    type: 'boolean',\n    alias: 'v',\n  },\n} as const;\n\nexport type EnvReaderOptions = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof yargsOptionsBuilderForEnv>>>;\n\n/**\n * This function reads environment variables from `.env` files.\n * Note it does not assign them in `process.env`.\n * @return [envVars, [envPaths, envVarCount][]]\n * */\nexport function readEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): [Record<string, string>, [string, number][]] {\n  let envPaths = (argv.env ?? []).map((envPath) => path.resolve(cwd, envPath.toString()));\n  const cascade =\n    argv.cascadeEnv ??\n    (argv.cascadeNodeEnv\n      ? process.env.NODE_ENV || 'development'\n      : argv.autoCascadeEnv\n        ? process.env.WB_ENV || process.env.NODE_ENV || 'development'\n        : undefined);\n  if (typeof cascade === 'string') {\n    if (envPaths.length === 0) {\n      envPaths.push(path.join(cwd, '.env'));\n      if (argv.includeRootEnv) {\n        const rootPath = path.resolve(cwd, '..', '..');\n        if (fs.existsSync(path.join(rootPath, 'package.json'))) {\n          envPaths.push(path.join(rootPath, '.env'));\n        }\n      }\n    }\n    envPaths = envPaths.flatMap((envPath) =>\n      cascade\n        ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n        : [`${envPath}.local`, envPath]\n    );\n  }\n  envPaths = envPaths.filter((envPath) => fs.existsSync(envPath)).map((envPath) => path.relative(cwd, envPath));\n  if (argv.verbose) {\n    console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`);\n    console.info('Reading env files:', envPaths.join(', '));\n  }\n\n  const envPathAndEnvVarCountPairs: [string, number][] = [];\n  const envVars: Record<string, string> = {};\n  for (const envPath of envPaths) {\n    let count = 0;\n    for (const [key, value] of Object.entries(readEnvFile(path.join(cwd, envPath)))) {\n      if (!(key in envVars)) {\n        envVars[key] = value;\n        count++;\n      }\n    }\n    envPathAndEnvVarCountPairs.push([envPath, count]);\n    if (argv.verbose && count > 0) {\n      console.info(`Read ${count} environment variables from ${envPath}`);\n    }\n  }\n\n  if (argv.checkEnv) {\n    const exampleKeys = Object.keys(readEnvFile(path.join(cwd, argv.checkEnv)));\n    const missingKeys = exampleKeys.filter((key) => !(key in envVars));\n    if (missingKeys.length > 0) {\n      throw new Error(`Missing environment variables in [${envPaths.join(', ')}]: [${missingKeys.join(', ')}]`);\n    }\n  }\n  return [expand({ parsed: envVars, processEnv: {} }).parsed ?? envVars, envPathAndEnvVarCountPairs];\n}\n\n/**\n * This function read environment variables from `.env` files and assign them in `process.env`.\n * */\nexport function readAndApplyEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): Record<string, string | undefined> {\n  const [envVars] = readEnvironmentVariables(argv, cwd);\n  Object.assign(process.env, envVars);\n  return envVars;\n}\n\nconst cachedEnvVars = new Map<string, Record<string, string>>();\n\nfunction readEnvFile(filePath: string): Record<string, string> {\n  const cached = cachedEnvVars.get(filePath);\n  if (cached) return cached;\n\n  const parsed = config({ path: path.resolve(filePath), processEnv: {} }).parsed ?? {};\n  cachedEnvVars.set(filePath, parsed);\n  return parsed;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n  // Remove npm & yarn environment variables from process.env\n  if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n    envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n      // Temporary directory in macOS\n      .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n      // Temporary directories in Linux\n      .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n      .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n  }\n  for (const key of Object.keys(envVars)) {\n    const upperKey = key.toUpperCase();\n    if (\n      upperKey.startsWith('NPM_') ||\n      upperKey.startsWith('YARN_') ||\n      upperKey.startsWith('BERRY_') ||\n      upperKey === 'PROJECT_CWD' ||\n      upperKey === 'INIT_CWD'\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete envVars[key];\n    }\n  }\n}\n","import type {\n  SpawnOptions,\n  SpawnOptionsWithoutStdio,\n  SpawnOptionsWithStdioTuple,\n  SpawnSyncReturns,\n  StdioNull,\n  StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport treeKill from 'tree-kill';\n\n/**\n * Return type for spawnAsync function, based on SpawnSyncReturns but without output and error properties\n */\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\n/**\n * Options for spawnAsync function, extending various Node.js spawn options with additional functionality\n */\nexport type SpawnAsyncOptions = (\n  | SpawnOptionsWithoutStdio\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n  | SpawnOptions\n) & {\n  /** Input string to write to the spawned process's stdin */\n  input?: string;\n  /** If true, stderr output will be merged into stdout */\n  mergeOutAndError?: boolean;\n  /** If true, the spawned process will be killed when the parent process exits */\n  killOnExit?: boolean;\n  /** If true, enables verbose logging of process operations */\n  verbose?: boolean;\n  /** If true, stdout data will be printed to console as it's received */\n  printingStdout?: boolean;\n  /** If true, stderr data will be printed to console as it's received */\n  printingStderr?: boolean;\n};\n\n/**\n * Spawns a child process asynchronously and returns a promise that resolves with the process results\n *\n * This function provides a Promise-based wrapper around Node.js's spawn function with additional features:\n * - Automatic encoding of stdout/stderr as UTF-8\n * - Option to merge stderr into stdout\n * - Option to automatically kill the process on parent exit\n * - Option to provide input via stdin\n * - Verbose logging capability\n *\n * @param command - The command to run\n * @param args - List of string arguments\n * @param options - Configuration options for the spawned process\n * @returns Promise that resolves with the process results including pid, stdout, stderr, status, and signal\n * @throws Will reject the promise if the process fails to spawn or encounters an error\n *\n * @example\n * ```typescript\n * const result = await spawnAsync('ls', ['-la'], { verbose: true });\n * console.log(result.stdout);\n * ```\n */\nexport async function spawnAsync(\n  command: string,\n  args?: readonly string[],\n  options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n  return new Promise((resolve, reject) => {\n    try {\n      const proc = spawn(command, args ?? [], options ?? {});\n      // `setEncoding` is undefined in Bun\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stdout?.setEncoding?.('utf8');\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stderr?.setEncoding?.('utf8');\n\n      let stdout = '';\n      let stderr = '';\n      proc.stdout?.on('data', (data: string) => {\n        stdout += data;\n        if (options?.printingStdout) {\n          process.stdout.write(data);\n        }\n      });\n      proc.stderr?.on('data', (data: string) => {\n        if (options?.mergeOutAndError) {\n          stdout += data;\n        } else {\n          stderr += data;\n        }\n        if (options?.printingStderr) {\n          process.stderr.write(data);\n        }\n      });\n\n      let stopped = false;\n      const stopProcess = (): void => {\n        if (stopped || !proc.pid) return;\n\n        stopped = true;\n        if (options?.verbose) {\n          console.info(`treeKill(${proc.pid})`);\n        }\n        treeKill(proc.pid);\n      };\n      if (options?.killOnExit) {\n        process.on('beforeExit', stopProcess);\n        process.on('SIGINT', stopProcess);\n      }\n\n      proc.on('error', (error) => {\n        process.removeListener('beforeExit', stopProcess);\n        process.removeListener('SIGINT', stopProcess);\n        proc.removeAllListeners('close');\n        reject(error);\n      });\n      proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n        process.removeListener('beforeExit', stopProcess);\n        process.removeListener('SIGINT', stopProcess);\n        if (proc.pid === undefined) {\n          reject(new Error('Process has no pid.'));\n        } else {\n          resolve({\n            pid: proc.pid,\n            stdout,\n            stderr,\n            status: code,\n            signal,\n          });\n        }\n      });\n\n      if (options?.input) {\n        proc.stdin?.write(options.input);\n        proc.stdin?.end();\n      }\n    } catch (error) {\n      // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n      reject(error);\n    }\n  });\n}\n","/**\n * [js-sha3]{@link https://github.com/emn178/js-sha3}\n *\n * @version 0.9.3\n * @author Chen, Yi-Cyuan [emn178@gmail.com]\n * @copyright Chen, Yi-Cyuan 2015-2023\n * @license MIT\n */\nconst t=[...\"0123456789abcdef\"],s=[6,1536,393216,100663296],i=[0,8,16,24],e=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];function o(t){return new h(512,s,512).update(t).hex()}const n=t=>{const s=[];for(const[i,e]of t.entries())s[i]=e;return s};class h{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(t,s,i){this.padding=s,this.outputBits=i,this.blockCount=1600-(t<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=i>>5,this.extraBytes=(31&i)>>3;for(let t=0;t<50;++t)this.s[t]=0}update(t){if(this.finalized)throw new Error(\"finalize already called\");const s=this.blocks,e=this.byteCount,o=t.length,n=this.blockCount,h=this.s;let l,c,f=0;for(;f<o;){if(this.reset)for(this.reset=!1,s[0]=this.block,l=1;l<n+1;++l)s[l]=0;for(l=this.start;f<o&&l<e;++f)c=t.codePointAt(f)||0,c<128?s[l>>2]|=c<<i[3&l++]:c<2048?(s[l>>2]|=(192|c>>6)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):c<55296||c>=57344?(s[l>>2]|=(224|c>>12)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):(c=65536+((1023&c)<<10|1023&(t.codePointAt(++f)||0)),s[l>>2]|=(240|c>>18)<<i[3&l++],s[l>>2]|=(128|c>>12&63)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]);if(this.lastByteIndex=l,l>=e){for(this.start=l-e,this.block=s[n],l=0;l<n;++l)h[l]^=s[l];r(h),this.reset=!0}else this.start=l}return this}finalize(){if(this.finalized)return;this.finalized=!0;const t=this.blocks;let s=this.lastByteIndex;const i=this.blockCount,e=this.s;if(t[s>>2]|=this.padding[3&s],this.lastByteIndex===this.byteCount)for(t[0]=t[i],s=1;s<i+1;++s)t[s]=0;for(t[i-1]|=2147483648,s=0;s<i;++s)e[s]^=t[s];r(e)}hex(){this.finalize();const s=this.blockCount;let i=this.s;const e=this.outputBlocks,o=this.extraBytes;let h,l=0,c=0,f=\"\";for(;c<e;){for(l=0;l<s&&c<e;++l,++c)h=i[l],f+=t[h>>4&15]+t[15&h]+t[h>>12&15]+t[h>>8&15]+t[h>>20&15]+t[h>>16&15]+t[h>>28&15]+t[h>>24&15];c%s===0&&(i=n(i),r(i),l=0)}return o&&(h=i[l],f+=t[h>>4&15]+t[15&h],o>1&&(f+=t[h>>12&15]+t[h>>8&15]),o>2&&(f+=t[h>>20&15]+t[h>>16&15])),f}}const r=function(t){let s,i,o,n,h,r,l,c,f,a,u,d,b,k,y,x,B,p,C,z,I,g,w,A,P,E,j,m,q,v,D,F,G,H,J,K,L,M,N,O,Q,R,S,T,U,V,W,X,Y,Z,$,_,tt,st,it,et,ot,nt,ht,rt,lt,ct,ft;for(o=0;o<48;o+=2)n=t[0]^t[10]^t[20]^t[30]^t[40],h=t[1]^t[11]^t[21]^t[31]^t[41],r=t[2]^t[12]^t[22]^t[32]^t[42],l=t[3]^t[13]^t[23]^t[33]^t[43],c=t[4]^t[14]^t[24]^t[34]^t[44],f=t[5]^t[15]^t[25]^t[35]^t[45],a=t[6]^t[16]^t[26]^t[36]^t[46],u=t[7]^t[17]^t[27]^t[37]^t[47],d=t[8]^t[18]^t[28]^t[38]^t[48],b=t[9]^t[19]^t[29]^t[39]^t[49],s=d^(r<<1|l>>>31),i=b^(l<<1|r>>>31),t[0]^=s,t[1]^=i,t[10]^=s,t[11]^=i,t[20]^=s,t[21]^=i,t[30]^=s,t[31]^=i,t[40]^=s,t[41]^=i,s=n^(c<<1|f>>>31),i=h^(f<<1|c>>>31),t[2]^=s,t[3]^=i,t[12]^=s,t[13]^=i,t[22]^=s,t[23]^=i,t[32]^=s,t[33]^=i,t[42]^=s,t[43]^=i,s=r^(a<<1|u>>>31),i=l^(u<<1|a>>>31),t[4]^=s,t[5]^=i,t[14]^=s,t[15]^=i,t[24]^=s,t[25]^=i,t[34]^=s,t[35]^=i,t[44]^=s,t[45]^=i,s=c^(d<<1|b>>>31),i=f^(b<<1|d>>>31),t[6]^=s,t[7]^=i,t[16]^=s,t[17]^=i,t[26]^=s,t[27]^=i,t[36]^=s,t[37]^=i,t[46]^=s,t[47]^=i,s=a^(n<<1|h>>>31),i=u^(h<<1|n>>>31),t[8]^=s,t[9]^=i,t[18]^=s,t[19]^=i,t[28]^=s,t[29]^=i,t[38]^=s,t[39]^=i,t[48]^=s,t[49]^=i,k=t[0],y=t[1],V=t[11]<<4|t[10]>>>28,W=t[10]<<4|t[11]>>>28,m=t[20]<<3|t[21]>>>29,q=t[21]<<3|t[20]>>>29,rt=t[31]<<9|t[30]>>>23,lt=t[30]<<9|t[31]>>>23,R=t[40]<<18|t[41]>>>14,S=t[41]<<18|t[40]>>>14,H=t[2]<<1|t[3]>>>31,J=t[3]<<1|t[2]>>>31,x=t[13]<<12|t[12]>>>20,B=t[12]<<12|t[13]>>>20,X=t[22]<<10|t[23]>>>22,Y=t[23]<<10|t[22]>>>22,v=t[33]<<13|t[32]>>>19,D=t[32]<<13|t[33]>>>19,ct=t[42]<<2|t[43]>>>30,ft=t[43]<<2|t[42]>>>30,st=t[5]<<30|t[4]>>>2,it=t[4]<<30|t[5]>>>2,K=t[14]<<6|t[15]>>>26,L=t[15]<<6|t[14]>>>26,p=t[25]<<11|t[24]>>>21,C=t[24]<<11|t[25]>>>21,Z=t[34]<<15|t[35]>>>17,$=t[35]<<15|t[34]>>>17,F=t[45]<<29|t[44]>>>3,G=t[44]<<29|t[45]>>>3,A=t[6]<<28|t[7]>>>4,P=t[7]<<28|t[6]>>>4,et=t[17]<<23|t[16]>>>9,ot=t[16]<<23|t[17]>>>9,M=t[26]<<25|t[27]>>>7,N=t[27]<<25|t[26]>>>7,z=t[36]<<21|t[37]>>>11,I=t[37]<<21|t[36]>>>11,_=t[47]<<24|t[46]>>>8,tt=t[46]<<24|t[47]>>>8,T=t[8]<<27|t[9]>>>5,U=t[9]<<27|t[8]>>>5,E=t[18]<<20|t[19]>>>12,j=t[19]<<20|t[18]>>>12,nt=t[29]<<7|t[28]>>>25,ht=t[28]<<7|t[29]>>>25,O=t[38]<<8|t[39]>>>24,Q=t[39]<<8|t[38]>>>24,g=t[48]<<14|t[49]>>>18,w=t[49]<<14|t[48]>>>18,t[0]=k^~x&p,t[1]=y^~B&C,t[10]=A^~E&m,t[11]=P^~j&q,t[20]=H^~K&M,t[21]=J^~L&N,t[30]=T^~V&X,t[31]=U^~W&Y,t[40]=st^~et&nt,t[41]=it^~ot&ht,t[2]=x^~p&z,t[3]=B^~C&I,t[12]=E^~m&v,t[13]=j^~q&D,t[22]=K^~M&O,t[23]=L^~N&Q,t[32]=V^~X&Z,t[33]=W^~Y&$,t[42]=et^~nt&rt,t[43]=ot^~ht&lt,t[4]=p^~z&g,t[5]=C^~I&w,t[14]=m^~v&F,t[15]=q^~D&G,t[24]=M^~O&R,t[25]=N^~Q&S,t[34]=X^~Z&_,t[35]=Y^~$&tt,t[44]=nt^~rt&ct,t[45]=ht^~lt&ft,t[6]=z^~g&k,t[7]=I^~w&y,t[16]=v^~F&A,t[17]=D^~G&P,t[26]=O^~R&H,t[27]=Q^~S&J,t[36]=Z^~_&T,t[37]=$^~tt&U,t[46]=rt^~ct&st,t[47]=lt^~ft&it,t[8]=g^~k&x,t[9]=w^~y&B,t[18]=F^~A&E,t[19]=G^~P&j,t[28]=R^~H&K,t[29]=S^~J&L,t[38]=_^~T&V,t[39]=tt^~U&W,t[48]=ct^~st&et,t[49]=ft^~it&ot,t[0]^=e[o],t[1]^=e[o+1]};export{o as sha3_512};\n//# sourceMappingURL=hash.js.map\n","const e=\"\",t=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,a,s])=>{e.name=t,e.message=n,void 0===a?delete e.stack:e.stack=a,void 0!==s&&(e.cause=s)}},t={instance:Uint8Array,from:e=>[btoa(a.decode(e))],create:([e])=>n.encode(atob(e))},s={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,a]of t)e.set(n,a)}},o={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},r={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},c={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},d={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,s,o,r,c,d].map(e=>[e.instance.name,e]))}(),n=new TextEncoder,a=new TextDecoder(\"utf-8\");export{t as GLOBAL_CONSTRUCTOR_MAP,e as PLAIN_OBJECT_LABEL};\n//# sourceMappingURL=constructors.js.map\n","import{GLOBAL_CONSTRUCTOR_MAP as t,PLAIN_OBJECT_LABEL as n}from\"./constructors.js\";const e=-1,r=-2,o=-3,i=-4,s=-5,c=-6;function f(n=void 0,e=t){return JSON.stringify(a(n,e))}function u(t){if(void 0===t)return-1;if(\"number\"==typeof t){if(Number.isNaN(t))return-3;if(!Number.isFinite(t))return t<0?-5:-4}return null}const l=[];function a(e,r=t){const o=u(e);if(null!==o)return o;const i=[],s=new Map;return function t(e){const o=u(e);if(null!==o)return o;let c=s.get(e);if(void 0!==c)return c;switch(c=i.length,typeof e){case\"number\":case\"string\":case\"boolean\":i[c]=e,s.set(e,c);break;case\"bigint\":i[c]=[-6,e.toString(16)],s.set(e,c);break;case\"object\":if(null===e)i[c]=e,s.set(e,c);else if(Array.isArray(e)){const n=function(t){if(l.length<t){const n=l.length;l.length=t,l.fill(-2,n,t)}return l.slice(0,t)}(e.length);i[c]=n,s.set(e,c);for(const[r,o]of e.entries())n[r]=t(o)}else{const[o,f]=function(t,e){const r=t.constructor;if(\"function\"==typeof r){const n=r.name,o=e.get(n);if(void 0!==o)return[n,o.from(t)]}const o=Object.entries(t),i=o.length,s=Array.from({length:i+i});for(let t=0;t<i;t++){const n=o[t],e=t+t;s[e]=n[0],s[e+1]=n[1]}return[n,s]}(e,r),u=f.length,l=Array.from({length:u+1});l[0]=o,i[c]=l,s.set(e,c);for(let n=0;n<u;n++)l[n+1]=t(f[n])}}return c}(e),i}export{r as ARRAY_HOLE_INDEX,c as BIG_INT_LABEL,o as NAN_INDEX,s as NEG_INF_INDEX,i as POS_INF_INDEX,e as UNDEFINED_INDEX,a as listify,f as stringify};\n//# sourceMappingURL=stringify.js.map\n","import{sha3_512 as r}from\"./hash.js\";import{stringify as n}from\"./oson/stringify.js\";function o(o,t){return r(n([o,t]))}function t(r,o){return n([r,o])}function i(){return\"\"}export{i as getCacheKeyOfEmptyString,o as getCacheKeyOfHash,t as getCacheKeyOfStringified};\n//# sourceMappingURL=getCacheKey.js.map\n","import{getCacheKeyOfHash as t,getCacheKeyOfEmptyString as e}from\"./getCacheKey.js\";const n=r({getCacheKey:t}),c=r({getCacheKey:e});function r({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:n=t}={}){return function(t,c){let r,o,i;return\"getter\"===c?.kind?function(){const c=n(this,[]),a=Date.now();return(i!==c||a-o>e)&&(i=c,r=t.call(this),o=a),r}:function(...a){const u=n(this,a),h=Date.now();return(i!==u||h-o>e)&&(i=u,r=c?t.call(this,...a):t(...a),o=h),r}}}export{n as memoizeOne,r as memoizeOneFactory,c as memoizeOneWithEmptyHash};\n//# sourceMappingURL=memoizeOne.js.map\n","export function isCI(ciEnv: string | undefined): boolean {\n  return !!ciEnv && ciEnv !== '0' && ciEnv !== 'false';\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport { readEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport { memoizeOne } from 'at-decorators';\nimport { globby } from 'globby';\nimport type { PackageJson } from 'type-fest';\n\nimport { isCI } from './utils/ci.js';\n\nexport class Project {\n  private readonly argv: EnvReaderOptions;\n  private readonly loadEnv: boolean;\n  private readonly pathByName = new Map<string, string>();\n\n  private readonly _dirPath: string;\n\n  constructor(dirPath: string, argv: EnvReaderOptions, loadEnv: boolean) {\n    this._dirPath = path.resolve(dirPath);\n    this.argv = argv;\n    this.loadEnv = loadEnv;\n  }\n\n  @memoizeOne\n  get isBunAvailable(): boolean {\n    try {\n      return /(^|\\n)bun\\s/.test(fs.readFileSync(path.join(this.rootDirPath, '.tool-versions'), 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get buildCommand(): string {\n    return this.packageJson.scripts?.build?.includes('buildIfNeeded')\n      ? 'YARN run build'\n      : this.packageJson.scripts?.build\n        ? `YARN wb buildIfNeeded ${this.argv.verbose ? '--verbose' : ''}`\n        : \"echo 'No build script'\";\n  }\n\n  get dirPath(): string {\n    return this._dirPath;\n  }\n\n  @memoizeOne\n  get rootDirPath(): string {\n    return fs.existsSync(path.join(this.dirPath, '..', '..', 'package.json'))\n      ? path.resolve(this.dirPath, '..', '..')\n      : this.dirPath;\n  }\n\n  @memoizeOne\n  get dockerfile(): string {\n    return fs.readFileSync(this.findFile('Dockerfile'), 'utf8');\n  }\n\n  @memoizeOne\n  get hasDockerfile(): boolean {\n    try {\n      return !!this.findFile('Dockerfile');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get hasSourceCode(): boolean {\n    return fs.existsSync(path.join(this.dirPath, 'src'));\n  }\n\n  @memoizeOne\n  get name(): string {\n    return this.packageJson.name || 'unknown';\n  }\n\n  @memoizeOne\n  get dockerImageName(): string {\n    const name = this.packageJson.name || 'unknown';\n    return name.replaceAll('@', '').replaceAll('/', '-');\n  }\n\n  @memoizeOne\n  get env(): Record<string, string | undefined> {\n    if (!this.loadEnv) return process.env;\n\n    const [envVars, envPathAndLoadedEnvVarCountPairs] = readEnvironmentVariables(this.argv, this.dirPath);\n    for (const [envPath, count] of envPathAndLoadedEnvVarCountPairs) {\n      console.info(`Loaded ${count} environment variables from ${envPath}`);\n    }\n    return { ...envVars, ...process.env };\n  }\n\n  @memoizeOne\n  get packageJson(): PackageJson {\n    return JSON.parse(fs.readFileSync(this.packageJsonPath, 'utf8')) as PackageJson;\n  }\n\n  @memoizeOne\n  get packageJsonPath(): string {\n    return path.join(this.dirPath, 'package.json');\n  }\n\n  @memoizeOne\n  get hasPrisma(): boolean {\n    return !!(this.packageJson.dependencies?.prisma ?? this.packageJson.devDependencies?.prisma);\n  }\n\n  @memoizeOne\n  get hasVitest(): boolean {\n    return !!(this.packageJson.dependencies?.vitest ?? this.packageJson.devDependencies?.vitest);\n  }\n\n  @memoizeOne\n  get skipLaunchingServerForPlaywright(): boolean {\n    if (isCI(this.env.CI)) return false;\n    try {\n      const configPath = this.findFile('playwright.config.ts');\n      return /\\bwebServer\\b/.test(fs.readFileSync(configPath, 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get dockerPackageJson(): PackageJson {\n    return path.dirname(this.findFile('Dockerfile')) === this.dirPath\n      ? this.packageJson\n      : (JSON.parse(\n          fs.readFileSync(path.join(path.dirname(this.findFile('Dockerfile')), 'package.json'), 'utf8')\n        ) as PackageJson);\n  }\n\n  @memoizeOne\n  get binExists(): boolean {\n    let binFound = false;\n    let currentPath = this.dirPath;\n    for (;;) {\n      const binPath = path.join(currentPath, 'node_modules', '.bin');\n      if (fs.existsSync(binPath)) {\n        this.env.PATH = `${binPath}:${this.env.PATH}`;\n        binFound = true;\n      }\n\n      if (fs.existsSync(path.join(currentPath, '.git'))) {\n        break;\n      }\n      const parentPath = path.dirname(currentPath);\n      if (currentPath === parentPath) {\n        break;\n      }\n      currentPath = parentPath;\n    }\n    return binFound;\n  }\n\n  findFile(fileName: string): string {\n    let filePath = this.pathByName.get(fileName);\n    if (filePath) return filePath;\n\n    filePath = [fileName, path.join('..', '..', fileName)]\n      .map((p) => path.resolve(this.dirPath, p))\n      .find((p) => fs.existsSync(p));\n    if (!filePath) {\n      throw new Error(`File not found: ${fileName}`);\n    }\n    this.pathByName.set(fileName, filePath);\n    return filePath;\n  }\n}\n\nexport interface FoundProjects {\n  root: Project;\n  self: Project;\n  descendants: Project[];\n}\n\nexport function findSelfProject(argv: EnvReaderOptions, loadEnv = true, dirPath?: string): Project | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  return new Project(dirPath, argv, loadEnv);\n}\n\nexport async function findDescendantProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Promise<FoundProjects | undefined> {\n  const rootAndSelfProjects = findRootAndSelfProjects(argv, loadEnv, dirPath);\n  if (!rootAndSelfProjects) return;\n\n  return {\n    ...rootAndSelfProjects,\n    descendants:\n      rootAndSelfProjects.root === rootAndSelfProjects.self\n        ? await getAllDescendantProjects(argv, rootAndSelfProjects.root, loadEnv)\n        : [rootAndSelfProjects.self],\n  };\n}\n\nexport function findRootAndSelfProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Omit<FoundProjects, 'descendants'> | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  const thisProject = new Project(dirPath, argv, loadEnv);\n  let rootProject = thisProject;\n  if (!thisProject.packageJson.workspaces && path.dirname(dirPath).endsWith('/packages')) {\n    const rootDirPath = path.resolve(dirPath, '..', '..');\n    if (fs.existsSync(path.join(rootDirPath, 'package.json'))) {\n      rootProject = new Project(rootDirPath, argv, loadEnv);\n    }\n  }\n  return { root: rootProject, self: thisProject };\n}\n\nasync function getAllDescendantProjects(\n  argv: EnvReaderOptions,\n  rootProject: Project,\n  loadEnv: boolean\n): Promise<Project[]> {\n  const projects = [rootProject];\n\n  const workspace = rootProject.packageJson.workspaces;\n  if (!Array.isArray(workspace)) return projects;\n\n  const globPattern: string[] = [];\n  const packageDirs: string[] = [];\n  for (const workspacePath of workspace.map((ws: string) => path.join(rootProject.dirPath, ws))) {\n    if (fs.existsSync(workspacePath)) {\n      packageDirs.push(workspacePath);\n    } else {\n      globPattern.push(workspacePath);\n    }\n  }\n  packageDirs.push(...(await globby(globPattern, { dot: true, onlyDirectories: true })));\n  for (const subPackageDirPath of packageDirs) {\n    if (!fs.existsSync(path.join(subPackageDirPath, 'package.json'))) continue;\n\n    projects.push(new Project(subPackageDirPath, argv, loadEnv));\n  }\n  return projects;\n}\n","export const isRunningOnBun =\n  // Detect `bun --bun run wb ...`. cf. https://bun.sh/guides/util/detect-bun\n  process.versions.bun ||\n  // Detect `bun run wb ...`.\n  process.argv[0]?.endsWith('/bun') ||\n  process.env.npm_execpath?.endsWith('/bun');\n\nexport const runtimeWithArgs = isRunningOnBun ? 'bun --bun run' : 'node';\nexport const packageManager = isRunningOnBun ? 'bun' : 'yarn';\nexport const packageManagerWithRun = isRunningOnBun ? 'bun --bun run' : 'yarn';\n","import child_process from 'node:child_process';\nimport type { BinaryLike, Hash } from 'node:crypto';\nimport { createHash } from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport { ignoreEnoentAsync } from '@willbooster/shared-lib/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isRunningOnBun } from '../utils/runtime.js';\n\nconst builder = {\n  command: {\n    description: 'A build command (default: yarn|bun build)',\n    type: 'string',\n    alias: 'c',\n  },\n} as const;\n\nexport const buildIfNeededCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'buildIfNeeded',\n  describe: 'Build code if changes are detected',\n  builder,\n  async handler(argv) {\n    await buildIfNeeded(argv);\n  },\n};\n\nexport async function buildIfNeeded(\n  // Test code requires Partial<...>\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>>>,\n  projectPathForTesting?: string\n): Promise<boolean | undefined> {\n  const project = findSelfProject(argv, true, projectPathForTesting);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    return true;\n  }\n\n  argv = { ...argv, command: argv.command ?? (isRunningOnBun ? 'bun run build' : 'yarn build') };\n\n  if (!fs.existsSync(path.join(project.rootDirPath, '.git'))) {\n    build(project, argv);\n    return true;\n  }\n\n  const [canSkip, cacheFilePath, contentHash] = await canSkipBuild(project, argv);\n  if (canSkip) {\n    console.info(chalk.green(`Skip to run '${argv.command}' 💫`));\n    return false;\n  }\n\n  if (!build(project, argv)) return;\n\n  if (!argv.dryRun) {\n    await fs.promises.writeFile(cacheFilePath, contentHash, 'utf8');\n  }\n  return true;\n}\n\nfunction build(project: Project, argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>): boolean {\n  console.info(chalk.green(`Run '${argv.command}'`));\n  if (!argv.dryRun) {\n    const ret = child_process.spawnSync(argv.command ?? '', {\n      cwd: project.dirPath,\n      env: project.env,\n      shell: true,\n      stdio: 'inherit',\n    });\n    if (ret.status !== 0) {\n      process.exitCode = ret.status ?? 1;\n      return false;\n    }\n  }\n  return true;\n}\n\nconst ignoringEnvVarNames = new Set(['CI', 'PWDEBUG', 'TMPDIR']);\n\nexport async function canSkipBuild(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>\n): Promise<[boolean, string, string]> {\n  const cacheDirectoryPath = path.resolve(project.dirPath, 'node_modules', '.cache', 'build');\n  const cacheFilePath = path.resolve(cacheDirectoryPath, 'last-build');\n  await fs.promises.mkdir(cacheDirectoryPath, { recursive: true });\n\n  const hash = createHash('sha256');\n\n  const commitHash = child_process.execSync('git rev-parse HEAD', { cwd: project.dirPath }).toString().trim();\n  hash.update(commitHash);\n\n  const environmentJson = JSON.stringify(\n    Object.entries(project.env)\n      .filter(([key]) => !ignoringEnvVarNames.has(key))\n      .toSorted(([key1], [key2]) => key1.localeCompare(key2))\n  );\n  hash.update(environmentJson);\n\n  await updateHashWithDiffResult(project, argv, hash);\n  const contentHash = hash.digest('hex');\n\n  const cachedContentHash = await ignoreEnoentAsync(() => fs.promises.readFile(cacheFilePath, 'utf8'));\n  return [cachedContentHash === contentHash, cacheFilePath, contentHash];\n}\n\nconst includePatterns = ['src/', 'public/'];\nconst includeSuffix = [\n  '.js',\n  '.cjs',\n  '.mjs',\n  '.jsx',\n  '.ts',\n  '.cts',\n  '.mts',\n  '.tsx',\n  '.json',\n  '.browserslistrc',\n  // Because some build commands affected by changes in `package.json`\n  'package.json',\n  'yarn.lock',\n];\nconst excludePatterns = ['test/', 'tests/', '__tests__/', 'test-fixtures/', 'test/fixtures/'];\n\nasync function updateHashWithDiffResult(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  hash: Hash\n): Promise<void> {\n  return new Promise((resolve) => {\n    const ret = child_process.spawnSync('git', ['status', '--porcelain'], {\n      cwd: project.dirPath,\n      env: project.env,\n      stdio: 'pipe',\n      encoding: 'utf8',\n    });\n    const lines = ret.stdout\n      .trim()\n      .split('\\n')\n      .filter((line) => line.length > 0);\n    const filePaths = lines\n      .map((line) => line.slice(2).trim())\n      .map((filePath) =>\n        project.env.WB_ENV === 'test' ? filePath.replace(/packages\\/wb\\/test\\/fixtures\\/[^/]+\\//, '') : filePath\n      );\n    const filteredFilePaths = filePaths.filter(\n      (filePath) =>\n        (includePatterns.some((pattern) => filePath.includes(pattern)) ||\n          includeSuffix.some((suffix) => filePath.endsWith(suffix))) &&\n        !excludePatterns.some((pattern) => filePath.includes(pattern))\n    );\n    if (argv.verbose) {\n      console.info(`Changed files: ${filteredFilePaths.join(', ')}`);\n    }\n\n    // 'git diff --' works only on rootDirPath\n    const proc = child_process.spawn('git', ['diff', '--', ...filteredFilePaths], { cwd: project.rootDirPath });\n    proc.stdout.on('data', (data: BinaryLike) => {\n      hash.update(data);\n      if (argv.verbose) {\n        console.info('Data:', data);\n        console.info('Hash:', hash.copy().digest('hex'));\n      }\n    });\n    proc.on('close', () => {\n      resolve();\n    });\n  });\n}\n","import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n  if (obj instanceof Error) return obj;\n  if (typeof obj === 'string') return new Error(obj);\n  try {\n    return new Error(JSON.stringify(obj));\n  } catch {\n    return new Error(String(obj));\n  }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport interface RetryOptions {\n  beforeRetry?: (error: unknown) => Promise<void>;\n  handleError?: (error: unknown) => Promise<void>;\n  retryCount?: number;\n  retryLogger?: (message: string) => void;\n  shouldRetry?: (error: unknown) => boolean;\n  sleepMilliseconds?: number;\n  updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n}\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of retries.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n  func: (failedCount: number) => T | Promise<T>,\n  {\n    beforeRetry,\n    handleError,\n    retryCount = 3,\n    retryLogger,\n    shouldRetry,\n    sleepMilliseconds = 0,\n    updateSleepMilliseconds,\n  }: RetryOptions = {}\n): Promise<T> {\n  let failedCount = 0;\n  for (;;) {\n    try {\n      return await func(failedCount);\n    } catch (error) {\n      await handleError?.(error);\n      failedCount++;\n      if (failedCount >= retryCount) {\n        throw error;\n      }\n      if (shouldRetry && !shouldRetry(error)) {\n        throw error;\n      }\n      if (sleepMilliseconds > 0) {\n        await sleep(sleepMilliseconds);\n      }\n      if (updateSleepMilliseconds) {\n        sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n      }\n      retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + (error.stack ?? '') : ''}`);\n      await beforeRetry?.(error);\n    }\n  }\n}\n","import chalk from 'chalk';\nimport killPortProcess from 'kill-port';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isCI } from '../utils/ci.js';\n\nconst killPortIfNonCiBuilder = {} as const;\n\nexport const killPortIfNonCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'kill-port-if-non-ci',\n  describe: 'Kill the port specified by PORT environment variable if non-CI.',\n  builder: killPortIfNonCiBuilder,\n  async handler(argv) {\n    await killPortIfNonCi(argv);\n  },\n};\n\nexport async function killPortIfNonCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const project = findSelfProject(argv);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  if (isCI(project.env.CI)) {\n    console.info(`Skip killing port due to CI: ${project.env.CI}`);\n    return;\n  }\n\n  const portEnv = project.env.PORT;\n  const port = Number(portEnv);\n  if (!Number.isInteger(port) || port <= 0) {\n    console.error(chalk.red(`PORT environment variable is invalid: ${portEnv}`));\n    process.exit(1);\n  }\n\n  console.info(`Killing the port: ${port}`);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n","import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n","import { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { isRunningOnBun, packageManagerWithRun } from '../utils/runtime.js';\n\ninterface Options {\n  ci?: boolean;\n  exitIfFailed?: boolean;\n  onSignal?: (signal: NodeJS.Signals | null) => void;\n  forceColor?: boolean;\n  timeout?: number;\n}\n\nconst defaultOptions: Options = {\n  exitIfFailed: true,\n};\n\nexport async function runWithSpawn(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<number> {\n  const normalizedScript = normalizeScript(script, project);\n  printStart(normalizedScript.printable, project);\n  if (argv.verbose) {\n    printStart(normalizedScript.runnable, project, 'Start (raw)', true);\n  }\n  if (argv.dryRun) {\n    printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts);\n    return 0;\n  }\n\n  const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n    cwd: project.dirPath,\n    env: configureEnv(project.env, opts),\n    shell: true,\n    stdio: 'inherit',\n    timeout: opts.timeout,\n    killOnExit: true,\n    verbose: argv.verbose,\n  });\n  opts.onSignal?.(ret.signal);\n  printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts);\n  return ret.status ?? 1;\n}\n\nexport function runWithSpawnInParallel(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<number> {\n  return promisePool.runAndWaitForReturnValue(async () => {\n    const normalizedScript = normalizeScript(script, project);\n    printStart(normalizedScript.printable, project, 'Start (parallel)', true);\n    if (argv.dryRun) {\n      printStart(normalizedScript.printable, project, 'Started (log)');\n      if (argv.verbose) {\n        printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n      }\n      printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts);\n      return 0;\n    }\n\n    const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n      cwd: project.dirPath,\n      env: configureEnv(project.env, opts),\n      shell: true,\n      stdio: 'pipe',\n      timeout: opts.timeout,\n      mergeOutAndError: true,\n      killOnExit: true,\n      verbose: argv.verbose,\n    });\n    opts.onSignal?.(ret.signal);\n    printStart(normalizedScript.printable, project, 'Started (log)');\n    if (argv.verbose) {\n      printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n    }\n    const out = ret.stdout.trim();\n    if (out) {\n      process.stdout.write(out);\n      process.stdout.write('\\n');\n    }\n    printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts);\n    return ret.status ?? 1;\n  });\n}\n\n/**\n * Replace capitalized commands (e.g., YARN, PRISMA, BUN) with suitable commands.\n */\nfunction normalizeScript(script: string, project: Project): { printable: string; runnable: string } {\n  let newScript = script\n    .replaceAll('\\n', '')\n    .replaceAll(/\\s\\s+/g, ' ')\n    .replaceAll(\n      'PRISMA generate ',\n      project.packageJson.dependencies?.blitz ? 'PRISMA generate ' : 'PRISMA generate --no-hints '\n    )\n    .replaceAll('PRISMA ', project.packageJson.dependencies?.blitz ? 'YARN blitz prisma ' : 'YARN prisma ')\n    .replaceAll('BUN ', project.isBunAvailable ? 'bun --bun run ' : 'YARN ')\n    // Avoid replacing `YARN run` with `run` by replacing `YARN` with `(yarn|bun --bun) run`\n    .replaceAll('YARN run ', isRunningOnBun ? 'bun --bun run ' : 'yarn run ');\n  if (isRunningOnBun) {\n    newScript = newScript\n      .replaceAll('YARN build-ts run', 'bun --bun run')\n      .replaceAll('bun --bun run bun --bun run', 'bun --bun run')\n      // Because bun can run src/index.ts directly.\n      .replaceAll('dist/index.js', 'src/index.ts')\n      .replaceAll(/(?:YARN )?vitest run/g, 'bun test')\n      // '--allowOnly' is sometimes removed.\n      .replaceAll(/ --color --passWithNoTests(?: --allowOnly)?/g, '');\n  }\n  newScript = newScript.trim();\n  const printableScript = fixBunCommand(newScript.replaceAll('YARN ', `${packageManagerWithRun} `));\n  const runnableScript = fixBunCommand(\n    newScript\n      // Because we need to use `yarn playwright` in a project depending on `artillery-engine-playwright`.\n      .replaceAll('YARN playwright ', `${packageManagerWithRun} playwright `)\n      .replaceAll('YARN ', !isRunningOnBun && project.binExists ? '' : `${packageManagerWithRun} `)\n  );\n  // Add cascade option when WB_ENV is defined\n  const cascadeOption = project.env.WB_ENV ? ` -c=${project.env.WB_ENV || 'development'}` : '';\n  return {\n    printable: `${packageManagerWithRun} dotenv${cascadeOption} -- ${printableScript}`,\n    runnable: runnableScript,\n  };\n}\n\nexport function printStart(normalizedScript: string, project: Project, prefix = 'Start', weak = false): void {\n  console.info(\n    '\\n' +\n      (weak ? chalk.gray : chalk.cyan)(chalk.bold(`${prefix}:`), normalizedScript) +\n      chalk.gray(` at ${project.dirPath}`)\n  );\n}\n\nexport function printFinishedAndExitIfNeeded(\n  script: string,\n  exitCode: number | null,\n  opts: Omit<Options, 'timeout'>\n): void {\n  if (exitCode === 0) {\n    console.info(chalk.green(chalk.bold('Finished:'), script));\n  } else {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}): `), script));\n    if (opts.exitIfFailed !== false) {\n      process.exit(exitCode ?? 1);\n    }\n  }\n}\n\nfunction configureEnv(env: Record<string, string | undefined>, opts: Options): Record<string, string | undefined> {\n  const newEnv = { ...env };\n  if (opts.ci) {\n    newEnv.CI = '1';\n  }\n  if (opts.forceColor) {\n    newEnv.FORCE_COLOR = '3';\n  }\n  return newEnv;\n}\n\nfunction fixBunCommand(command: string): string {\n  // cf. https://github.com/oven-sh/bun/issues/14359\n  return command.includes('next dev') ||\n    // cf. https://github.com/oven-sh/bun/issues/8222\n    command.includes('playwright') ||\n    // \"bun --bun prisma generate\" doesn't work\n    command.includes('prisma') ||\n    command.includes('test/e2e-additional')\n    ? command.replaceAll('bun --bun', 'bun')\n    : command;\n}\n","import path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isRunningOnBun } from '../utils/runtime.js';\n\nconst builder = {\n  fix: {\n    description: 'Fix the linting errors',\n    type: 'boolean',\n  },\n  format: {\n    description: 'Format the code',\n    type: 'boolean',\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  files: {\n    description: 'File and directory paths to lint',\n    type: 'array',\n  },\n} as const;\n\nconst biomeExtensions = new Set(['cjs', 'cts', 'js', 'json', 'jsonc', 'jsx', 'mjs', 'mts', 'ts', 'tsx']);\nconst prettierExtensions = new Set([\n  'cjs',\n  'cts',\n  'htm',\n  'html',\n  'js',\n  'json',\n  'jsonc',\n  'jsx',\n  'md',\n  'mjs',\n  'mts',\n  'scss',\n  'ts',\n  'tsx',\n  'vue',\n  'yaml',\n  'yml',\n]);\nconst prettierOnlyExtensions = new Set([...prettierExtensions].filter((ext) => !biomeExtensions.has(ext)));\n\nexport const lintCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder>\n> = {\n  command: 'lint [files...]',\n  describe: 'Lint code on Bun',\n  builder,\n  async handler(argv) {\n    if (!isRunningOnBun) {\n      console.error(chalk.red('This command is only available on Bun.'));\n      process.exit(1);\n    }\n\n    const projects = await findDescendantProjects(argv, false);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const files = argv.files ?? [];\n    let biomeArgsText: string;\n    let prettierArgsText: string;\n    let sortPackageJsonArgsText: string;\n    if (files.length > 0) {\n      const filePathsToBeCheckedByBiome: string[] = [];\n      const filePathsToBeFormattedByPrettier: string[] = [];\n      const packageJsonFilePaths: string[] = [];\n      for (const file of files) {\n        const filePath = path.resolve(String(file));\n        if (\n          filePath.endsWith('/test/fixtures') ||\n          filePath.includes('/test/fixtures/') ||\n          filePath.endsWith('/test-fixtures') ||\n          filePath.includes('/test-fixtures/')\n        ) {\n          continue;\n        }\n\n        const extension = path.extname(filePath).slice(1);\n        if (filePath.endsWith('/package.json')) {\n          packageJsonFilePaths.push(filePath);\n        } else if (biomeExtensions.has(extension)) {\n          filePathsToBeCheckedByBiome.push(filePath);\n        } else if (prettierExtensions.has(extension)) {\n          filePathsToBeFormattedByPrettier.push(filePath);\n        }\n      }\n      biomeArgsText = filePathsToBeCheckedByBiome.map((f) => `\"${f}\"`).join(' ');\n      prettierArgsText = filePathsToBeFormattedByPrettier.map((f) => `\"${f}\"`).join(' ');\n      sortPackageJsonArgsText = packageJsonFilePaths.map((f) => `\"${f}\"`).join(' ');\n    } else {\n      biomeArgsText = '';\n      prettierArgsText = `\"**/{.*/,}*.{${[...prettierOnlyExtensions].join(',')}}\" \"!**/test{-,/}fixtures/**\"`;\n      sortPackageJsonArgsText = projects.descendants.map((p) => `\"${p.packageJsonPath}\"`).join(' ');\n    }\n\n    const biomeCommand =\n      argv.fix && argv.format ? 'check --fix' : argv.fix ? 'lint --fix' : argv.format ? 'format --fix' : 'lint';\n    let biomePromise: Promise<number> | undefined;\n    if (biomeArgsText || files.length === 0) {\n      biomePromise = runWithSpawnInParallel(\n        `bun --bun biome ${biomeCommand} --colors=force --no-errors-on-unmatched --files-ignore-unknown=true ${biomeArgsText}`,\n        projects.self,\n        argv,\n        { forceColor: true }\n      );\n    }\n    if (argv.format) {\n      if (prettierArgsText) {\n        void runWithSpawnInParallel(\n          `bun --bun prettier --cache --color --no-error-on-unmatched-pattern --write ${prettierArgsText}`,\n          projects.self,\n          argv,\n          { forceColor: true }\n        );\n      }\n      if (sortPackageJsonArgsText) {\n        await biomePromise;\n        void runWithSpawnInParallel(`bun --bun sort-package-json ${sortPackageJsonArgsText}`, projects.self, argv, {\n          forceColor: true,\n        });\n      }\n    }\n  },\n};\n","import type { Project } from '../project.js';\n\nexport function* prepareForRunningCommand(commandName: string, projects: Project[]): Generator<Project, void, unknown> {\n  for (const project of projects) {\n    console.info(`Running \"${commandName}\" for ${project.name} ...`);\n\n    yield project;\n  }\n}\n","import child_process from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { PackageJson } from 'type-fest';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { packageManager } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {\n  outside: {\n    description: 'Whether the optimization is executed outside a docker container or not',\n    type: 'boolean',\n    alias: 'o',\n  },\n} as const;\n\nexport const optimizeForDockerBuildCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'optimizeForDockerBuild',\n  describe: 'Optimize configuration when building a Docker image',\n  builder,\n  async handler(argv) {\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of prepareForRunningCommand('optimizeForDockerBuild', projects.descendants)) {\n      const packageJson: PackageJson = project.packageJson;\n      const keys = ['dependencies', 'devDependencies'] as const;\n      for (const key of keys) {\n        const deps = packageJson[key] ?? {};\n        for (const [name, value] of Object.entries(deps)) {\n          if (value?.startsWith('git@github.com:')) {\n            deps[name] = `./${name}`;\n          }\n        }\n      }\n\n      optimizeDevDependencies(argv, packageJson);\n\n      optimizeScripts(packageJson);\n\n      optimizeRootProps(packageJson);\n\n      if (argv.dryRun) continue;\n\n      const distDirPath = argv.outside ? path.join(project.dirPath, 'dist') : project.dirPath;\n      await fs.promises.mkdir(distDirPath, { recursive: true });\n      await fs.promises.writeFile(path.join(distDirPath, 'package.json'), JSON.stringify(packageJson), 'utf8');\n    }\n    if (!argv.dryRun && !argv.outside) {\n      child_process.spawnSync(packageManager, ['install'], {\n        stdio: 'inherit',\n      });\n      console.info('Installed dependencies.');\n    }\n  },\n};\n\nfunction optimizeDevDependencies(argv: InferredOptionTypes<typeof builder>, packageJson: PackageJson): void {\n  if (!argv.outside) {\n    delete packageJson.devDependencies;\n    console.info('Removed all devDependencies.');\n    return;\n  }\n\n  const devDeps = packageJson.devDependencies ?? {};\n  const nameWordsToBeRemoved = [\n    'artillery',\n    'biome',\n    'concurrently',\n    'conventional-changelog-conventionalcommits',\n    'eslint',\n    'husky',\n    'imagemin',\n    'jest',\n    'kill-port',\n    'lint-staged',\n    'open-cli',\n    'playwright',\n    'prettier',\n    'pinst',\n    'railway',\n    'semantic-release',\n    'sort-package-json',\n    'wait-on',\n    'vitest',\n  ];\n  const removedDeps: string[] = [];\n  for (const name of Object.keys(devDeps)) {\n    if (\n      nameWordsToBeRemoved.some((word) => name.includes(word)) ||\n      (name.includes('willbooster') && name.includes('config'))\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete devDeps[name];\n      removedDeps.push(name);\n    }\n  }\n  console.info('Removed devDependencies:', removedDeps.join(', ') || 'none');\n}\n\nfunction optimizeScripts(packageJson: PackageJson): void {\n  const nameWordsOfUnnecessaryScripts = ['check', 'deploy', 'format', 'lint', 'start', 'test'];\n  const contentWordsOfUnnecessaryScripts = ['pinst ', 'husky '];\n  const scripts = (packageJson.scripts ?? {}) as Record<string, string>;\n  const removedScripts: string[] = [];\n  for (const [name, content] of Object.entries(scripts)) {\n    if (\n      nameWordsOfUnnecessaryScripts.some((word) => name.startsWith(word)) ||\n      // Support \"husky\" since husky v9 requires `\"postinstall\": \"husky\"`\n      contentWordsOfUnnecessaryScripts.some((word) => content.includes(word) || content.trim() === word.trim())\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete scripts[name];\n      removedScripts.push(name);\n    }\n  }\n  console.info('Removed scripts:', removedScripts.join(', ') || 'none');\n}\n\nfunction optimizeRootProps(packageJson: PackageJson): void {\n  delete packageJson.private;\n  delete packageJson.publishConfig;\n  delete packageJson.prettier;\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { Project } from '../project.js';\nimport { runtimeWithArgs } from '../utils/runtime.js';\n\n/**\n * A collection of scripts for executing Prisma commands.\n * Note that `PRISMA` is replaced with `YARN prisma` or `YARN blitz prisma`\n * and `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PrismaScripts {\n  cleanUpLitestream(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    // Cleanup existing artifacts to avoid issues with Litestream replication.\n    // Note that don't merge multiple rm commands into one, because if one fails, the subsequent ones won't run.\n    return `rm -Rf ${dirPath}/prod.sqlite3-*; rm -Rf ${dirPath}/prod.sqlite3.*; rm -Rf ${dirPath}/.prod.sqlite3* || true`;\n  }\n\n  deploy(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions}`;\n  }\n\n  deployForce(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    // Don't skip \"migrate deploy\" because restored database may be older than the current schema.\n    return `PRISMA migrate reset --force --skip-seed && rm -Rf ${dirPath}/prod.sqlite3*\n      && litestream restore -config litestream.yml -o ${dirPath}/prod.sqlite3 ${dirPath}/prod.sqlite3 && ls -ahl ${dirPath}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`;\n  }\n\n  listBackups(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `litestream ltx -config litestream.yml ${dirPath}/prod.sqlite3`;\n  }\n\n  migrate(project: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions} && PRISMA generate && ${this.seed(project)}`;\n  }\n\n  migrateDev(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate dev ${additionalOptions}`;\n  }\n\n  reset(project: Project, additionalOptions = ''): string {\n    // cf. https://www.prisma.io/docs/guides/database/seed-database#integrated-seeding-with-prisma-migrate\n    const resetOptions = additionalOptions.trim();\n    const baseReset = `PRISMA migrate reset --force ${resetOptions}`;\n    const resetCommand = project.packageJson.dependencies?.blitz ? `${baseReset} && ${this.seed(project)}` : baseReset;\n    const resetCommandForTest = project.packageJson.dependencies?.blitz\n      ? String.raw`find db \\( -name \"test.db*\" -o -name \"test.sqlite*\" \\) -delete`\n      : String.raw`find prisma \\( -name \"test.db*\" -o -name \"test.sqlite*\" \\) -delete`;\n    return `${resetCommand} && ${resetCommandForTest}`;\n  }\n\n  restore(project: Project, outputPath: string): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `${this.removeSqliteArtifacts(outputPath)}; litestream restore -config litestream.yml -o ${outputPath} ${dirPath}/prod.sqlite3`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (project.packageJson.dependencies?.blitz) return `YARN blitz db seed${scriptPath ? ` -f ${scriptPath}` : ''}`;\n    if (scriptPath) return `BUN build-ts run ${scriptPath}`;\n    if ((project.packageJson.prisma as Record<string, string> | undefined)?.seed) return `YARN prisma db seed`;\n    return `if [ -e \"prisma/seeds.ts\" ]; then BUN build-ts run prisma/seeds.ts; fi`;\n  }\n\n  setUpDBForLitestream(_: Project): string {\n    // cf. https://litestream.io/tips/\n    return `${runtimeWithArgs} -e '\nconst { PrismaClient } = require(\"@prisma/client\");\nconst prisma = new PrismaClient();\n(async () => {\n  try {\n    await prisma.$queryRawUnsafe(\"PRAGMA busy_timeout = 5000\");\n    await prisma.$queryRawUnsafe(\"PRAGMA journal_mode = WAL\");\n    await prisma.$queryRawUnsafe(\"PRAGMA synchronous = NORMAL\");\n    await prisma.$queryRawUnsafe(\"PRAGMA wal_autocheckpoint = 0\");\n  } catch (error) {\n    console.error(\"Failed due to:\", error);\n    process.exit(1);\n  } finally {\n    await prisma.$disconnect();\n  }\n})();\n'`;\n  }\n\n  studio(project: Project, dbUrlOrPath?: string, additionalOptions = ''): string {\n    const FILE_SCHEMA = 'file:';\n    let prefix = '';\n    // Deal with Prisma issue: https://github.com/prisma/studio/issues/1273\n    if (dbUrlOrPath) {\n      try {\n        new URL(dbUrlOrPath);\n        prefix = `DATABASE_URL=${dbUrlOrPath} `;\n      } catch {\n        const absolutePath = path.resolve(dbUrlOrPath);\n        prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n      }\n    } else if (project.env.DATABASE_URL?.startsWith(FILE_SCHEMA)) {\n      const POSSIBLE_PATHS = [\n        { schemaPath: path.join('prisma', 'schema.prisma'), dbPath: 'prisma' },\n        { schemaPath: path.join('prisma', 'schema'), dbPath: path.join('prisma', 'schema') },\n        { schemaPath: path.join('db', 'schema.prisma'), dbPath: 'db' },\n      ];\n      for (const { dbPath, schemaPath } of POSSIBLE_PATHS) {\n        if (fs.existsSync(path.resolve(project.dirPath, schemaPath))) {\n          const absolutePath = path.resolve(\n            project.dirPath,\n            dbPath,\n            project.env.DATABASE_URL.slice(FILE_SCHEMA.length)\n          );\n          prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n          break;\n        }\n      }\n    }\n    return `${prefix}PRISMA studio ${additionalOptions}`;\n  }\n\n  private removeSqliteArtifacts(sqlitePath: string): string {\n    // Litestream requires removing WAL/SHM and Litestream sidecar files when recreating databases.\n    return `rm -Rf ${sqlitePath} ${sqlitePath}-shm ${sqlitePath}-wal ${sqlitePath}-litestream`;\n  }\n}\n\nfunction getDatabaseDirPath(project: Project): string {\n  return project.packageJson.dependencies?.blitz ? 'db/mount' : 'prisma/mount';\n}\n\nexport const prismaScripts = new PrismaScripts();\n","import { yargsOptionsBuilderForEnv } from '@willbooster/shared-lib-node/src';\n\nexport const sharedOptionsBuilder = {\n  ...yargsOptionsBuilderForEnv,\n  // This option is for debugging mainly.\n  'working-dir': {\n    description: 'A working directory',\n    type: 'string',\n    alias: 'w',\n  },\n  'dry-run': {\n    description: 'Whether to skip actual command execution',\n    type: 'boolean',\n    alias: ['dry', 'd'],\n  },\n} as const;\n","import fs from 'node:fs';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport { prismaScripts } from '../scripts/prismaScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const prismaCommand: CommandModule = {\n  command: 'prisma',\n  describe: 'Run prisma commands',\n  builder: (yargs) => {\n    return yargs\n      .command(cleanUpLitestreamCommand)\n      .command(createLitestreamConfigCommand)\n      .command(deployCommand)\n      .command(deployForceCommand)\n      .command(listBackupsCommand)\n      .command(setUpDBForLitestreamCommand)\n      .command(migrateCommand)\n      .command(migrateDevCommand)\n      .command(resetCommand)\n      .command(restoreCommand)\n      .command(seedCommand)\n      .command(studioCommand)\n      .command(defaultCommand)\n      .demandCommand()\n      .strict(false); // Allow unknown options to be passed through\n  },\n  handler() {\n    // Do nothing\n  },\n};\n\nconst cleanUpLitestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'cleanup-litestream',\n  describe: 'Clean up temporal Litestream files',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma cleanup-litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.cleanUpLitestream(project), project, argv);\n    }\n  },\n};\n\nconst createLitestreamConfigCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'create-litestream-config',\n  describe: 'Create Litestream configuration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma create-litestream-config', allProjects)) {\n      createLitestreamConfig(project);\n    }\n  },\n};\n\nconst deployCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy',\n  describe: 'Apply migration to DB without initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma deploy', allProjects)) {\n      await runWithSpawn(prismaScripts.deploy(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst deployForceCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy-force',\n  describe: \"Force to apply migration to DB utilizing Litestream's backup without initializing it\",\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma deploy-force', allProjects)) {\n      await runWithSpawn(prismaScripts.deployForce(project), project, argv);\n    }\n  },\n};\n\nconst listBackupsCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'list-backups',\n  describe: 'List Litestream backups',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma list-backups', allProjects)) {\n      await runWithSpawn(prismaScripts.listBackups(project), project, argv);\n    }\n  },\n};\n\nconst migrateCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate',\n  describe: 'Apply migration to DB with initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma migrate', allProjects)) {\n      await runWithSpawn(prismaScripts.migrate(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst migrateDevCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate-dev',\n  describe: 'Create a migration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma migrate-dev', allProjects)) {\n      await runWithSpawn(prismaScripts.migrateDev(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst resetCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'reset',\n  describe: 'Reset DB',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma reset', allProjects)) {\n      await runWithSpawn(prismaScripts.reset(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst restoreBuilder = {\n  ...builder,\n  output: {\n    description: 'Output path of the restored database. Defaults to \"<db|prisma>/restored.sqlite3\".',\n    type: 'string',\n  },\n} as const;\n\nconst restoreCommand: CommandModule<unknown, InferredOptionTypes<typeof restoreBuilder>> = {\n  command: 'restore',\n  describe: \"Restore DB from Litestream's backup\",\n  builder: restoreBuilder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma restore', allProjects)) {\n      const output =\n        argv.output ?? (project.packageJson.dependencies?.blitz ? 'db/restored.sqlite3' : 'prisma/restored.sqlite3');\n      await runWithSpawn(prismaScripts.restore(project, output), project, argv);\n    }\n  },\n};\n\nconst seedBuilder = {\n  ...builder,\n  file: {\n    alias: 'f',\n    description: 'Path of the seed script.',\n    type: 'string',\n  },\n} as const;\n\nconst seedCommand: CommandModule<unknown, InferredOptionTypes<typeof seedBuilder>> = {\n  command: 'seed',\n  describe: 'Populate DB with seed data',\n  builder: seedBuilder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma seed', allProjects)) {\n      await runWithSpawn(prismaScripts.seed(project, argv.file), project, argv);\n    }\n  },\n};\n\nconst setUpDBForLitestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'setup-db-for-litestream',\n  describe: 'Setup DB for Litestream',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma setup-db-for-litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.setUpDBForLitestream(project), project, argv);\n    }\n  },\n};\n\nconst studioBuilder = {\n  ...builder,\n  'db-url-or-path': {\n    description: 'URL or path to the database',\n    type: 'string',\n  },\n  restored: {\n    description: 'Whether to open the default restored database (<db|prisma>/restored.sqlite3).',\n    type: 'boolean',\n  },\n} as const;\n\nconst studioCommand: CommandModule<unknown, InferredOptionTypes<typeof studioBuilder>> = {\n  command: 'studio [db-url-or-path]',\n  describe: 'Open Prisma Studio',\n  builder: studioBuilder,\n  async handler(argv) {\n    if (argv.restored && argv.dbUrlOrPath) {\n      throw new Error('You cannot specify both --restored and --db-url-or-path.');\n    }\n\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv, ['db-url-or-path', 'restored']);\n    for (const project of prepareForRunningCommand('prisma studio', allProjects)) {\n      const dbUrlOrPath = argv.restored\n        ? project.packageJson.dependencies?.blitz\n          ? 'db/restored.sqlite3'\n          : 'prisma/restored.sqlite3'\n        : argv.dbUrlOrPath?.toString();\n      await runWithSpawn(prismaScripts.studio(project, dbUrlOrPath, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst defaultCommandBuilder = { args: { type: 'array' } } as const;\n\nconst defaultCommand: CommandModule<unknown, InferredOptionTypes<typeof defaultCommandBuilder>> = {\n  command: '$0 <args..>',\n  describe: 'Pass the command and arguments to prisma as is',\n  builder: defaultCommandBuilder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const script = (argv.args?.join(' ') ?? '').trimEnd();\n    const unknownOptions = extractUnknownOptions(argv, ['args']);\n    const fullCommand = [script, unknownOptions].filter(Boolean).join(' ');\n    for (const project of prepareForRunningCommand(`prisma ${fullCommand}`, allProjects)) {\n      await runWithSpawn(`PRISMA ${fullCommand}`, project, argv);\n    }\n  },\n};\n\nfunction createLitestreamConfig(project: Project): void {\n  const dirName = project.packageJson.dependencies?.blitz ? 'db' : 'prisma';\n  const dbPath = `${dirName}/mount/prod.sqlite3`;\n  const requiredEnvVars = {\n    CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,\n    CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME: project.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,\n    CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,\n    CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY: project.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY,\n  } as const;\n  const missingEnvVars = Object.entries(requiredEnvVars)\n    .filter(([, value]) => !value)\n    .map(([key]) => key);\n  if (missingEnvVars.length > 0) {\n    throw new Error(`Missing environment variables for Litestream: ${missingEnvVars.join(', ')}`);\n  }\n\n  const retentionCheckInterval = project.env.WB_ENV === 'staging' ? '5m' : '1h';\n  const litestreamConfig = `dbs:\n  - path: ${dbPath}\n    replica:\n      type: s3\n      endpoint: https://${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n      bucket: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n      access-key-id: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n      secret-access-key: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n      snapshot-interval: 24h  # Create a backup per day\n      retention: 72h          # Keep backups for 3 days\n      retention-check-interval: ${retentionCheckInterval}\n      sync-interval: 60s\n`;\n\n  const configPath = '/etc/litestream.yml';\n  try {\n    fs.writeFileSync(configPath, litestreamConfig);\n    console.info(`Generated ${configPath}`);\n  } catch (error) {\n    const reason = error instanceof Error ? error.message : String(error);\n    throw new Error(`Failed to write ${configPath}: ${reason}`);\n  }\n}\n\nasync function findPrismaProjects(argv: EnvReaderOptions): Promise<Project[]> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  const filtered = projects.descendants.filter(\n    (project) => project.packageJson.dependencies?.prisma ?? project.packageJson.devDependencies?.prisma\n  );\n  if (filtered.length === 0) {\n    console.error(chalk.red('No prisma project found.'));\n    process.exit(1);\n  }\n  return filtered;\n}\n\n/**\n * Extract unknown options from argv to pass to prisma command\n */\nexport function extractUnknownOptions(argv: Record<string, unknown>, knownOptions: string[] = []): string {\n  const unknownOptions: string[] = [];\n\n  // Build list of known options from shared options builders\n  const sharedOptionKeys = Object.keys(sharedOptionsBuilder);\n  const sharedOptionAliases = Object.values(sharedOptionsBuilder)\n    .flatMap((option) => {\n      if ('alias' in option) {\n        return Array.isArray(option.alias) ? option.alias : [option.alias];\n      }\n      return [];\n    })\n    .map(String);\n\n  const allKnownOptions = new Set([\n    ...knownOptions,\n    ...sharedOptionKeys,\n    ...sharedOptionAliases,\n    // Internal yargs properties\n    '_',\n    '$0',\n  ]);\n\n  for (const [key, value] of Object.entries(argv)) {\n    if (!allKnownOptions.has(key)) {\n      // Skip camelCase versions of kebab-case options to avoid duplication\n      // If we have both 'create-only' and 'createOnly', prefer the kebab-case version\n      const kebabCaseKey = key.replaceAll(/[A-Z]/g, (match) => `-${match.toLowerCase()}`);\n      if (kebabCaseKey !== key && argv[kebabCaseKey] !== undefined) {\n        continue; // Skip camelCase version if kebab-case exists\n      }\n\n      // Handle boolean flags\n      if (typeof value === 'boolean' && value) {\n        unknownOptions.push(`--${key}`);\n      }\n      // Handle string/number values\n      else if (typeof value === 'string' || typeof value === 'number') {\n        unknownOptions.push(`--${key}`, String(value));\n      }\n      // Handle arrays\n      else if (Array.isArray(value)) {\n        for (const item of value) {\n          unknownOptions.push(`--${key}`, String(item));\n        }\n      }\n    }\n  }\n\n  return unknownOptions.join(' ');\n}\n","import chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {\n  retry: {\n    description: 'A maximum retry count',\n    type: 'number',\n    alias: 'r',\n    default: 3,\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  command: {\n    description: 'A command to retry',\n    type: 'string',\n  },\n  args: {\n    description: 'Arguments for the command',\n    type: 'array',\n  },\n} as const;\n\nexport const retryCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder>\n> = {\n  command: 'retry [command] [args...]',\n  describe: 'Retry the given command until it succeeds',\n  builder,\n  async handler(argv) {\n    const project = findSelfProject(argv);\n    if (!project) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const cmdAndArgs = [argv.command, ...(argv.args ?? []), ...argv._.slice(1)].filter(Boolean);\n    let lastStatus = 0;\n    for (let i = 0; i < argv.retry; i++) {\n      if (i > 0) {\n        console.info(`\\n${chalk.yellow(`#${i} Retrying: ${cmdAndArgs.join(' ')}`)}`);\n      }\n      // TODO: should we add single quotes around each argument?\n      lastStatus = await runWithSpawn(cmdAndArgs.join(' '), project, argv, {\n        exitIfFailed: false,\n        onSignal: (signal) => {\n          if (signal) {\n            process.exit(1);\n          }\n        },\n      });\n      if (lastStatus === 0) return;\n    }\n    process.exit(lastStatus);\n  },\n};\n","import child_process from 'node:child_process';\nimport fs from 'node:fs/promises';\nimport os from 'node:os';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { packageManagerWithRun } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const setupCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'setup',\n  describe: 'Setup development environment. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    await setup(argv);\n  },\n};\n\n// Test code requires Partial<...>\nexport async function setup(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  projectPathForTesting?: string\n): Promise<void> {\n  const projects = await findDescendantProjects(argv, false, projectPathForTesting);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  for (const project of prepareForRunningCommand('setup', projects.descendants)) {\n    const dirents = await fs.readdir(project.dirPath, { withFileTypes: true });\n    if (project === projects.root) {\n      if (os.platform() === 'darwin') {\n        const packages = ['pstree'];\n        await runWithSpawnInParallel(`brew install ${packages.join(' ')}`, project, argv);\n      }\n\n      if (dirents.some((d) => d.isFile() && d.name.includes('-version'))) {\n        await runWithSpawn('asdf install', project, argv, { exitIfFailed: false });\n      }\n    }\n\n    if (dirents.some((d) => d.isFile() && d.name === 'pyproject.toml')) {\n      await runWithSpawnInParallel('poetry config virtualenvs.in-project true', project, argv);\n      const [, version] = child_process.execSync('asdf current python').toString().trim().split(/\\s+/);\n      await runWithSpawnInParallel(`poetry env use ${version}`, project, argv);\n      await promisePool.promiseAll();\n      await runWithSpawn('poetry run pip install --upgrade pip', project, argv);\n      await runWithSpawn('poetry install --ansi', project, argv);\n    }\n\n    if (\n      (project === projects.root || !projects.root.packageJson.scripts?.['gen-code']) &&\n      project.packageJson.scripts?.['gen-code']\n    ) {\n      await runWithSpawn(`${packageManagerWithRun} gen-code`, project, argv);\n    }\n  }\n\n  const project = projects.descendants.find((p) => p.packageJson.devDependencies?.playwright);\n  if (project) {\n    await runWithSpawn(`${packageManagerWithRun} playwright install --with-deps`, project, argv);\n  }\n}\n","import type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nexport const scriptOptionsBuilder = {\n  watch: {\n    description: 'Whether to watch files',\n    type: 'boolean',\n  },\n  args: {\n    description: 'Arguments for core command',\n    type: 'array',\n    alias: 'a',\n    default: [],\n  },\n  'docker-options': {\n    description: 'Arguments for \"docker run\"',\n    type: 'array',\n    default: [],\n  },\n} as const;\n\nexport type ScriptArgv = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>> & {\n  normalizedArgsText?: string;\n  normalizedDockerOptionsText?: string;\n  silent?: boolean;\n  verbose?: boolean;\n};\n\nexport function normalizeArgs(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>>\n): void {\n  (argv as ScriptArgv).normalizedArgsText = [...(argv.args ?? []), ...(argv._?.slice(1) ?? [])]\n    .map((arg) => `'${arg}'`)\n    .join(' ');\n  (argv as ScriptArgv).normalizedDockerOptionsText = (argv.dockerOptions ?? []).map((arg) => `'${arg}'`).join(' ');\n}\n\nexport function toDevNull(argv: unknown): string {\n  return (argv as { silent: boolean }).silent ? ` > /dev/null` : '';\n}\n","import { spawnSync } from 'node:child_process';\n\nimport { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport killPortProcess from 'kill-port';\n\nimport type { Project } from '../project.js';\nimport { printFinishedAndExitIfNeeded, printStart } from '../scripts/run.js';\n\nimport { isPortAvailable } from './port.js';\n\nconst killed = new Set<number | string>();\n\nexport async function killPortProcessImmediatelyAndOnExit(port: number, project: Project): Promise<void> {\n  const available = await isPortAvailable(port);\n  if (!available) {\n    await killPortContainerAndProcess(port, project);\n  }\n\n  const killFunc = async (): Promise<void> => {\n    if (killed.has(port)) return;\n\n    killed.add(port);\n    await killPortContainerAndProcess(port, project);\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n\nasync function killPortContainerAndProcess(port: number, project: Project): Promise<void> {\n  // We should stop Docker containers first because `kill-port` may fail to stop Docker containers.\n  await stopDockerContainerByPort(port, project);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function stopDockerContainerByImageName(imageName: string, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `name=${imageName}`], project);\n}\n\nexport async function stopDockerContainerByPort(port: number, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `publish=${port}`], project);\n}\n\nasync function removeDockerContainers(filterArgs: string[], project: Project): Promise<void> {\n  try {\n    const containerIds = await listDockerContainerIds(filterArgs, project);\n    if (containerIds.length === 0) return;\n\n    await spawnAsync('docker', ['rm', '-f', ...containerIds], {\n      cwd: project.dirPath,\n      env: project.env,\n    });\n  } catch {\n    // do nothing\n  }\n}\n\nasync function listDockerContainerIds(filterArgs: string[], project: Project): Promise<string[]> {\n  const { stdout } = await spawnAsync('docker', ['ps', '-q', ...filterArgs], {\n    cwd: project.dirPath,\n    env: project.env,\n  });\n  return stdout\n    .split(/\\s+/)\n    .map((id) => id.trim())\n    .filter(Boolean);\n}\n\nexport function spawnSyncOnExit(script: string, project: Project): void {\n  const killFunc = (): void => {\n    if (killed.has(script)) return;\n\n    killed.add(script);\n    printStart(script, project);\n    const { status } = spawnSync(script, { cwd: project.dirPath, shell: true, stdio: 'inherit' });\n    printFinishedAndExitIfNeeded(script, status, {});\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n","import { createServer } from 'node:net';\n\nimport type { Project } from '../project.js';\n\nimport { killPortProcessImmediatelyAndOnExit } from './process.js';\n\n/**\n * Checks the given port and kills any process using it.\n * Note wb always requires PORT environment variable.\n */\nexport async function checkAndKillPortProcess(rawPort: unknown, project: Project): Promise<number> {\n  const port = Number(rawPort);\n  if (!port) throw new Error(`The given port (${port}) is invalid.`);\n\n  await killPortProcessImmediatelyAndOnExit(port, project);\n  return port;\n}\n\n/**\n * Checks if a port is available.\n * @param port - The port number to check\n * @returns A promise that resolves to true if the port is available, false otherwise\n */\nexport async function isPortAvailable(port: number): Promise<boolean> {\n  // Check both stacks to catch processes bound only on IPv6 or IPv4.\n  for (const host of ['127.0.0.1', '::']) {\n    const available = await probePort(host, port);\n    if (!available) return false;\n  }\n  return true;\n}\n\nasync function probePort(host: string, port: number): Promise<boolean> {\n  return new Promise((resolve) => {\n    const server = createServer();\n\n    server.once('error', (err: NodeJS.ErrnoException) => {\n      if (err.code === 'EADDRINUSE') {\n        resolve(false);\n        return;\n      }\n      if (err.code === 'EAFNOSUPPORT') {\n        resolve(true);\n        return;\n      }\n      resolve(false);\n    });\n\n    server.once('listening', () => {\n      server.close(() => {\n        resolve(true);\n      });\n    });\n\n    server.listen(port, host);\n  });\n}\n","import path from 'node:path';\n\nimport type { Project } from '../project.js';\nimport { spawnSyncOnExit } from '../utils/process.js';\n\n/**\n * A collection of scripts for executing Docker commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass DockerScripts {\n  buildImage(project: Project, version: string): string {\n    // e.g. coding-booster uses `\"docker/build/prepare\": \"touch drill-users.csv\",`\n    const prefix = project.dockerPackageJson.scripts?.['docker/build/prepare']\n      ? 'YARN run docker/build/prepare && '\n      : '';\n    return `cd ${path.dirname(project.findFile('Dockerfile'))}\n    && ${prefix}YARN wb optimizeForDockerBuild --outside\n    && YARN wb retry -- docker build -t ${project.dockerImageName}\n        --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n        --build-arg WB_ENV=${project.env.WB_ENV}\n        --build-arg WB_VERSION=${version} .`;\n  }\n\n  stopAndStart(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    return `${this.stop(project)} && ${this.start(project, additionalOptions, additionalArgs)}`;\n  }\n\n  start(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    spawnSyncOnExit(this.stop(project), project);\n    const allocateTty = additionalArgs.includes('/bin/bash');\n    return `docker run --rm ${allocateTty ? '-it ' : ''}--publish ${project.env.PORT}:8080 --name ${project.dockerImageName} ${additionalOptions} ${project.dockerImageName} ${additionalArgs}`;\n  }\n\n  stop(project: Project): string {\n    return `true $(docker rm -f $(docker container ls -q -f name=${project.dockerImageName}) 2> /dev/null)`;\n  }\n\n  stopAll(): string {\n    return `true $(docker rm -f $(docker ps -q) 2> /dev/null)`;\n  }\n}\n\nexport const dockerScripts = new DockerScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { toDevNull } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nexport interface TestE2EOptions {\n  /** '--e2e generate' calls 'codegen http://localhost:8080' */\n  playwrightArgs?: string;\n}\n\n/**\n * A collection of scripts for executing an app.\n * Note that YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nexport abstract class BaseScripts {\n  private readonly shouldWaitAndOpenApp: boolean;\n  protected constructor(shouldWaitAndOpenApp: boolean) {\n    this.shouldWaitAndOpenApp = shouldWaitAndOpenApp;\n  }\n\n  buildDocker(project: Project, version: string): string {\n    return dockerScripts.buildImage(project, version);\n  }\n\n  // ------------ START: start commands ------------\n  async startDev(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startDevProtected(project, argv);\n\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"${this.startDevProtected(project, argv)}\"\n      \"${this.waitAndOpenApp(project)}\"`;\n  }\n  async startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startProductionProtected(project, argv);\n\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"${this.startProductionProtected(project, argv)}\"\n      \"${this.waitAndOpenApp(project)}\"`;\n  }\n  async startTest(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    return this.startProductionProtected(project, argv);\n  }\n  async startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) {\n      return `${this.buildDocker(project, 'development')}\n      && ${dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? '')}`;\n    }\n\n    return `${this.buildDocker(project, 'development')}\n      && YARN concurrently --raw --kill-others-on-fail\n        \"${dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? '')}\"\n        \"${this.waitAndOpenApp(project)}\"`;\n  }\n\n  protected abstract startDevProtected(_: Project, argv: ScriptArgv): string;\n  protected startProductionProtected(project: Project, argv: ScriptArgv): string {\n    const ecosystemConfigPath = findEcosystemConfigPath(project);\n    const commands =\n      ecosystemConfigPath === undefined\n        ? [\n            `YARN wb buildIfNeeded ${argv.verbose ? '--verbose' : ''}`.trim(),\n            `node dist/index.js ${argv.normalizedArgsText ?? ''}`.trim(),\n          ]\n        : [project.buildCommand, `pm2-runtime start --no-autorestart ${ecosystemConfigPath}`];\n\n    return [...(project.hasPrisma ? prismaScripts.migrate(project).split('&&') : []), ...commands]\n      .filter(Boolean)\n      .map((cmd) => `${cmd} ${toDevNull(argv)}`.trim())\n      .join(' && ');\n  }\n  // ------------ END: start commands ------------\n\n  // ------------ START: test (e2e) commands ------------\n  testE2EDev(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startDevProtected(project, argv), options);\n  }\n  testE2EProduction(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startProductionProtected(project, argv), options);\n  }\n  testE2EDocker(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, dockerScripts.stopAndStart(project), options);\n  }\n  async testStart(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    // Use empty NODE_ENV to avoid \"production\" mode in some frameworks like Blitz.js.\n    return `NODE_ENV=\"\" YARN concurrently --kill-others --raw --success first \"${this.startDevProtected(project, argv)}\" \"${this.waitApp(project)}\"`;\n  }\n\n  async testE2EProtected(\n    project: Project,\n    argv: TestArgv,\n    startCommand: string,\n    { playwrightArgs = 'test test/e2e/' }: TestE2EOptions\n  ): Promise<string> {\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const playwrightCommand = buildPlaywrightCommand(playwrightArgs, argv.targets);\n    if (project.skipLaunchingServerForPlaywright) {\n      return `${playwrightCommand}${suffix}`;\n    }\n\n    return `YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port}\n        && ${playwrightCommand}${suffix}\"`;\n  }\n  // ------------ END: test (e2e) commands ------------\n\n  testUnit(project: Project, argv: TestArgv): string {\n    const testTarget = argv.targets?.join(' ') || 'test/unit/';\n    if (project.hasVitest) {\n      // Since this command is referred from other commands, we have to use \"vitest run\" (non-interactive mode).\n      return `YARN vitest run ${testTarget} --color --passWithNoTests --allowOnly`;\n    } else if (project.isBunAvailable) {\n      return `bun test ${testTarget}`;\n    }\n    return 'echo \"No tests.\"';\n  }\n\n  protected waitApp(project: Project): string {\n    const port = project.env.PORT;\n    return `wait-on -t 10000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 500 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${port}`;\n  }\n\n  protected waitAndOpenApp(project: Project): string {\n    const port = project.env.PORT;\n    return `${this.waitApp(\n      project\n    )} || wait-on http-get://127.0.0.1:${port} && open-cli http://\\${HOST:-localhost}:${port}`;\n  }\n}\n\nfunction findEcosystemConfigPath(project: Project): string | undefined {\n  try {\n    return project.findFile('ecosystem.config.cjs');\n  } catch {\n    return;\n  }\n}\n\nfunction buildPlaywrightCommand(playwrightArgs: string, targets: TestArgv['targets']): string {\n  const base = 'BUN playwright';\n  const target = targets?.join(' ') || 'test/e2e/';\n  if (!playwrightArgs.startsWith('test ') || !targets?.length) {\n    return `${base} ${playwrightArgs}`;\n  }\n\n  const rest = playwrightArgs.slice('test '.length).trim();\n  const parts = rest.length > 0 ? rest.split(/\\s+/) : [];\n  if (!parts[0] || parts[0].startsWith('-')) {\n    parts.unshift(target);\n  } else {\n    parts[0] = target;\n  }\n  return `${base} test ${parts.join(' ')}`;\n}\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Blitz.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass BlitzScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `blitz dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const blitzScripts = new BlitzScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass HttpServerScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  async testE2EProtected(project: Project, argv: TestArgv, startCommand: string): Promise<string> {\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const testTarget = argv.targets && argv.targets.length > 0 ? argv.targets.join(' ') : 'test/e2e/';\n\n    return `YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port}\n        && vitest run ${testTarget} --color --passWithNoTests --allowOnly${suffix}\"`;\n  }\n}\n\nexport const httpServerScripts = new HttpServerScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Next.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass NextScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `next dev --turbopack ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const nextScripts = new NextScripts();\n","import type { Project } from '../../project.js';\nimport { SERVER_LOG_FILE } from '../../utils/log.js';\nimport { runtimeWithArgs } from '../../utils/runtime.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PlainAppScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected startDevProtected(_1: Project, _2: ScriptArgv): string {\n    throw new Error('This method should not be called.');\n  }\n\n  override startDev(_: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`\n    );\n  }\n  override startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${project.buildCommand} && ${runtimeWithArgs} dist/index.js ${argv.normalizedArgsText ?? ''} | tee ${SERVER_LOG_FILE}`\n    );\n  }\n  override startTest(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${this.buildDocker(project, 'development')} && ${dockerScripts.stopAndStart(\n        project,\n        argv.normalizedDockerOptionsText ?? '',\n        argv.normalizedArgsText ?? ''\n      )}`\n    );\n  }\n\n  override testE2EDev(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EProduction(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EDocker(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testStart(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n}\n\nexport const plainAppScripts = new PlainAppScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Remix commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass RemixScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `remix dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const remixScripts = new RemixScripts();\n","export const httpServerPackages = ['express', 'fastify', 'elysia', 'hono'];\n","import chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { normalizeArgs, scriptOptionsBuilder } from '../scripts/builder.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst builder = {\n  ...scriptOptionsBuilder,\n  mode: {\n    description: 'Start mode: dev[elopment] (default) | staging | docker | docker-debug | test',\n    type: 'string',\n    alias: 'm',\n  },\n} as const;\n\nexport const startCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  command: 'start [args..]',\n  describe: 'Start app',\n  builder,\n  async handler(argv) {\n    normalizeArgs(argv);\n\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of projects.descendants) {\n      const deps = project.packageJson.dependencies ?? {};\n      const devDeps = project.packageJson.devDependencies ?? {};\n      let scripts: BaseScripts;\n      if (deps.blitz) {\n        scripts = blitzScripts;\n      } else if (deps.next) {\n        scripts = nextScripts;\n      } else if (devDeps['@remix-run/dev']) {\n        scripts = remixScripts;\n      } else if (\n        (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) ||\n        (project.hasDockerfile && /EXPOSE\\s+8080/.test(project.dockerfile))\n      ) {\n        scripts = httpServerScripts;\n      } else if (deps['build-ts'] || devDeps['build-ts']) {\n        scripts = plainAppScripts;\n      } else {\n        continue;\n      }\n      console.info(`Running \"start\" for ${project.name} ...`);\n\n      switch (argv.mode ?? 'dev') {\n        case 'dev':\n        case 'development': {\n          process.env.WB_ENV ||= 'development';\n          await runWithSpawn(await scripts.startDev(project, argv), project, argv);\n          break;\n        }\n        case 'staging': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startProduction(project, argv), project, argv);\n          break;\n        }\n        case 'docker': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'docker-debug': {\n          process.env.WB_ENV ||= 'staging';\n          argv.normalizedArgsText = `'/bin/bash'`;\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'test': {\n          process.env.WB_ENV ||= 'test';\n          const script = await scripts.startTest(project, argv);\n          await runWithSpawn(script, project, argv);\n          break;\n        }\n        default: {\n          throw new Error(`Unknown start mode: ${argv.mode}`);\n        }\n      }\n    }\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport type { scriptOptionsBuilder } from '../scripts/builder.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst builder = {\n  e2e: {\n    description:\n      'E2e test mode: headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace',\n    type: 'string',\n    choices: [\n      'headless',\n      'headless-dev',\n      'headed',\n      'headed-dev',\n      'docker',\n      'docker-debug',\n      'debug',\n      'generate',\n      'trace',\n    ],\n    default: 'headless',\n  },\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n  'unit-timeout': {\n    description: 'Timeout for unit tests',\n    type: 'number',\n  },\n} as const;\n\nconst argumentsBuilder = {\n  targets: {\n    description: 'Test target paths',\n    type: 'array',\n  },\n} as const;\n\nexport type TestArgv = Partial<\n  ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof scriptOptionsBuilder & typeof argumentsBuilder>>\n>;\n\nexport const testCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof argumentsBuilder>\n> = {\n  command: 'test [targets...]',\n  describe: 'Test project. If you pass no arguments, it will run all tests.',\n  builder: { ...builder, ...argumentsBuilder },\n  async handler(argv) {\n    await test(argv);\n  },\n};\n\nexport async function test(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof argumentsBuilder>>\n): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  if (projects.descendants.length > 1) {\n    // Disable interactive mode\n    process.env.CI = '1';\n  }\n  process.env.FORCE_COLOR ||= '3';\n  process.env.WB_ENV ||= 'test';\n\n  // Get test targets from positional arguments\n  const testTargets = (argv.targets ?? []) as string[];\n  const shouldRunAllTests = testTargets.length === 0;\n\n  // Detect test modes from target paths\n  const hasE2eTargets = testTargets.some((target) => target.includes('/e2e'));\n  const hasUnitTargets = testTargets.some((target) => target.includes('/unit'));\n  const shouldRunUnit = shouldRunAllTests || hasUnitTargets;\n  const shouldRunE2e = shouldRunAllTests || hasE2eTargets;\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test\" for ${project.name} ...`);\n\n    // Run unit tests if needed\n    if (shouldRunUnit && fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n      const unitTargets = testTargets.filter((target) => target.includes('/unit'));\n      const unitArgv = { ...argv, targets: unitTargets.length > 0 ? unitTargets : undefined };\n      await runWithSpawn(scripts.testUnit(project, unitArgv), project, argv, { timeout: argv.unitTimeout });\n    }\n    // Skip e2e tests if not needed or no e2e directory exists\n    if (!shouldRunE2e || !fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      continue;\n    }\n\n    // Get e2e targets for this project\n    const e2eTargets = testTargets.filter((target) => target.includes('/e2e'));\n    const e2eArgv = { ...argv, targets: e2eTargets.length > 0 ? e2eTargets : undefined };\n\n    switch (argv.e2e) {\n      case 'headless': {\n        await runWithSpawn(await scripts.testE2EProduction(project, e2eArgv, {}), project, argv);\n        continue;\n      }\n      case 'headless-dev': {\n        await runWithSpawn(await scripts.testE2EDev(project, e2eArgv, {}), project, argv);\n        continue;\n      }\n      case 'docker': {\n        await testOnDocker(project, e2eArgv, scripts);\n        continue;\n      }\n      case 'docker-debug': {\n        const e2eTarget = e2eTargets.length > 0 ? e2eTargets.join(' ') : 'test/e2e/';\n        await testOnDocker(project, e2eArgv, scripts, `test ${e2eTarget} --debug`);\n        continue;\n      }\n    }\n    if (deps.blitz || deps.next || devDeps['@remix-run/dev']) {\n      const e2eTarget = e2eTargets.length > 0 ? e2eTargets.join(' ') : 'test/e2e/';\n      switch (argv.e2e) {\n        case 'headed': {\n          await runWithSpawn(\n            await scripts.testE2EProduction(project, e2eArgv, { playwrightArgs: `test ${e2eTarget} --headed` }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'headed-dev': {\n          await runWithSpawn(\n            await scripts.testE2EDev(project, e2eArgv, { playwrightArgs: `test ${e2eTarget} --headed` }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'debug': {\n          await runWithSpawn(\n            await scripts.testE2EProduction(project, e2eArgv, { playwrightArgs: `test ${e2eTarget} --debug` }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'generate': {\n          await runWithSpawn(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: `codegen http://localhost:${project.env.PORT}`,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'trace': {\n          await runWithSpawn(`BUN playwright show-trace`, project, argv);\n          break;\n        }\n      }\n    }\n  }\n}\n\nasync function testOnDocker(\n  project: Project,\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof argumentsBuilder>>,\n  scripts: BaseScripts,\n  playwrightArgs?: string\n): Promise<void> {\n  project.env.WB_DOCKER ||= '1';\n  await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n  process.exitCode = await runWithSpawn(\n    await scripts.testE2EDocker(project, argv, {\n      playwrightArgs,\n    }),\n    project,\n    argv,\n    { exitIfFailed: false }\n  );\n  await runWithSpawn(dockerScripts.stop(project), project, argv);\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst testOnCiBuilder = {\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n} as const;\nexport const testOnCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'test-on-ci',\n  describe: 'Test project on CI with no options.',\n  builder: testOnCiBuilder,\n  async handler(argv) {\n    await testOnCi(argv);\n  },\n};\n\nexport async function testOnCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  process.env.CI ||= '1';\n  process.env.FORCE_COLOR ||= '3';\n  process.env.WB_ENV ||= 'test';\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test-on-ci\" for ${project.name} ...`);\n\n    await runWithSpawnInParallel(dockerScripts.stopAll(), project, argv);\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n      // CI mode disallows `only` to avoid including debug tests\n      await runWithSpawnInParallel(scripts.testUnit(project, argv).replaceAll(' --allowOnly', ''), project, argv);\n    }\n    await runWithSpawnInParallel(await scripts.testStart(project, argv), project, argv);\n    await promisePool.promiseAll();\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      if (project.hasDockerfile) {\n        project.env.WB_DOCKER ||= '1';\n        await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n      }\n      const script = project.hasDockerfile\n        ? await scripts.testE2EDocker(project, argv, {})\n        : await scripts.testE2EProduction(project, argv, {});\n      process.exitCode = await runWithSpawn(\n        // CI mode disallows `only` to avoid including debug tests\n        script.replaceAll(' --allowOnly', ''),\n        project,\n        argv,\n        {\n          exitIfFailed: false,\n        }\n      );\n      await runWithSpawn(dockerScripts.stop(project), project, argv);\n    }\n  }\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {} as const;\n\nexport const typeCheckCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>\n> = {\n  command: 'typecheck',\n  describe: 'Run type checking. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    const projects = await findDescendantProjects(argv, false);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    let removedNextDir = false as boolean;\n    const promises = projects.descendants.map(async (project) => {\n      const commands: string[] = [];\n      if (!project.packageJson.workspaces) {\n        if (project.packageJson.dependencies?.typescript || project.packageJson.devDependencies?.typescript) {\n          commands.push('BUN tsc --noEmit --Pretty');\n        }\n        if (project.packageJson.devDependencies?.pyright) {\n          commands.push('YARN pyright');\n        }\n      } else if (\n        project.hasSourceCode &&\n        (project.packageJson.dependencies?.typescript || project.packageJson.devDependencies?.typescript)\n      ) {\n        commands.push('BUN tsc --noEmit --Pretty');\n      }\n      while (commands.length > 0) {\n        const exitCode = await runWithSpawnInParallel(commands.join(' && '), project, argv, {\n          // Disable interactive mode\n          ci: projects.descendants.length > 1,\n          exitIfFailed: false,\n          forceColor: true,\n        });\n\n        // Re-try type checking after removing `.next` directory\n        const nextDirPath = path.join(project.dirPath, '.next');\n        if (exitCode && fs.existsSync(nextDirPath)) {\n          fs.rmSync(nextDirPath, { force: true, recursive: true });\n          console.info(chalk.yellow('Removed `.next` directory. We will re-try type checking.'));\n          removedNextDir = true;\n          continue;\n        }\n\n        return exitCode;\n      }\n    });\n    const exitCodes = await Promise.all(promises);\n    let finalExitCode = 0;\n    for (const [i, exitCode] of exitCodes.entries()) {\n      if (exitCode) {\n        const deps = projects.descendants[i]?.packageJson.dependencies ?? {};\n        if (deps.blitz) {\n          console.info(chalk.yellow('Please try \"yarn gen-code\" if you face unknown type errors.'));\n        }\n        finalExitCode = exitCode;\n      }\n    }\n    if (!finalExitCode)\n      console.info(\n        chalk.green(\n          removedNextDir\n            ? '-----\\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.'\n            : 'No type errors found.'\n        )\n      );\n    process.exit(finalExitCode);\n  },\n};\n\nexport const tcCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  ...typeCheckCommand,\n  command: 'tc',\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport treeKill from 'tree-kill';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { buildIfNeededCommand } from './commands/buildIfNeeded.js';\nimport { killPortIfNonCiCommand } from './commands/killPortIfNonCi.js';\nimport { lintCommand } from './commands/lint.js';\nimport { optimizeForDockerBuildCommand } from './commands/optimizeForDockerBuild.js';\nimport { prismaCommand } from './commands/prisma.js';\nimport { retryCommand } from './commands/retry.js';\nimport { setupCommand } from './commands/setup.js';\nimport { startCommand } from './commands/start.js';\nimport { testCommand } from './commands/test.js';\nimport { testOnCiCommand } from './commands/testOnCi.js';\nimport { tcCommand, typeCheckCommand } from './commands/typecheck.js';\nimport { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\n\nawait yargs(hideBin(process.argv))\n  .scriptName('wb')\n  .options(sharedOptionsBuilder)\n  .middleware((argv) => {\n    const workingDir = argv['working-dir'];\n    if (workingDir) {\n      const dirPath = path.resolve(workingDir);\n      process.chdir(dirPath);\n    }\n\n    removeNpmAndYarnEnvironmentVariables(process.env);\n  })\n  .command(buildIfNeededCommand)\n  .command(killPortIfNonCiCommand)\n  .command(lintCommand)\n  .command(optimizeForDockerBuildCommand)\n  .command(prismaCommand)\n  .command(retryCommand)\n  .command(setupCommand)\n  .command(startCommand)\n  .command(testCommand)\n  .command(testOnCiCommand)\n  .command(typeCheckCommand)\n  .command(tcCommand)\n  .demandCommand()\n  .strict()\n  .version(getVersion())\n  .help().argv;\n\nfunction getVersion(): string {\n  let packageJsonDir = path.dirname(new URL(import.meta.url).pathname);\n  while (!fs.existsSync(path.join(packageJsonDir, 'package.json'))) {\n    packageJsonDir = path.dirname(packageJsonDir);\n  }\n  const packageJson = JSON.parse(fs.readFileSync(path.join(packageJsonDir, 'package.json'), 'utf8')) as {\n    version: string;\n  };\n  return packageJson.version;\n}\n\nfor (const signal of ['SIGINT', 'SIGTERM', 'SIGQUIT']) {\n  process.on(signal, () => {\n    treeKill(process.pid);\n    process.exit();\n  });\n}\n"],"names":["cachedEnvVars","Map","readEnvFile","filePath","cached","get","parsed","config","path","resolve","processEnv","set","async","spawnAsync","command","args","options","Promise","reject","proc","spawn","stdout","setEncoding","stderr","on","data","printingStdout","process","write","mergeOutAndError","printingStderr","stopped","stopProcess","pid","verbose","console","info","treeKill","killOnExit","error","removeListener","removeAllListeners","code","signal","undefined","Error","status","input","stdin","end","t","s","i","e","n","entries","h","blocks","reset","finalized","block","start","lastByteIndex","constructor","this","padding","outputBits","blockCount","byteCount","outputBlocks","extraBytes","update","o","length","l","c","f","codePointAt","r","finalize","hex","a","u","d","b","k","y","x","B","p","C","z","I","g","w","A","P","E","j","m","q","v","D","F","G","H","J","K","L","M","N","O","Q","R","S","T","U","V","W","X","Y","Z","$","_","tt","st","it","et","ot","nt","ht","rt","lt","ct","ft","instance","from","name","message","stack","push","cause","stub","hydrate","Uint8Array","btoa","decode","create","encode","atob","Set","values","add","Date","toJSON","RegExp","flags","source","URL","href","map","TextEncoder","TextDecoder","JSON","stringify","Number","isNaN","isFinite","toString","Array","isArray","fill","slice","Object","cacheDuration","POSITIVE_INFINITY","getCacheKey","kind","now","call","isCI","ciEnv","Project","_initProto","_applyDecs","memoizeOne","argv","pathByName","dirPath","loadEnv","_dirPath","isBunAvailable","test","fs","readFileSync","join","rootDirPath","buildCommand","packageJson","scripts","build","includes","existsSync","dockerfile","findFile","hasDockerfile","hasSourceCode","dockerImageName","replaceAll","env","envVars","envPathAndLoadedEnvVarCountPairs","cwd","envPaths","envPath","cascade","cascadeEnv","cascadeNodeEnv","NODE_ENV","autoCascadeEnv","WB_ENV","includeRootEnv","rootPath","flatMap","filter","relative","envPathAndEnvVarCountPairs","count","key","value","checkEnv","missingKeys","keys","expand","readEnvironmentVariables","parse","packageJsonPath","hasPrisma","dependencies","prisma","devDependencies","hasVitest","vitest","skipLaunchingServerForPlaywright","CI","configPath","dockerPackageJson","dirname","binExists","binFound","currentPath","binPath","PATH","parentPath","fileName","find","findSelfProject","findDescendantProjects","rootAndSelfProjects","thisProject","rootProject","workspaces","endsWith","root","self","findRootAndSelfProjects","descendants","getAllDescendantProjects","projects","workspace","globPattern","packageDirs","workspacePath","ws","globby","dot","onlyDirectories","subPackageDirPath","isRunningOnBun","versions","bun","npm_execpath","runtimeWithArgs","packageManager","packageManagerWithRun","buildIfNeededCommand","describe","description","type","alias","handler","projectPathForTesting","project","chalk","red","canSkip","cacheFilePath","contentHash","cacheDirectoryPath","promises","mkdir","recursive","hash","createHash","commitHash","child_process","execSync","trim","environmentJson","ignoringEnvVarNames","has","toSorted","key1","key2","localeCompare","filteredFilePaths","spawnSync","stdio","encoding","split","line","replace","includePatterns","some","pattern","includeSuffix","suffix","excludePatterns","copy","digest","updateHashWithDiffResult","cachedContentHash","fn","ignoreEnoentAsync","readFile","canSkipBuild","green","dryRun","writeFile","buildIfNeeded","ret","shell","exitCode","killPortIfNonCiCommand","builder","exit","portEnv","PORT","port","isInteger","killPortProcess","killPortIfNonCi","promisePool","PromisePool","defaultOptions","exitIfFailed","runWithSpawn","script","opts","normalizedScript","normalizeScript","printStart","printable","runnable","printFinishedAndExitIfNeeded","configureEnv","timeout","onSignal","runWithSpawnInParallel","runAndWaitForReturnValue","out","newScript","blitz","printableScript","fixBunCommand","runnableScript","cascadeOption","prefix","weak","gray","cyan","bold","newEnv","ci","forceColor","FORCE_COLOR","biomeExtensions","prettierExtensions","prettierOnlyExtensions","ext","lintCommand","fix","format","files","biomeArgsText","prettierArgsText","sortPackageJsonArgsText","filePathsToBeCheckedByBiome","filePathsToBeFormattedByPrettier","packageJsonFilePaths","file","String","extension","extname","biomeCommand","biomePromise","prepareForRunningCommand","commandName","optimizeForDockerBuildCommand","outside","deps","startsWith","optimizeDevDependencies","optimizeScripts","optimizeRootProps","distDirPath","devDeps","nameWordsToBeRemoved","removedDeps","word","nameWordsOfUnnecessaryScripts","contentWordsOfUnnecessaryScripts","removedScripts","content","private","publishConfig","prettier","getDatabaseDirPath","prismaScripts","cleanUpLitestream","deploy","additionalOptions","deployForce","listBackups","migrate","seed","migrateDev","baseReset","raw","restore","outputPath","removeSqliteArtifacts","scriptPath","setUpDBForLitestream","studio","dbUrlOrPath","FILE_SCHEMA","DATABASE_URL","POSSIBLE_PATHS","schemaPath","dbPath","sqlitePath","sharedOptionsBuilder","default","prismaCommand","yargs","cleanUpLitestreamCommand","createLitestreamConfigCommand","deployCommand","deployForceCommand","listBackupsCommand","setUpDBForLitestreamCommand","migrateCommand","migrateDevCommand","resetCommand","restoreCommand","seedCommand","studioCommand","defaultCommand","demandCommand","strict","allProjects","findPrismaProjects","createLitestreamConfig","unknownOptions","extractUnknownOptions","output","restored","fullCommand","trimEnd","Boolean","requiredEnvVars","CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID","CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME","CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID","CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY","missingEnvVars","retentionCheckInterval","litestreamConfig","writeFileSync","reason","filtered","knownOptions","sharedOptionKeys","sharedOptionAliases","option","allKnownOptions","kebabCaseKey","match","toLowerCase","item","retryCommand","retry","cmdAndArgs","lastStatus","yellow","setupCommand","dirents","readdir","withFileTypes","os","platform","packages","isFile","version","promiseAll","playwright","setup","toDevNull","silent","killed","killPortProcessImmediatelyAndOnExit","available","host","probePort","isPortAvailable","killPortContainerAndProcess","killFunc","filterArgs","containerIds","id","listDockerContainerIds","removeDockerContainers","stopDockerContainerByPort","checkAndKillPortProcess","rawPort","server","createServer","once","err","close","listen","dockerScripts","buildImage","stopAndStart","additionalArgs","stop","spawnSyncOnExit","stopAll","BaseScripts","shouldWaitAndOpenApp","buildDocker","startDev","startDevProtected","waitAndOpenApp","startProduction","startProductionProtected","startTest","startDocker","normalizedDockerOptionsText","normalizedArgsText","ecosystemConfigPath","findEcosystemConfigPath","commands","cmd","testE2EDev","testE2EProtected","testE2EProduction","testE2EDocker","testStart","waitApp","startCommand","playwrightArgs","playwrightCommand","targets","base","target","rest","parts","unshift","buildPlaywrightCommand","testUnit","testTarget","blitzScripts","super","httpServerScripts","watch","nextScripts","plainAppScripts","_1","_2","remixScripts","httpServerPackages","mode","arg","dockerOptions","normalizeArgs","next","testCommand","e2e","choices","testTargets","shouldRunAllTests","hasE2eTargets","hasUnitTargets","shouldRunUnit","shouldRunE2e","unitTargets","unitArgv","unitTimeout","e2eTargets","e2eArgv","testOnDocker","e2eTarget","WB_DOCKER","testOnCiCommand","testOnCi","typeCheckCommand","removedNextDir","typescript","pyright","nextDirPath","rmSync","force","exitCodes","all","finalExitCode","tcCommand","hideBin","scriptName","middleware","workingDir","chdir","BERRY_BIN_FOLDER","upperKey","toUpperCase","removeNpmAndYarnEnvironmentVariables","packageJsonDir","url","pathname","getVersion","help"],"mappings":"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","x_google_ignoreList":[2,3,4,5,6]}
|
|
9
|
+
*/const $=[..."0123456789abcdef"],P=[6,1536,393216,100663296],R=[0,8,16,24],S=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];const x=e=>{const t=[];for(const[n,r]of e.entries())t[n]=r;return t};class N{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(e,t,n){this.padding=t,this.outputBits=n,this.blockCount=1600-(e<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=n>>5,this.extraBytes=(31&n)>>3;for(let e=0;e<50;++e)this.s[e]=0}update(e){if(this.finalized)throw new Error("finalize already called");const t=this.blocks,n=this.byteCount,r=e.length,s=this.blockCount,o=this.s;let i,a,c=0;for(;c<r;){if(this.reset)for(this.reset=!1,t[0]=this.block,i=1;i<s+1;++i)t[i]=0;for(i=this.start;c<r&&i<n;++c)a=e.codePointAt(c)||0,a<128?t[i>>2]|=a<<R[3&i++]:a<2048?(t[i>>2]|=(192|a>>6)<<R[3&i++],t[i>>2]|=(128|63&a)<<R[3&i++]):a<55296||a>=57344?(t[i>>2]|=(224|a>>12)<<R[3&i++],t[i>>2]|=(128|a>>6&63)<<R[3&i++],t[i>>2]|=(128|63&a)<<R[3&i++]):(a=65536+((1023&a)<<10|1023&(e.codePointAt(++c)||0)),t[i>>2]|=(240|a>>18)<<R[3&i++],t[i>>2]|=(128|a>>12&63)<<R[3&i++],t[i>>2]|=(128|a>>6&63)<<R[3&i++],t[i>>2]|=(128|63&a)<<R[3&i++]);if(this.lastByteIndex=i,i>=n){for(this.start=i-n,this.block=t[s],i=0;i<s;++i)o[i]^=t[i];j(o),this.reset=!0}else this.start=i}return this}finalize(){if(this.finalized)return;this.finalized=!0;const e=this.blocks;let t=this.lastByteIndex;const n=this.blockCount,r=this.s;if(e[t>>2]|=this.padding[3&t],this.lastByteIndex===this.byteCount)for(e[0]=e[n],t=1;t<n+1;++t)e[t]=0;for(e[n-1]|=2147483648,t=0;t<n;++t)r[t]^=e[t];j(r)}hex(){this.finalize();const e=this.blockCount;let t=this.s;const n=this.outputBlocks,r=this.extraBytes;let s,o=0,i=0,a="";for(;i<n;){for(o=0;o<e&&i<n;++o,++i)s=t[o],a+=$[s>>4&15]+$[15&s]+$[s>>12&15]+$[s>>8&15]+$[s>>20&15]+$[s>>16&15]+$[s>>28&15]+$[s>>24&15];i%e===0&&(t=x(t),j(t),o=0)}return r&&(s=t[o],a+=$[s>>4&15]+$[15&s],r>1&&(a+=$[s>>12&15]+$[s>>8&15]),r>2&&(a+=$[s>>20&15]+$[s>>16&15])),a}}const j=function(e){let t,n,r,s,o,i,a,c,d,l,u,p,f,m,h,g,b,v,y,w,k,E,A,$,P,R,x,N,j,D,_,T,O,I,C,B,L,F,J,W,z,U,M,Y,V,q,K,G,H,Q,X,Z,ee,te,ne,re,se,oe,ie,ae,ce,de,le;for(r=0;r<48;r+=2)s=e[0]^e[10]^e[20]^e[30]^e[40],o=e[1]^e[11]^e[21]^e[31]^e[41],i=e[2]^e[12]^e[22]^e[32]^e[42],a=e[3]^e[13]^e[23]^e[33]^e[43],c=e[4]^e[14]^e[24]^e[34]^e[44],d=e[5]^e[15]^e[25]^e[35]^e[45],l=e[6]^e[16]^e[26]^e[36]^e[46],u=e[7]^e[17]^e[27]^e[37]^e[47],p=e[8]^e[18]^e[28]^e[38]^e[48],f=e[9]^e[19]^e[29]^e[39]^e[49],t=p^(i<<1|a>>>31),n=f^(a<<1|i>>>31),e[0]^=t,e[1]^=n,e[10]^=t,e[11]^=n,e[20]^=t,e[21]^=n,e[30]^=t,e[31]^=n,e[40]^=t,e[41]^=n,t=s^(c<<1|d>>>31),n=o^(d<<1|c>>>31),e[2]^=t,e[3]^=n,e[12]^=t,e[13]^=n,e[22]^=t,e[23]^=n,e[32]^=t,e[33]^=n,e[42]^=t,e[43]^=n,t=i^(l<<1|u>>>31),n=a^(u<<1|l>>>31),e[4]^=t,e[5]^=n,e[14]^=t,e[15]^=n,e[24]^=t,e[25]^=n,e[34]^=t,e[35]^=n,e[44]^=t,e[45]^=n,t=c^(p<<1|f>>>31),n=d^(f<<1|p>>>31),e[6]^=t,e[7]^=n,e[16]^=t,e[17]^=n,e[26]^=t,e[27]^=n,e[36]^=t,e[37]^=n,e[46]^=t,e[47]^=n,t=l^(s<<1|o>>>31),n=u^(o<<1|s>>>31),e[8]^=t,e[9]^=n,e[18]^=t,e[19]^=n,e[28]^=t,e[29]^=n,e[38]^=t,e[39]^=n,e[48]^=t,e[49]^=n,m=e[0],h=e[1],q=e[11]<<4|e[10]>>>28,K=e[10]<<4|e[11]>>>28,N=e[20]<<3|e[21]>>>29,j=e[21]<<3|e[20]>>>29,ae=e[31]<<9|e[30]>>>23,ce=e[30]<<9|e[31]>>>23,U=e[40]<<18|e[41]>>>14,M=e[41]<<18|e[40]>>>14,I=e[2]<<1|e[3]>>>31,C=e[3]<<1|e[2]>>>31,g=e[13]<<12|e[12]>>>20,b=e[12]<<12|e[13]>>>20,G=e[22]<<10|e[23]>>>22,H=e[23]<<10|e[22]>>>22,D=e[33]<<13|e[32]>>>19,_=e[32]<<13|e[33]>>>19,de=e[42]<<2|e[43]>>>30,le=e[43]<<2|e[42]>>>30,te=e[5]<<30|e[4]>>>2,ne=e[4]<<30|e[5]>>>2,B=e[14]<<6|e[15]>>>26,L=e[15]<<6|e[14]>>>26,v=e[25]<<11|e[24]>>>21,y=e[24]<<11|e[25]>>>21,Q=e[34]<<15|e[35]>>>17,X=e[35]<<15|e[34]>>>17,T=e[45]<<29|e[44]>>>3,O=e[44]<<29|e[45]>>>3,$=e[6]<<28|e[7]>>>4,P=e[7]<<28|e[6]>>>4,re=e[17]<<23|e[16]>>>9,se=e[16]<<23|e[17]>>>9,F=e[26]<<25|e[27]>>>7,J=e[27]<<25|e[26]>>>7,w=e[36]<<21|e[37]>>>11,k=e[37]<<21|e[36]>>>11,Z=e[47]<<24|e[46]>>>8,ee=e[46]<<24|e[47]>>>8,Y=e[8]<<27|e[9]>>>5,V=e[9]<<27|e[8]>>>5,R=e[18]<<20|e[19]>>>12,x=e[19]<<20|e[18]>>>12,oe=e[29]<<7|e[28]>>>25,ie=e[28]<<7|e[29]>>>25,W=e[38]<<8|e[39]>>>24,z=e[39]<<8|e[38]>>>24,E=e[48]<<14|e[49]>>>18,A=e[49]<<14|e[48]>>>18,e[0]=m^~g&v,e[1]=h^~b&y,e[10]=$^~R&N,e[11]=P^~x&j,e[20]=I^~B&F,e[21]=C^~L&J,e[30]=Y^~q&G,e[31]=V^~K&H,e[40]=te^~re&oe,e[41]=ne^~se&ie,e[2]=g^~v&w,e[3]=b^~y&k,e[12]=R^~N&D,e[13]=x^~j&_,e[22]=B^~F&W,e[23]=L^~J&z,e[32]=q^~G&Q,e[33]=K^~H&X,e[42]=re^~oe&ae,e[43]=se^~ie&ce,e[4]=v^~w&E,e[5]=y^~k&A,e[14]=N^~D&T,e[15]=j^~_&O,e[24]=F^~W&U,e[25]=J^~z&M,e[34]=G^~Q&Z,e[35]=H^~X&ee,e[44]=oe^~ae&de,e[45]=ie^~ce&le,e[6]=w^~E&m,e[7]=k^~A&h,e[16]=D^~T&$,e[17]=_^~O&P,e[26]=W^~U&I,e[27]=z^~M&C,e[36]=Q^~Z&Y,e[37]=X^~ee&V,e[46]=ae^~de&te,e[47]=ce^~le&ne,e[8]=E^~m&g,e[9]=A^~h&b,e[18]=T^~$&R,e[19]=O^~P&x,e[28]=U^~I&B,e[29]=M^~C&L,e[38]=Z^~Y&q,e[39]=ee^~V&K,e[48]=de^~te&re,e[49]=le^~ne&se,e[0]^=S[r],e[1]^=S[r+1]},D=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,r,s])=>{e.name=t,e.message=n,void 0===r?delete e.stack:e.stack=r,void 0!==s&&(e.cause=s)}},t={instance:Uint8Array,from:e=>[btoa(T.decode(e))],create:([e])=>_.encode(atob(e))},n={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,r]of t)e.set(n,r)}},r={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},s={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},o={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},i={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,n,r,s,o,i].map(e=>[e.instance.name,e]))}(),_=new TextEncoder,T=new TextDecoder("utf-8");function O(e=void 0,t=D){return JSON.stringify(B(e,t))}function I(e){if(void 0===e)return-1;if("number"==typeof e){if(Number.isNaN(e))return-3;if(!Number.isFinite(e))return e<0?-5:-4}return null}const C=[];function B(e,t=D){const n=I(e);if(null!==n)return n;const r=[],s=new Map;return function e(n){const o=I(n);if(null!==o)return o;let i=s.get(n);if(void 0!==i)return i;switch(i=r.length,typeof n){case"number":case"string":case"boolean":r[i]=n,s.set(n,i);break;case"bigint":r[i]=[-6,n.toString(16)],s.set(n,i);break;case"object":if(null===n)r[i]=n,s.set(n,i);else if(Array.isArray(n)){const t=function(e){if(C.length<e){const t=C.length;C.length=e,C.fill(-2,t,e)}return C.slice(0,e)}(n.length);r[i]=t,s.set(n,i);for(const[r,s]of n.entries())t[r]=e(s)}else{const[o,a]=function(e,t){const n=e.constructor;if("function"==typeof n){const r=n.name,s=t.get(r);if(void 0!==s)return[r,s.from(e)]}const r=Object.entries(e),s=r.length,o=Array.from({length:s+s});for(let e=0;e<s;e++){const t=r[e],n=e+e;o[n]=t[0],o[n+1]=t[1]}return["",o]}(n,t),c=a.length,d=Array.from({length:c+1});d[0]=o,r[i]=d,s.set(n,i);for(let t=0;t<c;t++)d[t+1]=e(a[t])}}return i}(e),r}function L(e,t){return function(e){return new N(512,P,512).update(e).hex()}(O([e,t]))}const F=function({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:t=L}={}){return function(n,r){let s,o,i;return"getter"===r?.kind?function(){const r=t(this,[]),a=Date.now();return(i!==r||a-o>e)&&(i=r,s=n.call(this),o=a),s}:function(...a){const c=t(this,a),d=Date.now();return(i!==c||d-o>e)&&(i=c,s=r?n.call(this,...a):n(...a),o=d),s}}}({getCacheKey:L});function J(e){return!!e&&"0"!==e&&"false"!==e}let W;class z{static{[W]=function(e,t,n,r,s){var o,i,a,c,d,l,u,p=Symbol.metadata||Symbol.for("Symbol.metadata"),f=Object.defineProperty,m=Object.create,h=[m(null),m(null)],g=t.length;function b(t,n,r){return function(s,o){n&&(o=s,s=e);for(var i=0;i<t.length;i++)o=t[i].apply(s,r?[o]:[]);return r?o:s}}function v(e,t,n,r){if("function"!=typeof e&&(r||void 0!==e))throw new TypeError(t+" must "+(n||"be")+" a function"+(r?"":" or undefined"));return e}function y(e,t,n,r,s,a,c,d,l,u,p){function m(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),y=t[3],w=!c,k=1===s,A=3===s,$=4===s,P=2===s;function R(t,n,r){return function(s,o){return n&&(o=s,s=e),r&&r(s),S[t].call(s,o)}}if(!w){var S={},x=[],N=A?"get":$||k?"set":"value";if(l?(u||k?S={get:E(function(){return y(this)},r,"get"),set:function(e){t[4](this,e)}}:S[N]=y,u||E(S[N],r,P?"":N)):u||(S=Object.getOwnPropertyDescriptor(e,r)),!u&&!l){if((i=h[+d][r])&&7!==(i^s))throw Error("Decorating two elements with the same name ("+S[N].name+") is not supported yet");h[+d][r]=s<3?1:s}}for(var j=e,D=g.length-1;D>=0;D-=n?2:1){var _=v(g[D],"A decorator","be",!0),T=n?g[D-1]:void 0,O={},I={kind:["field","accessor","method","getter","setter","class"][s],name:r,metadata:o,addInitializer:function(e,t){if(e.v)throw new TypeError("attempted to call addInitializer after decoration was finished");v(t,"An initializer","be",!0),a.push(t)}.bind(null,O)};if(w)i=_.call(T,j,I),O.v=1,v(i,"class decorators","return")&&(j=i);else if(I.static=d,I.private=l,i=I.access={has:l?p.bind():function(e){return r in e}},$||(i.get=l?P?function(e){return m(e),S.value}:R("get",0,m):function(e){return e[r]}),P||A||(i.set=l?R("set",0,m):function(e,t){e[r]=t}),j=_.call(T,k?{get:S.get,set:S.set}:S[N],I),O.v=1,k){if("object"==typeof j&&j)(i=v(j.get,"accessor.get"))&&(S.get=i),(i=v(j.set,"accessor.set"))&&(S.set=i),(i=v(j.init,"accessor.init"))&&x.unshift(i);else if(void 0!==j)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else v(j,(u?"field":"method")+" decorators","return")&&(u?x.unshift(j):S[N]=j)}return s<2&&c.push(b(x,d,1),b(a,d,0)),u||w||(l?k?c.splice(-1,0,R("get",d),R("set",d)):c.push(P?S[N]:v.call.bind(S[N])):f(e,r,S)),j}function w(e){return f(e,p,{configurable:!0,enumerable:!0,value:o})}return o=m(null==o?null:o),d=[],l=function(e){e&&d.push(b(e))},u=function(t,r){for(var o=0;o<n.length;o++){var i=n[o],l=i[1],u=7&l;if((8&l)==t&&!u==r){var p=i[2],f=!!i[3],m=16&l;y(t?e:e.prototype,i,m,f?"#"+p:A(p),u,u<2?[]:t?c=c||[]:a=a||[],d,!!t,f,r,t&&f?function(t){return k(t)===e}:s)}}},u(8,0),u(0,0),u(8,1),u(0,1),l(a),l(c),i=d,g||w(e),{e:i,get c(){var n=[];return g&&[w(e=y(e,[t],r,e.name,5,n)),b(n,1)]}}}(this,[],[[F,3,"isBunAvailable"],[F,3,"buildCommand"],[F,3,"rootDirPath"],[F,3,"dockerfile"],[F,3,"hasDockerfile"],[F,3,"hasSourceCode"],[F,3,"name"],[F,3,"dockerImageName"],[F,3,"env"],[F,3,"packageJson"],[F,3,"packageJsonPath"],[F,3,"hasPrisma"],[F,3,"hasVitest"],[F,3,"skipLaunchingServerForPlaywright"],[F,3,"dockerPackageJson"],[F,3,"binExists"]]).e}argv=void W(this);pathByName=new Map;constructor(e,n,r){this._dirPath=t.resolve(e),this.argv=n,this.loadEnv=r}get isBunAvailable(){try{return/(^|\n)bun\s/.test(e.readFileSync(t.join(this.rootDirPath,".tool-versions"),"utf8"))}catch{return!1}}get buildCommand(){return this.packageJson.scripts?.build?.includes("buildIfNeeded")?"YARN run build":this.packageJson.scripts?.build?"YARN wb buildIfNeeded "+(this.argv.verbose?"--verbose":""):"echo 'No build script'"}get dirPath(){return this._dirPath}get rootDirPath(){return e.existsSync(t.join(this.dirPath,"..","..","package.json"))?t.resolve(this.dirPath,"..",".."):this.dirPath}get dockerfile(){return e.readFileSync(this.findFile("Dockerfile"),"utf8")}get hasDockerfile(){try{return!!this.findFile("Dockerfile")}catch{return!1}}get hasSourceCode(){return e.existsSync(t.join(this.dirPath,"src"))}get name(){return this.packageJson.name||"unknown"}get dockerImageName(){return(this.packageJson.name||"unknown").replaceAll("@","").replaceAll("/","-")}get env(){if(!this.loadEnv)return process.env;const[n,r]=function(n,r){let s=(n.env??[]).map(e=>t.resolve(r,e.toString()));const o=n.cascadeEnv??(n.cascadeNodeEnv?process.env.NODE_ENV||"development":n.autoCascadeEnv?process.env.WB_ENV||process.env.NODE_ENV||"development":void 0);if("string"==typeof o){if(0===s.length&&(s.push(t.join(r,".env")),n.includeRootEnv)){const n=t.resolve(r,"..","..");e.existsSync(t.join(n,"package.json"))&&s.push(t.join(n,".env"))}s=s.flatMap(e=>o?[`${e}.${o}.local`,`${e}.local`,`${e}.${o}`,e]:[`${e}.local`,e])}s=s.filter(t=>e.existsSync(t)).map(e=>t.relative(r,e)),n.verbose&&(console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`),console.info("Reading env files:",s.join(", ")));const i=[],a={};for(const e of s){let s=0;for(const[n,o]of Object.entries(y(t.join(r,e))))n in a||(a[n]=o,s++);i.push([e,s]),n.verbose&&s>0&&console.info(`Read ${s} environment variables from ${e}`)}if(n.checkEnv){const e=Object.keys(y(t.join(r,n.checkEnv))).filter(e=>!(e in a));if(e.length>0)throw new Error(`Missing environment variables in [${s.join(", ")}]: [${e.join(", ")}]`)}return[p({parsed:a,processEnv:{}}).parsed??a,i]}(this.argv,this.dirPath);for(const[e,t]of r)console.info(`Loaded ${t} environment variables from ${e}`);return{...n,...process.env}}get packageJson(){return JSON.parse(e.readFileSync(this.packageJsonPath,"utf8"))}get packageJsonPath(){return t.join(this.dirPath,"package.json")}get hasPrisma(){return!!(this.packageJson.dependencies?.prisma??this.packageJson.devDependencies?.prisma)}get hasVitest(){return!!(this.packageJson.dependencies?.vitest??this.packageJson.devDependencies?.vitest)}get skipLaunchingServerForPlaywright(){if(J(this.env.CI))return!1;try{const t=this.findFile("playwright.config.ts");return/\bwebServer\b/.test(e.readFileSync(t,"utf8"))}catch{return!1}}get dockerPackageJson(){return t.dirname(this.findFile("Dockerfile"))===this.dirPath?this.packageJson:JSON.parse(e.readFileSync(t.join(t.dirname(this.findFile("Dockerfile")),"package.json"),"utf8"))}get binExists(){let n=!1,r=this.dirPath;for(;;){const s=t.join(r,"node_modules",".bin");if(e.existsSync(s)&&(this.env.PATH=`${s}:${this.env.PATH}`,n=!0),e.existsSync(t.join(r,".git")))break;const o=t.dirname(r);if(r===o)break;r=o}return n}findFile(n){let r=this.pathByName.get(n);if(r)return r;if(r=[n,t.join("..","..",n)].map(e=>t.resolve(this.dirPath,e)).find(t=>e.existsSync(t)),!r)throw new Error(`File not found: ${n}`);return this.pathByName.set(n,r),r}}function U(n,r=!0,s){if(s??=process.cwd(),e.existsSync(t.join(s,"package.json")))return new z(s,n,r)}async function M(n,r=!0,s){const o=function(n,r=!0,s){if(s??=process.cwd(),!e.existsSync(t.join(s,"package.json")))return;const o=new z(s,n,r);let i=o;if(!o.packageJson.workspaces&&t.dirname(s).endsWith("/packages")){const o=t.resolve(s,"..","..");e.existsSync(t.join(o,"package.json"))&&(i=new z(o,n,r))}return{root:i,self:o}}(n,r,s);if(o)return{...o,descendants:o.root===o.self?await Y(n,o.root,r):[o.self]}}async function Y(n,r,s){const o=[r],i=r.packageJson.workspaces;if(!Array.isArray(i))return o;const a=[],c=[];for(const n of i.map(e=>t.join(r.dirPath,e)))e.existsSync(n)?c.push(n):a.push(n);c.push(...await l(a,{dot:!0,onlyDirectories:!0}));for(const r of c)e.existsSync(t.join(r,"package.json"))&&o.push(new z(r,n,s));return o}const V=process.versions.bun||process.argv[0]?.endsWith("/bun")||process.env.npm_execpath?.endsWith("/bun"),q=V?"bun --bun run":"node",K=V?"bun":"yarn",G=V?"bun --bun run":"yarn",H={command:"buildIfNeeded",describe:"Build code if changes are detected",builder:{command:{description:"A build command (default: yarn|bun build)",type:"string",alias:"c"}},async handler(n){await async function(n,r){const s=U(n,!0,r);if(!s)return console.error(d.red("No project found.")),!0;if(n={...n,command:n.command??(V?"bun run build":"yarn build")},!e.existsSync(t.join(s.rootDirPath,".git")))return Q(s,n),!0;const[i,a,l]=await async function(n,r){const s=t.resolve(n.dirPath,"node_modules",".cache","build"),i=t.resolve(s,"last-build");await e.promises.mkdir(s,{recursive:!0});const a=c("sha256"),d=o.execSync("git rev-parse HEAD",{cwd:n.dirPath}).toString().trim();a.update(d);const l=JSON.stringify(Object.entries(n.env).filter(([e])=>!X.has(e)).toSorted(([e],[t])=>e.localeCompare(t)));a.update(l),await async function(e,t,n){return new Promise(r=>{const s=o.spawnSync("git",["status","--porcelain"],{cwd:e.dirPath,env:e.env,stdio:"pipe",encoding:"utf8"}).stdout.trim().split("\n").filter(e=>e.length>0).map(e=>e.slice(2).trim()).map(t=>"test"===e.env.WB_ENV?t.replace(/packages\/wb\/test\/fixtures\/[^/]+\//,""):t).filter(e=>(Z.some(t=>e.includes(t))||ee.some(t=>e.endsWith(t)))&&!te.some(t=>e.includes(t)));t.verbose&&console.info(`Changed files: ${s.join(", ")}`);const i=o.spawn("git",["diff","--",...s],{cwd:e.rootDirPath});i.stdout.on("data",e=>{n.update(e),t.verbose&&(console.info("Data:",e),console.info("Hash:",n.copy().digest("hex")))}),i.on("close",()=>{r()})})}(n,r,a);const u=a.digest("hex"),p=await async function(e){try{return await e()}catch(e){if("object"==typeof e&&e&&"code"in e&&"ENOENT"===e.code)return;throw e}}(()=>e.promises.readFile(i,"utf8"));return[p===u,i,u]}(s,n);if(i)return console.info(d.green(`Skip to run '${n.command}' 💫`)),!1;if(!Q(s,n))return;n.dryRun||await e.promises.writeFile(a,l,"utf8");return!0}(n)}};function Q(e,t){if(console.info(d.green(`Run '${t.command}'`)),!t.dryRun){const n=o.spawnSync(t.command??"",{cwd:e.dirPath,env:e.env,shell:!0,stdio:"inherit"});if(0!==n.status)return process.exitCode=n.status??1,!1}return!0}const X=new Set(["CI","PWDEBUG","TMPDIR"]);const Z=["src/","public/"],ee=[".js",".cjs",".mjs",".jsx",".ts",".cts",".mts",".tsx",".json",".browserslistrc","package.json","yarn.lock"],te=["test/","tests/","__tests__/","test-fixtures/","test/fixtures/"];const ne={command:"kill-port-if-non-ci",describe:"Kill the port specified by PORT environment variable if non-CI.",builder:{},async handler(e){await async function(e){const t=U(e);t||(console.error(d.red("No project found.")),process.exit(1));if(J(t.env.CI))return void console.info(`Skip killing port due to CI: ${t.env.CI}`);const n=t.env.PORT,r=Number(n);(!Number.isInteger(r)||r<=0)&&(console.error(d.red(`PORT environment variable is invalid: ${n}`)),process.exit(1));console.info(`Killing the port: ${r}`);try{await f(r)}catch{}}(e)}};const re=new m,se={exitIfFailed:!0};async function oe(e,t,n,r=se){const s=ae(e,t);if(ce(s.printable,t),n.verbose&&ce(s.runnable,t,"Start (raw)",!0),n.dryRun)return de(s.printable,0,r),0;const o=await w(s.runnable,void 0,{cwd:t.dirPath,env:le(t.env,r),shell:!0,stdio:"inherit",timeout:r.timeout,killOnExit:!0,verbose:n.verbose});return r.onSignal?.(o.signal),de(s.printable,o.status,r),o.status??1}function ie(e,t,n,r=se){return re.runAndWaitForReturnValue(async()=>{const s=ae(e,t);if(ce(s.printable,t,"Start (parallel)",!0),n.dryRun)return ce(s.printable,t,"Started (log)"),n.verbose&&ce(s.runnable,t,"Started (raw)",!0),de(s.printable,0,r),0;const o=await w(s.runnable,void 0,{cwd:t.dirPath,env:le(t.env,r),shell:!0,stdio:"pipe",timeout:r.timeout,mergeOutAndError:!0,killOnExit:!0,verbose:n.verbose});r.onSignal?.(o.signal),ce(s.printable,t,"Started (log)"),n.verbose&&ce(s.runnable,t,"Started (raw)",!0);const i=o.stdout.trim();return i&&(process.stdout.write(i),process.stdout.write("\n")),de(s.printable,o.status,r),o.status??1})}function ae(e,t){let n=e.replaceAll("\n","").replaceAll(/\s\s+/g," ").replaceAll("PRISMA generate ",t.packageJson.dependencies?.blitz?"PRISMA generate ":"PRISMA generate --no-hints ").replaceAll("PRISMA ",t.packageJson.dependencies?.blitz?"YARN blitz prisma ":"YARN prisma ").replaceAll("BUN ",t.isBunAvailable?"bun --bun run ":"YARN ").replaceAll("YARN run ",V?"bun --bun run ":"yarn run ");V&&(n=n.replaceAll("YARN build-ts run","bun --bun run").replaceAll("bun --bun run bun --bun run","bun --bun run").replaceAll("dist/index.js","src/index.ts").replaceAll(/(?:YARN )?vitest run/g,"bun test").replaceAll(/ --color --passWithNoTests(?: --allowOnly)?/g,"")),n=n.trim();const r=ue(n.replaceAll("YARN ",`${G} `)),s=ue(n.replaceAll("YARN playwright ",`${G} playwright `).replaceAll("YARN ",!V&&t.binExists?"":`${G} `)),o=t.env.WB_ENV?` -c=${t.env.WB_ENV||"development"}`:"";return{printable:`${G} dotenv${o} -- ${r}`,runnable:s}}function ce(e,t,n="Start",r=!1){console.info("\n"+(r?d.gray:d.cyan)(d.bold(`${n}:`),e)+d.gray(` at ${t.dirPath}`))}function de(e,t,n){0===t?console.info(d.green(d.bold("Finished:"),e)):(console.info(d.red(d.bold(`Failed (exit code ${t}): `),e)),!1!==n.exitIfFailed&&process.exit(t??1))}function le(e,t){const n={...e};return t.ci&&(n.CI="1"),t.forceColor&&(n.FORCE_COLOR="3"),n}function ue(e){return e.includes("next dev")||e.includes("playwright")||e.includes("prisma")||e.includes("test/e2e-additional")?e.replaceAll("bun --bun","bun"):e}const pe=new Set(["cjs","cts","js","json","jsonc","jsx","mjs","mts","ts","tsx"]),fe=new Set(["cjs","cts","htm","html","js","json","jsonc","jsx","md","mjs","mts","scss","ts","tsx","vue","yaml","yml"]),me=new Set([...fe].filter(e=>!pe.has(e))),he={command:"lint [files...]",describe:"Lint code on Bun",builder:{fix:{description:"Fix the linting errors",type:"boolean"},format:{description:"Format the code",type:"boolean"}},async handler(e){V||(console.error(d.red("This command is only available on Bun.")),process.exit(1));const n=await M(e,!1);n||(console.error(d.red("No project found.")),process.exit(1));const r=e.files??[];let s,o,i;if(r.length>0){const e=[],n=[],a=[];for(const s of r){const r=t.resolve(String(s));if(r.endsWith("/test/fixtures")||r.includes("/test/fixtures/")||r.endsWith("/test-fixtures")||r.includes("/test-fixtures/"))continue;const o=t.extname(r).slice(1);r.endsWith("/package.json")?a.push(r):pe.has(o)?e.push(r):fe.has(o)&&n.push(r)}s=e.map(e=>`"${e}"`).join(" "),o=n.map(e=>`"${e}"`).join(" "),i=a.map(e=>`"${e}"`).join(" ")}else s="",o=`"**/{.*/,}*.{${[...me].join(",")}}" "!**/test{-,/}fixtures/**"`,i=n.descendants.map(e=>`"${e.packageJsonPath}"`).join(" ");const a=e.fix&&e.format?"check --fix":e.fix?"lint --fix":e.format?"format --fix":"lint";let c;(s||0===r.length)&&(c=ie(`bun --bun biome ${a} --colors=force --no-errors-on-unmatched --files-ignore-unknown=true ${s}`,n.self,e,{forceColor:!0})),e.format&&(o&&ie(`bun --bun prettier --cache --color --no-error-on-unmatched-pattern --write ${o}`,n.self,e,{forceColor:!0}),i&&(await c,ie(`bun --bun sort-package-json ${i}`,n.self,e,{forceColor:!0})))}};function*ge(e,t){for(const n of t)console.info(`Running "${e}" for ${n.name} ...`),yield n}const be={command:"optimizeForDockerBuild",describe:"Optimize configuration when building a Docker image",builder:{outside:{description:"Whether the optimization is executed outside a docker container or not",type:"boolean",alias:"o"}},async handler(n){const r=await M(n);r||(console.error(d.red("No project found.")),process.exit(1));for(const s of ge("optimizeForDockerBuild",r.descendants)){const r=s.packageJson,o=["dependencies","devDependencies"];for(const e of o){const t=r[e]??{};for(const[e,n]of Object.entries(t))n?.startsWith("git@github.com:")&&(t[e]=`./${e}`)}if(ve(n,r),ye(r),we(r),n.dryRun)continue;const i=n.outside?t.join(s.dirPath,"dist"):s.dirPath;await e.promises.mkdir(i,{recursive:!0}),await e.promises.writeFile(t.join(i,"package.json"),JSON.stringify(r),"utf8")}n.dryRun||n.outside||(o.spawnSync(K,["install"],{stdio:"inherit"}),console.info("Installed dependencies."))}};function ve(e,t){if(!e.outside)return delete t.devDependencies,void console.info("Removed all devDependencies.");const n=t.devDependencies??{},r=["artillery","biome","concurrently","conventional-changelog-conventionalcommits","eslint","husky","imagemin","jest","kill-port","lint-staged","open-cli","playwright","prettier","pinst","railway","semantic-release","sort-package-json","wait-on","vitest"],s=[];for(const e of Object.keys(n))(r.some(t=>e.includes(t))||e.includes("willbooster")&&e.includes("config"))&&(delete n[e],s.push(e));console.info("Removed devDependencies:",s.join(", ")||"none")}function ye(e){const t=["check","deploy","format","lint","start","test"],n=["pinst ","husky "],r=e.scripts??{},s=[];for(const[e,o]of Object.entries(r))(t.some(t=>e.startsWith(t))||n.some(e=>o.includes(e)||o.trim()===e.trim()))&&(delete r[e],s.push(e));console.info("Removed scripts:",s.join(", ")||"none")}function we(e){delete e.private,delete e.publishConfig,delete e.prettier}function ke(e){return e.packageJson.dependencies?.blitz?"db/mount":"prisma/mount"}const Ee=new class{cleanUpLitestream(e){const t=ke(e);return`rm -Rf ${t}/prod.sqlite3-*; rm -Rf ${t}/prod.sqlite3.*; rm -Rf ${t}/.prod.sqlite3* || true`}deploy(e,t=""){return`PRISMA migrate deploy ${t}`}deployForce(e){const t=ke(e);return`rm -Rf ${t}/prod.sqlite3*; PRISMA migrate reset --force --skip-seed && rm -Rf ${t}/prod.sqlite3*\n && litestream restore -config litestream.yml -o ${t}/prod.sqlite3 ${t}/prod.sqlite3 && ls -ahl ${t}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`}listBackups(e){return`litestream ltx -config litestream.yml ${ke(e)}/prod.sqlite3`}migrate(e,t=""){return`PRISMA migrate deploy ${t} && PRISMA generate && ${this.seed(e)}`}migrateDev(e,t=""){return`PRISMA migrate dev ${t}`}reset(e,t=""){return e.packageJson.dependencies?.blitz?`PRISMA migrate reset --force ${t} && ${this.seed(e)}`:`PRISMA migrate reset --force ${t}`}restore(e,t){return`rm -Rf ${t}*; litestream restore -config litestream.yml -o ${t} ${ke(e)}/prod.sqlite3`}seed(e,t){return e.packageJson.dependencies?.blitz?"YARN blitz db seed"+(t?` -f ${t}`:""):t?`BUN build-ts run ${t}`:e.packageJson.prisma?.seed?"YARN prisma db seed":'if [ -e "prisma/seeds.ts" ]; then BUN build-ts run prisma/seeds.ts; fi'}studio(n,r,s=""){const o="file:";let i="";if(r)try{new URL(r),i=`DATABASE_URL=${r} `}catch{i=`DATABASE_URL=${o}${t.resolve(r)} `}else if(n.env.DATABASE_URL?.startsWith(o)){const r=[{schemaPath:t.join("prisma","schema.prisma"),dbPath:"prisma"},{schemaPath:t.join("prisma","schema"),dbPath:t.join("prisma","schema")},{schemaPath:t.join("db","schema.prisma"),dbPath:"db"}];for(const{dbPath:s,schemaPath:a}of r)if(e.existsSync(t.resolve(n.dirPath,a))){i=`DATABASE_URL=${o}${t.resolve(n.dirPath,s,n.env.DATABASE_URL.slice(5))} `;break}}return`${i}PRISMA studio ${s}`}},Ae={env:{description:".env files to be loaded.",type:"array"},"cascade-env":{description:"Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.",type:"string"},"cascade-node-env":{description:'Same with --cascade-env=<NODE_ENV || "development">. Preferred over `auto-cascade-env`.',type:"boolean"},"auto-cascade-env":{description:'Same with --cascade-env=<WB_ENV || NODE_ENV || "development">.',type:"boolean",default:!0},"include-root-env":{description:"Include .env files in root directory if the project is in a monorepo and --env option is not used.",type:"boolean",default:!0},"check-env":{description:"Check whether the keys of the loaded .env files are same with the given .env file.",type:"string",default:".env.example"},verbose:{description:"Whether to show verbose information",type:"boolean",alias:"v"},"working-dir":{description:"A working directory",type:"string",alias:"w"},"dry-run":{description:"Whether to skip actual command execution",type:"boolean",alias:["dry","d"]}},$e={},Pe={command:"prisma",describe:"Run prisma commands",builder:e=>e.command(Re).command(Se).command(xe).command(Ne).command(je).command(De).command(_e).command(Te).command(Oe).command(Ie).command(Ce).command(Be).demandCommand().strict(!1),handler(){}},Re={command:"cleanup-litestream",describe:"Clean up temporal Litestream files",builder:$e,async handler(e){const t=await Fe(e);for(const n of ge("prisma cleanup-litestream",t))await oe(Ee.cleanUpLitestream(n),n,e)}},Se={command:"create-litestream-config",describe:"Create Litestream configuration file",builder:$e,async handler(e){const t=await Fe(e);for(const e of ge("prisma create-litestream-config",t))Le(e)}},xe={command:"deploy",describe:"Apply migration to DB without initializing it",builder:$e,async handler(e){const t=await Fe(e),n=Je(e);for(const r of ge("prisma deploy",t))await oe(Ee.deploy(r,n),r,e)}},Ne={command:"deploy-force",describe:"Force to apply migration to DB utilizing Litestream's backup without initializing it",builder:$e,async handler(e){const t=await Fe(e);for(const n of ge("prisma deploy-force",t))await oe(Ee.deployForce(n),n,e)}},je={command:"list-backups",describe:"List Litestream backups",builder:$e,async handler(e){const t=await Fe(e);for(const n of ge("prisma list-backups",t))await oe(Ee.listBackups(n),n,e)}},De={command:"migrate",describe:"Apply migration to DB with initializing it",builder:$e,async handler(e){const t=await Fe(e),n=Je(e);for(const r of ge("prisma migrate",t))await oe(Ee.migrate(r,n),r,e)}},_e={command:"migrate-dev",describe:"Create a migration file",builder:$e,async handler(e){const t=await Fe(e),n=Je(e);for(const r of ge("prisma migrate-dev",t))await oe(Ee.migrateDev(r,n),r,e)}},Te={command:"reset",describe:"Reset DB",builder:$e,async handler(e){const t=await Fe(e),n=Je(e);for(const r of ge("prisma reset",t))await oe(Ee.reset(r,n),r,e);if("test"!==process.env.WB_ENV){process.env.WB_ENV="test";for(const t of ge("WB_ENV=test prisma reset",await Fe(e)))await oe(Ee.reset(t,n),t,e)}}},Oe={command:"restore",describe:"Restore DB from Litestream's backup",builder:{...$e,output:{description:'Output path of the restored database. Defaults to "<db|prisma>/restored.sqlite3".',type:"string"}},async handler(e){const t=await Fe(e);for(const n of ge("prisma restore",t)){const t=e.output??(n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3");await oe(Ee.restore(n,t),n,e)}}},Ie={command:"seed",describe:"Populate DB with seed data",builder:{...$e,file:{alias:"f",description:"Path of the seed script.",type:"string"}},async handler(e){const t=await Fe(e);for(const n of ge("prisma seed",t))await oe(Ee.seed(n,e.file),n,e)}},Ce={command:"studio [db-url-or-path]",describe:"Open Prisma Studio",builder:{...$e,"db-url-or-path":{description:"URL or path to the database",type:"string"},restored:{description:"Whether to open the default restored database (<db|prisma>/restored.sqlite3).",type:"boolean"}},async handler(e){if(e.restored&&e.dbUrlOrPath)throw new Error("You cannot specify both --restored and --db-url-or-path.");const t=await Fe(e),n=Je(e,["db-url-or-path","restored"]);for(const r of ge("prisma studio",t)){const t=e.restored?r.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3":e.dbUrlOrPath?.toString();await oe(Ee.studio(r,t,n),r,e)}}},Be={command:"$0 <args..>",describe:"Pass the command and arguments to prisma as is",builder:{args:{type:"array"}},async handler(e){const t=await Fe(e),n=[(e.args?.join(" ")??"").trimEnd(),Je(e,["args"])].filter(Boolean).join(" ");for(const r of ge(`prisma ${n}`,t))await oe(`PRISMA ${n}`,r,e)}};function Le(t){const n=`${t.packageJson.dependencies?.blitz?"db":"prisma"}/mount/prod.sqlite3`,r={CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME:t.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID:t.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY:t.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY},s=Object.entries(r).filter(([,e])=>!e).map(([e])=>e);if(s.length>0)throw new Error(`Missing environment variables for Litestream: ${s.join(", ")}`);const o="staging"===t.env.WB_ENV?"5m":"1h",i=`dbs:\n - path: ${n}\n replica:\n type: s3\n endpoint: https://${r.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n bucket: ${r.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n access-key-id: ${r.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n secret-access-key: ${r.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n snapshot-interval: 24h # Create a backup per day\n retention: 72h # Keep backups for 3 days\n retention-check-interval: ${o}\n sync-interval: 60s\n`,a="/etc/litestream.yml";try{e.writeFileSync(a,i),console.info(`Generated ${a}`)}catch(e){const t=e instanceof Error?e.message:String(e);throw new Error(`Failed to write ${a}: ${t}`)}}async function Fe(e){const t=await M(e);t||(console.error(d.red("No project found.")),process.exit(1));const n=t.descendants.filter(e=>e.packageJson.dependencies?.prisma??e.packageJson.devDependencies?.prisma);return 0===n.length&&(console.error(d.red("No prisma project found.")),process.exit(1)),n}function Je(e,t=[]){const n=[],r=Object.keys(Ae),s=Object.values(Ae).flatMap(e=>"alias"in e?Array.isArray(e.alias)?e.alias:[e.alias]:[]).map(String),o=new Set([...t,...r,...s,"_","$0"]);for(const[t,r]of Object.entries(e))if(!o.has(t)){const s=t.replaceAll(/[A-Z]/g,e=>`-${e.toLowerCase()}`);if(s!==t&&void 0!==e[s])continue;if("boolean"==typeof r&&r)n.push(`--${t}`);else if("string"==typeof r||"number"==typeof r)n.push(`--${t}`,String(r));else if(Array.isArray(r))for(const e of r)n.push(`--${t}`,String(e))}return n.join(" ")}const We={command:"retry [command] [args...]",describe:"Retry the given command until it succeeds",builder:{retry:{description:"A maximum retry count",type:"number",alias:"r",default:3}},async handler(e){const t=U(e);t||(console.error(d.red("No project found.")),process.exit(1));const n=[e.command,...e.args??[],...e._.slice(1)].filter(Boolean);let r=0;for(let s=0;s<e.retry;s++)if(s>0&&console.info(`\n${d.yellow(`#${s} Retrying: ${n.join(" ")}`)}`),r=await oe(n.join(" "),t,e,{exitIfFailed:!1,onSignal:e=>{e&&process.exit(1)}}),0===r)return;process.exit(r)}},ze={command:"setup",describe:"Setup development environment. .env files are ignored.",builder:{},async handler(e){await async function(e,t){const n=await M(e,!1,t);n||(console.error(d.red("No project found.")),process.exit(1));for(const t of ge("setup",n.descendants)){const r=await h.readdir(t.dirPath,{withFileTypes:!0});if(t===n.root){if("darwin"===g.platform()){const n=["pstree"];await ie(`brew install ${n.join(" ")}`,t,e)}r.some(e=>e.isFile()&&e.name.includes("-version"))&&await oe("asdf install",t,e,{exitIfFailed:!1})}if(r.some(e=>e.isFile()&&"pyproject.toml"===e.name)){await ie("poetry config virtualenvs.in-project true",t,e);const[,n]=o.execSync("asdf current python").toString().trim().split(/\s+/);await ie(`poetry env use ${n}`,t,e),await re.promiseAll(),await oe("poetry run pip install --upgrade pip",t,e),await oe("poetry install --ansi",t,e)}t!==n.root&&n.root.packageJson.scripts?.["gen-code"]||!t.packageJson.scripts?.["gen-code"]||await oe(`${G} gen-code`,t,e)}const r=n.descendants.find(e=>e.packageJson.devDependencies?.playwright);r&&await oe(`${G} playwright install --with-deps`,r,e)}(e)}};function Ue(e){return e.silent?" > /dev/null":""}const Me=new Set;async function Ye(e,t){const n=await async function(e){for(const t of["127.0.0.1","::"]){if(!await Ke(t,e))return!1}return!0}(e);n||await Ve(e,t);const r=async()=>{Me.has(e)||(Me.add(e),await Ve(e,t))};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,r)}async function Ve(e,t){await async function(e,t){await async function(e,t){try{const n=await async function(e,t){const{stdout:n}=await w("docker",["ps","-q",...e],{cwd:t.dirPath,env:t.env});return n.split(/\s+/).map(e=>e.trim()).filter(Boolean)}(e,t);if(0===n.length)return;await w("docker",["rm","-f",...n],{cwd:t.dirPath,env:t.env})}catch{}}(["--filter",`publish=${e}`],t)}(e,t);try{await f(e)}catch{}}async function qe(e,t){const n=Number(e);if(!n)throw new Error(`The given port (${n}) is invalid.`);return await Ye(n,t),n}async function Ke(e,t){return new Promise(n=>{const r=b();r.once("error",e=>{"EADDRINUSE"!==e.code?"EAFNOSUPPORT"!==e.code?n(!1):n(!0):n(!1)}),r.once("listening",()=>{r.close(()=>{n(!0)})}),r.listen(t,e)})}const Ge=new class{buildImage(e,n){const r=e.dockerPackageJson.scripts?.["docker/build/prepare"]?"YARN run docker/build/prepare && ":"";return`cd ${t.dirname(e.findFile("Dockerfile"))}\n && ${r}YARN wb optimizeForDockerBuild --outside\n && YARN wb retry -- docker build -t ${e.dockerImageName}\n --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n --build-arg WB_ENV=${e.env.WB_ENV}\n --build-arg WB_VERSION=${n} .`}stopAndStart(e,t="",n=""){return`${this.stop(e)} && ${this.start(e,t,n)}`}start(e,t="",n=""){!function(e,t){const n=()=>{if(Me.has(e))return;Me.add(e),ce(e,t);const{status:n}=a(e,{cwd:t.dirPath,shell:!0,stdio:"inherit"});de(e,n,{})};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,n)}(this.stop(e),e);return`docker run --rm ${n.includes("/bin/bash")?"-it ":""}--publish ${e.env.PORT}:8080 --name ${e.dockerImageName} ${t} ${e.dockerImageName} ${n}`}stop(e){return`true $(docker rm -f $(docker container ls -q -f name=${e.dockerImageName}) 2> /dev/null)`}stopAll(){return"true $(docker rm -f $(docker ps -q) 2> /dev/null)"}};class He{constructor(e){this.shouldWaitAndOpenApp=e}buildDocker(e,t){return Ge.buildImage(e,t)}async startDev(e,t){return await qe(e.env.PORT,e),this.shouldWaitAndOpenApp?`YARN concurrently --raw --kill-others-on-fail\n "${this.startDevProtected(e,t)}"\n "${this.waitAndOpenApp(e)}"`:this.startDevProtected(e,t)}async startProduction(e,t){return await qe(e.env.PORT,e),this.shouldWaitAndOpenApp?`YARN concurrently --raw --kill-others-on-fail\n "${this.startProductionProtected(e,t)}"\n "${this.waitAndOpenApp(e)}"`:this.startProductionProtected(e,t)}async startTest(e,t){return await qe(e.env.PORT,e),this.startProductionProtected(e,t)}async startDocker(e,t){return await qe(e.env.PORT,e),this.shouldWaitAndOpenApp?`${this.buildDocker(e,"development")}\n && YARN concurrently --raw --kill-others-on-fail\n "${Ge.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}"\n "${this.waitAndOpenApp(e)}"`:`${this.buildDocker(e,"development")}\n && ${Ge.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProductionProtected(e,t){const n=function(e){try{return e.findFile("ecosystem.config.cjs")}catch{return}}(e),r=void 0===n?[("YARN wb buildIfNeeded "+(t.verbose?"--verbose":"")).trim(),`node dist/index.js ${t.normalizedArgsText??""}`.trim()]:[e.buildCommand,`pm2-runtime start --no-autorestart ${n}`];return[...e.hasPrisma?Ee.migrate(e).split("&&"):[],...r].filter(Boolean).map(e=>`${e} ${Ue(t)}`.trim()).join(" && ")}testE2EDev(e,t,n){return this.testE2EProtected(e,t,this.startDevProtected(e,t),n)}testE2EProduction(e,t,n){return this.testE2EProtected(e,t,this.startProductionProtected(e,t),n)}testE2EDocker(e,t,n){return this.testE2EProtected(e,t,Ge.stopAndStart(e),n)}async testStart(e,t){return await qe(e.env.PORT,e),`NODE_ENV="" YARN concurrently --kill-others --raw --success first "${this.startDevProtected(e,t)}" "${this.waitApp(e)}"`}async testE2EProtected(e,t,n,{playwrightArgs:r="test test/e2e/"}){const s=await qe(e.env.PORT,e),o=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"",i=function(e,t){const n="BUN playwright",r=t?.join(" ")||"test/e2e/";if(!e.startsWith("test ")||!t?.length)return`${n} ${e}`;const s=e.slice(5).trim(),o=s.length>0?s.split(/\s+/):[];!o[0]||o[0].startsWith("-")?o.unshift(r):o[0]=r;return`${n} test ${o.join(" ")}`}(r,t.targets);return e.skipLaunchingServerForPlaywright?`${i}${o}`:`YARN concurrently --kill-others --raw --success first\n "${n} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:${s}\n && ${i}${o}"`}testUnit(e,t){const n=t.targets?.join(" ")||"test/unit/";return e.hasVitest?`YARN vitest run ${n} --color --passWithNoTests --allowOnly`:e.isBunAvailable?`bun test ${n}`:'echo "No tests."'}waitApp(e){const t=e.env.PORT;return`wait-on -t 10000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 500 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${t} 2> /dev/null\n || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${t}`}waitAndOpenApp(e){const t=e.env.PORT;return`${this.waitApp(e)} || wait-on http-get://127.0.0.1:${t} && open-cli http://\${HOST:-localhost}:${t}`}}const Qe=new class extends He{constructor(){super(!0)}startDevProtected(e,t){return`blitz dev ${t.normalizedArgsText??""}`}};const Xe=new class extends He{constructor(){super(!1)}startDevProtected(e,t){return`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`}async testE2EProtected(e,t,n){const r=await qe(e.env.PORT,e),s=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"";return`YARN concurrently --kill-others --raw --success first\n "${n} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:${r}\n && vitest run ${t.targets&&t.targets.length>0?t.targets.join(" "):"test/e2e/"} --color --passWithNoTests --allowOnly${s}"`}};const Ze=new class extends He{constructor(){super(!0)}startDevProtected(e,t){return`next dev --turbopack ${t.normalizedArgsText??""}`}};const et=new class extends He{constructor(){super(!1)}startDevProtected(e,t){throw new Error("This method should not be called.")}startDev(e,t){return Promise.resolve(`YARN build-ts run ${t.watch?"--watch":""} src/index.ts -- ${t.normalizedArgsText??""}`)}startProduction(e,t){return Promise.resolve(`${e.buildCommand} && ${q} dist/index.js ${t.normalizedArgsText??""} | tee server.log`)}startTest(){return Promise.resolve("echo 'do nothing.'")}startDocker(e,t){return Promise.resolve(`${this.buildDocker(e,"development")} && ${Ge.stopAndStart(e,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`)}testE2EDev(){return Promise.resolve("echo 'do nothing.'")}testE2EProduction(){return Promise.resolve("echo 'do nothing.'")}testE2EDocker(){return Promise.resolve("echo 'do nothing.'")}testStart(){return Promise.resolve("echo 'do nothing.'")}};const tt=new class extends He{constructor(){super(!0)}startDevProtected(e,t){return`remix dev ${t.normalizedArgsText??""}`}},nt=["express","fastify","elysia","hono"],rt={command:"start [args..]",describe:"Start app",builder:{watch:{description:"Whether to watch files",type:"boolean"},args:{description:"Arguments for core command",type:"array",alias:"a",default:[]},"docker-options":{description:'Arguments for "docker run"',type:"array",default:[]},mode:{description:"Start mode: dev[elopment] (default) | staging | docker | docker-debug | test",type:"string",alias:"m"}},async handler(e){!function(e){e.normalizedArgsText=[...e.args??[],...e._?.slice(1)??[]].map(e=>`'${e}'`).join(" "),e.normalizedDockerOptionsText=(e.dockerOptions??[]).map(e=>`'${e}'`).join(" ")}(e);const t=await M(e);t||(console.error(d.red("No project found.")),process.exit(1));for(const n of t.descendants){const t=n.packageJson.dependencies??{},r=n.packageJson.devDependencies??{};let s;if(t.blitz)s=Qe;else if(t.next)s=Ze;else if(r["@remix-run/dev"])s=tt;else if(nt.some(e=>t[e])&&!t["firebase-functions"]||n.hasDockerfile&&/EXPOSE\s+8080/.test(n.dockerfile))s=Xe;else{if(!t["build-ts"]&&!r["build-ts"])continue;s=et}switch(console.info(`Running "start" for ${n.name} ...`),e.mode??"dev"){case"dev":case"development":process.env.WB_ENV||="development",await oe(await s.startDev(n,e),n,e);break;case"staging":process.env.WB_ENV||="staging",await oe(await s.startProduction(n,e),n,e);break;case"docker":process.env.WB_ENV||="staging",await oe(await s.startDocker(n,e),n,e);break;case"docker-debug":process.env.WB_ENV||="staging",e.normalizedArgsText="'/bin/bash'",await oe(await s.startDocker(n,e),n,e);break;case"test":{process.env.WB_ENV||="test";const t=await s.startTest(n,e);await oe(t,n,e);break}default:throw new Error(`Unknown start mode: ${e.mode}`)}}}},st={command:"test [targets...]",describe:"Test project. If you pass no arguments, it will run all tests.",builder:{e2e:{description:"E2e test mode: headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace",type:"string",choices:["headless","headless-dev","headed","headed-dev","docker","docker-debug","debug","generate","trace"],default:"headless"},silent:{description:"Reduce redundant outputs",type:"boolean"},"unit-timeout":{description:"Timeout for unit tests",type:"number"},targets:{description:"Test target paths",type:"array"}},async handler(n){await async function(n){const r=await M(n);r||(console.error(d.red("No project found.")),process.exit(1));r.descendants.length>1&&(process.env.CI="1");process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";const s=n.targets??[],o=0===s.length,i=s.some(e=>e.includes("/e2e")),a=s.some(e=>e.includes("/unit")),c=o||a,l=o||i;for(const o of r.descendants){const r=o.packageJson.dependencies??{},i=o.packageJson.devDependencies??{};let a;if(a=r.blitz?Qe:r.next?Ze:i["@remix-run/dev"]?tt:nt.some(e=>r[e])&&!r["firebase-functions"]?Xe:et,console.info(`Running "test" for ${o.name} ...`),c&&e.existsSync(t.join(o.dirPath,"test","unit"))){const e=s.filter(e=>e.includes("/unit")),t={...n,targets:e.length>0?e:void 0};await oe(a.testUnit(o,t),o,n,{timeout:n.unitTimeout})}if(!l||!e.existsSync(t.join(o.dirPath,"test","e2e")))continue;const d=s.filter(e=>e.includes("/e2e")),u={...n,targets:d.length>0?d:void 0};switch(n.e2e){case"headless":await oe(await a.testE2EProduction(o,u,{}),o,n);continue;case"headless-dev":await oe(await a.testE2EDev(o,u,{}),o,n);continue;case"docker":await ot(o,u,a);continue;case"docker-debug":{const e=d.length>0?d.join(" "):"test/e2e/";await ot(o,u,a,`test ${e} --debug`);continue}}if(r.blitz||r.next||i["@remix-run/dev"]){const e=d.length>0?d.join(" "):"test/e2e/";switch(n.e2e){case"headed":await oe(await a.testE2EProduction(o,u,{playwrightArgs:`test ${e} --headed`}),o,n);break;case"headed-dev":await oe(await a.testE2EDev(o,u,{playwrightArgs:`test ${e} --headed`}),o,n);break;case"debug":await oe(await a.testE2EProduction(o,u,{playwrightArgs:`test ${e} --debug`}),o,n);break;case"generate":await oe(await a.testE2EProduction(o,u,{playwrightArgs:`codegen http://localhost:${o.env.PORT}`}),o,n);break;case"trace":await oe("BUN playwright show-trace",o,n)}}}}(n)}};async function ot(e,t,n,r){e.env.WB_DOCKER||="1",await oe(`${n.buildDocker(e,"test")}${Ue(t)}`,e,t),process.exitCode=await oe(await n.testE2EDocker(e,t,{playwrightArgs:r}),e,t,{exitIfFailed:!1}),await oe(Ge.stop(e),e,t)}const it={command:"test-on-ci",describe:"Test project on CI with no options.",builder:{silent:{description:"Reduce redundant outputs",type:"boolean"}},async handler(n){await async function(n){const r=await M(n);r||(console.error(d.red("No project found.")),process.exit(1));process.env.CI||="1",process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";for(const s of r.descendants){const r=s.packageJson.dependencies??{},o=s.packageJson.devDependencies??{};let i;if(i=r.blitz?Qe:r.next?Ze:o["@remix-run/dev"]?tt:nt.some(e=>r[e])&&!r["firebase-functions"]?Xe:et,console.info(`Running "test-on-ci" for ${s.name} ...`),await ie(Ge.stopAll(),s,n),e.existsSync(t.join(s.dirPath,"test","unit"))&&await ie(i.testUnit(s,n).replaceAll(" --allowOnly",""),s,n),await ie(await i.testStart(s,n),s,n),await re.promiseAll(),e.existsSync(t.join(s.dirPath,"test","e2e"))){s.hasDockerfile&&(s.env.WB_DOCKER||="1",await oe(`${i.buildDocker(s,"test")}${Ue(n)}`,s,n));const e=s.hasDockerfile?await i.testE2EDocker(s,n,{}):await i.testE2EProduction(s,n,{});process.exitCode=await oe(e.replaceAll(" --allowOnly",""),s,n,{exitIfFailed:!1}),await oe(Ge.stop(s),s,n)}}}(n)}};const at={command:"typecheck",describe:"Run type checking. .env files are ignored.",builder:{},async handler(n){const r=await M(n,!1);r||(console.error(d.red("No project found.")),process.exit(1));let s=!1;const o=r.descendants.map(async o=>{const i=[];for(o.packageJson.workspaces?o.hasSourceCode&&(o.packageJson.dependencies?.typescript||o.packageJson.devDependencies?.typescript)&&i.push("BUN tsc --noEmit --Pretty"):((o.packageJson.dependencies?.typescript||o.packageJson.devDependencies?.typescript)&&i.push("BUN tsc --noEmit --Pretty"),o.packageJson.devDependencies?.pyright&&i.push("YARN pyright"));i.length>0;){const a=await ie(i.join(" && "),o,n,{ci:r.descendants.length>1,exitIfFailed:!1,forceColor:!0}),c=t.join(o.dirPath,".next");if(!a||!e.existsSync(c))return a;e.rmSync(c,{force:!0,recursive:!0}),console.info(d.yellow("Removed `.next` directory. We will re-try type checking.")),s=!0}}),i=await Promise.all(o);let a=0;for(const[e,t]of i.entries())if(t){(r.descendants[e]?.packageJson.dependencies??{}).blitz&&console.info(d.yellow('Please try "yarn gen-code" if you face unknown type errors.')),a=t}a||console.info(d.green(s?"-----\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.":"No type errors found.")),process.exit(a)}},ct={...at,command:"tc"};await r(s(process.argv)).scriptName("wb").options(Ae).middleware(e=>{const n=e["working-dir"];if(n){const e=t.resolve(n);process.chdir(e)}!function(e){e.PATH&&e.BERRY_BIN_FOLDER&&(e.PATH=e.PATH.replace(`${e.BERRY_BIN_FOLDER}:`,"").replaceAll(/\/private\/var\/folders\/[^:]+:/g,"").replaceAll(/\/var\/tmp\/[^:]+:/g,"").replaceAll(/\/tmp\/[^:]+:/g,""));for(const t of Object.keys(e)){const n=t.toUpperCase();(n.startsWith("NPM_")||n.startsWith("YARN_")||n.startsWith("BERRY_")||"PROJECT_CWD"===n||"INIT_CWD"===n)&&delete e[t]}}(process.env)}).command(H).command(ne).command(he).command(be).command(Pe).command(We).command(ze).command(rt).command(st).command(it).command(at).command(ct).demandCommand().strict().version(function(){let n=t.dirname(new URL(import.meta.url).pathname);for(;!e.existsSync(t.join(n,"package.json"));)n=t.dirname(n);return JSON.parse(e.readFileSync(t.join(n,"package.json"),"utf8")).version}()).help().argv;for(const e of["SIGINT","SIGTERM","SIGQUIT"])process.on(e,()=>{n(process.pid),process.exit()});
|
|
10
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","sources":["../../shared-lib-node/src/env.ts","../../shared-lib-node/src/spawn.ts","../../../node_modules/at-decorators/dist/hash.js","../../../node_modules/at-decorators/dist/oson/constructors.js","../../../node_modules/at-decorators/dist/oson/stringify.js","../../../node_modules/at-decorators/dist/getCacheKey.js","../../../node_modules/at-decorators/dist/memoizeOne.js","../src/utils/ci.ts","../src/project.ts","../src/utils/runtime.ts","../src/commands/buildIfNeeded.ts","../../shared-lib/src/error.ts","../src/commands/killPortIfNonCi.ts","../src/utils/promisePool.ts","../src/scripts/run.ts","../src/commands/lint.ts","../src/commands/commandUtils.ts","../src/commands/optimizeForDockerBuild.ts","../src/scripts/prismaScripts.ts","../src/sharedOptionsBuilder.ts","../src/commands/prisma.ts","../src/commands/retry.ts","../src/commands/setup.ts","../src/scripts/builder.ts","../src/utils/process.ts","../src/utils/port.ts","../src/scripts/dockerScripts.ts","../src/scripts/execution/baseScripts.ts","../src/scripts/execution/blitzScripts.ts","../src/scripts/execution/httpServerScripts.ts","../src/scripts/execution/nextScripts.ts","../src/scripts/execution/plainAppScripts.ts","../src/scripts/execution/remixScripts.ts","../src/commands/httpServerPackages.ts","../src/commands/start.ts","../src/commands/test.ts","../src/commands/testOnCi.ts","../src/commands/typecheck.ts","../src/index.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { config } from 'dotenv';\nimport { expand } from 'dotenv-expand';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nexport const yargsOptionsBuilderForEnv = {\n  env: {\n    description: '.env files to be loaded.',\n    type: 'array',\n  },\n  'cascade-env': {\n    description:\n      'Environment to load cascading .env files (e.g., `.env`, `.env.<environment>`, `.env.local` and `.env.<environment>.local`). Preferred over `cascade-node-env` and `auto-cascade-env`.',\n    type: 'string',\n  },\n  'cascade-node-env': {\n    description: 'Same with --cascade-env=<NODE_ENV || \"development\">. Preferred over `auto-cascade-env`.',\n    type: 'boolean',\n  },\n  'auto-cascade-env': {\n    description: 'Same with --cascade-env=<WB_ENV || NODE_ENV || \"development\">.',\n    type: 'boolean',\n    default: true,\n  },\n  'include-root-env': {\n    description: 'Include .env files in root directory if the project is in a monorepo and --env option is not used.',\n    type: 'boolean',\n    default: true,\n  },\n  'check-env': {\n    description: 'Check whether the keys of the loaded .env files are same with the given .env file.',\n    type: 'string',\n    default: '.env.example',\n  },\n  verbose: {\n    description: 'Whether to show verbose information',\n    type: 'boolean',\n    alias: 'v',\n  },\n} as const;\n\nexport type EnvReaderOptions = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof yargsOptionsBuilderForEnv>>>;\n\n/**\n * This function reads environment variables from `.env` files.\n * Note it does not assign them in `process.env`.\n * @return [envVars, [envPaths, envVarCount][]]\n * */\nexport function readEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): [Record<string, string>, [string, number][]] {\n  let envPaths = (argv.env ?? []).map((envPath) => path.resolve(cwd, envPath.toString()));\n  const cascade =\n    argv.cascadeEnv ??\n    (argv.cascadeNodeEnv\n      ? process.env.NODE_ENV || 'development'\n      : argv.autoCascadeEnv\n        ? process.env.WB_ENV || process.env.NODE_ENV || 'development'\n        : undefined);\n  if (typeof cascade === 'string') {\n    if (envPaths.length === 0) {\n      envPaths.push(path.join(cwd, '.env'));\n      if (argv.includeRootEnv) {\n        const rootPath = path.resolve(cwd, '..', '..');\n        if (fs.existsSync(path.join(rootPath, 'package.json'))) {\n          envPaths.push(path.join(rootPath, '.env'));\n        }\n      }\n    }\n    envPaths = envPaths.flatMap((envPath) =>\n      cascade\n        ? [`${envPath}.${cascade}.local`, `${envPath}.local`, `${envPath}.${cascade}`, envPath]\n        : [`${envPath}.local`, envPath]\n    );\n  }\n  envPaths = envPaths.filter((envPath) => fs.existsSync(envPath)).map((envPath) => path.relative(cwd, envPath));\n  if (argv.verbose) {\n    console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`);\n    console.info('Reading env files:', envPaths.join(', '));\n  }\n\n  const envPathAndEnvVarCountPairs: [string, number][] = [];\n  const envVars: Record<string, string> = {};\n  for (const envPath of envPaths) {\n    let count = 0;\n    for (const [key, value] of Object.entries(readEnvFile(path.join(cwd, envPath)))) {\n      if (!(key in envVars)) {\n        envVars[key] = value;\n        count++;\n      }\n    }\n    envPathAndEnvVarCountPairs.push([envPath, count]);\n    if (argv.verbose && count > 0) {\n      console.info(`Read ${count} environment variables from ${envPath}`);\n    }\n  }\n\n  if (argv.checkEnv) {\n    const exampleKeys = Object.keys(readEnvFile(path.join(cwd, argv.checkEnv)));\n    const missingKeys = exampleKeys.filter((key) => !(key in envVars));\n    if (missingKeys.length > 0) {\n      throw new Error(`Missing environment variables in [${envPaths.join(', ')}]: [${missingKeys.join(', ')}]`);\n    }\n  }\n  return [expand({ parsed: envVars, processEnv: {} }).parsed ?? envVars, envPathAndEnvVarCountPairs];\n}\n\n/**\n * This function read environment variables from `.env` files and assign them in `process.env`.\n * */\nexport function readAndApplyEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string\n): Record<string, string | undefined> {\n  const [envVars] = readEnvironmentVariables(argv, cwd);\n  Object.assign(process.env, envVars);\n  return envVars;\n}\n\nconst cachedEnvVars = new Map<string, Record<string, string>>();\n\nfunction readEnvFile(filePath: string): Record<string, string> {\n  const cached = cachedEnvVars.get(filePath);\n  if (cached) return cached;\n\n  const parsed = config({ path: path.resolve(filePath), processEnv: {} }).parsed ?? {};\n  cachedEnvVars.set(filePath, parsed);\n  return parsed;\n}\n\n/**\n * This function removes environment variables related to npm and yarn from the given environment variables.\n * */\nexport function removeNpmAndYarnEnvironmentVariables(envVars: Record<string, string | undefined>): void {\n  // Remove npm & yarn environment variables from process.env\n  if (envVars.PATH && envVars.BERRY_BIN_FOLDER) {\n    envVars.PATH = envVars.PATH.replace(`${envVars.BERRY_BIN_FOLDER}:`, '')\n      // Temporary directory in macOS\n      .replaceAll(/\\/private\\/var\\/folders\\/[^:]+:/g, '')\n      // Temporary directories in Linux\n      .replaceAll(/\\/var\\/tmp\\/[^:]+:/g, '')\n      .replaceAll(/\\/tmp\\/[^:]+:/g, '');\n  }\n  for (const key of Object.keys(envVars)) {\n    const upperKey = key.toUpperCase();\n    if (\n      upperKey.startsWith('NPM_') ||\n      upperKey.startsWith('YARN_') ||\n      upperKey.startsWith('BERRY_') ||\n      upperKey === 'PROJECT_CWD' ||\n      upperKey === 'INIT_CWD'\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete envVars[key];\n    }\n  }\n}\n","import type {\n  SpawnOptions,\n  SpawnOptionsWithoutStdio,\n  SpawnOptionsWithStdioTuple,\n  SpawnSyncReturns,\n  StdioNull,\n  StdioPipe,\n} from 'node:child_process';\nimport { spawn } from 'node:child_process';\n\nimport treeKill from 'tree-kill';\n\n/**\n * Return type for spawnAsync function, based on SpawnSyncReturns but without output and error properties\n */\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\n\n/**\n * Options for spawnAsync function, extending various Node.js spawn options with additional functionality\n */\nexport type SpawnAsyncOptions = (\n  | SpawnOptionsWithoutStdio\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioPipe, StdioNull, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioPipe, StdioNull>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioPipe>\n  | SpawnOptionsWithStdioTuple<StdioNull, StdioNull, StdioNull>\n  | SpawnOptions\n) & {\n  /** Input string to write to the spawned process's stdin */\n  input?: string;\n  /** If true, stderr output will be merged into stdout */\n  mergeOutAndError?: boolean;\n  /** If true, the spawned process will be killed when the parent process exits */\n  killOnExit?: boolean;\n  /** If true, enables verbose logging of process operations */\n  verbose?: boolean;\n  /** If true, stdout data will be printed to console as it's received */\n  printingStdout?: boolean;\n  /** If true, stderr data will be printed to console as it's received */\n  printingStderr?: boolean;\n};\n\n/**\n * Spawns a child process asynchronously and returns a promise that resolves with the process results\n *\n * This function provides a Promise-based wrapper around Node.js's spawn function with additional features:\n * - Automatic encoding of stdout/stderr as UTF-8\n * - Option to merge stderr into stdout\n * - Option to automatically kill the process on parent exit\n * - Option to provide input via stdin\n * - Verbose logging capability\n *\n * @param command - The command to run\n * @param args - List of string arguments\n * @param options - Configuration options for the spawned process\n * @returns Promise that resolves with the process results including pid, stdout, stderr, status, and signal\n * @throws Will reject the promise if the process fails to spawn or encounters an error\n *\n * @example\n * ```typescript\n * const result = await spawnAsync('ls', ['-la'], { verbose: true });\n * console.log(result.stdout);\n * ```\n */\nexport async function spawnAsync(\n  command: string,\n  args?: readonly string[],\n  options?: SpawnAsyncOptions\n): Promise<SpawnAsyncReturns> {\n  return new Promise((resolve, reject) => {\n    try {\n      const proc = spawn(command, args ?? [], options ?? {});\n      // `setEncoding` is undefined in Bun\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stdout?.setEncoding?.('utf8');\n      // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n      proc.stderr?.setEncoding?.('utf8');\n\n      let stdout = '';\n      let stderr = '';\n      proc.stdout?.on('data', (data: string) => {\n        stdout += data;\n        if (options?.printingStdout) {\n          process.stdout.write(data);\n        }\n      });\n      proc.stderr?.on('data', (data: string) => {\n        if (options?.mergeOutAndError) {\n          stdout += data;\n        } else {\n          stderr += data;\n        }\n        if (options?.printingStderr) {\n          process.stderr.write(data);\n        }\n      });\n\n      let stopped = false;\n      const stopProcess = (): void => {\n        if (stopped || !proc.pid) return;\n\n        stopped = true;\n        if (options?.verbose) {\n          console.info(`treeKill(${proc.pid})`);\n        }\n        treeKill(proc.pid);\n      };\n      if (options?.killOnExit) {\n        process.on('beforeExit', stopProcess);\n        process.on('SIGINT', stopProcess);\n      }\n\n      proc.on('error', (error) => {\n        process.removeListener('beforeExit', stopProcess);\n        process.removeListener('SIGINT', stopProcess);\n        proc.removeAllListeners('close');\n        reject(error);\n      });\n      proc.on('close', (code: number | null, signal: NodeJS.Signals | null) => {\n        process.removeListener('beforeExit', stopProcess);\n        process.removeListener('SIGINT', stopProcess);\n        if (proc.pid === undefined) {\n          reject(new Error('Process has no pid.'));\n        } else {\n          resolve({\n            pid: proc.pid,\n            stdout,\n            stderr,\n            status: code,\n            signal,\n          });\n        }\n      });\n\n      if (options?.input) {\n        proc.stdin?.write(options.input);\n        proc.stdin?.end();\n      }\n    } catch (error) {\n      // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n      reject(error);\n    }\n  });\n}\n","/**\n * [js-sha3]{@link https://github.com/emn178/js-sha3}\n *\n * @version 0.9.3\n * @author Chen, Yi-Cyuan [emn178@gmail.com]\n * @copyright Chen, Yi-Cyuan 2015-2023\n * @license MIT\n */\nconst t=[...\"0123456789abcdef\"],s=[6,1536,393216,100663296],i=[0,8,16,24],e=[1,0,32898,0,32906,2147483648,2147516416,2147483648,32907,0,2147483649,0,2147516545,2147483648,32777,2147483648,138,0,136,0,2147516425,0,2147483658,0,2147516555,0,139,2147483648,32905,2147483648,32771,2147483648,32770,2147483648,128,2147483648,32778,0,2147483658,2147483648,2147516545,2147483648,32896,2147483648,2147483649,0,2147516424,2147483648];function o(t){return new h(512,s,512).update(t).hex()}const n=t=>{const s=[];for(const[i,e]of t.entries())s[i]=e;return s};class h{blocks=[];s=[];reset=!0;finalized=!1;block=0;start=0;lastByteIndex=0;constructor(t,s,i){this.padding=s,this.outputBits=i,this.blockCount=1600-(t<<1)>>5,this.byteCount=this.blockCount<<2,this.outputBlocks=i>>5,this.extraBytes=(31&i)>>3;for(let t=0;t<50;++t)this.s[t]=0}update(t){if(this.finalized)throw new Error(\"finalize already called\");const s=this.blocks,e=this.byteCount,o=t.length,n=this.blockCount,h=this.s;let l,c,f=0;for(;f<o;){if(this.reset)for(this.reset=!1,s[0]=this.block,l=1;l<n+1;++l)s[l]=0;for(l=this.start;f<o&&l<e;++f)c=t.codePointAt(f)||0,c<128?s[l>>2]|=c<<i[3&l++]:c<2048?(s[l>>2]|=(192|c>>6)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):c<55296||c>=57344?(s[l>>2]|=(224|c>>12)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]):(c=65536+((1023&c)<<10|1023&(t.codePointAt(++f)||0)),s[l>>2]|=(240|c>>18)<<i[3&l++],s[l>>2]|=(128|c>>12&63)<<i[3&l++],s[l>>2]|=(128|c>>6&63)<<i[3&l++],s[l>>2]|=(128|63&c)<<i[3&l++]);if(this.lastByteIndex=l,l>=e){for(this.start=l-e,this.block=s[n],l=0;l<n;++l)h[l]^=s[l];r(h),this.reset=!0}else this.start=l}return this}finalize(){if(this.finalized)return;this.finalized=!0;const t=this.blocks;let s=this.lastByteIndex;const i=this.blockCount,e=this.s;if(t[s>>2]|=this.padding[3&s],this.lastByteIndex===this.byteCount)for(t[0]=t[i],s=1;s<i+1;++s)t[s]=0;for(t[i-1]|=2147483648,s=0;s<i;++s)e[s]^=t[s];r(e)}hex(){this.finalize();const s=this.blockCount;let i=this.s;const e=this.outputBlocks,o=this.extraBytes;let h,l=0,c=0,f=\"\";for(;c<e;){for(l=0;l<s&&c<e;++l,++c)h=i[l],f+=t[h>>4&15]+t[15&h]+t[h>>12&15]+t[h>>8&15]+t[h>>20&15]+t[h>>16&15]+t[h>>28&15]+t[h>>24&15];c%s===0&&(i=n(i),r(i),l=0)}return o&&(h=i[l],f+=t[h>>4&15]+t[15&h],o>1&&(f+=t[h>>12&15]+t[h>>8&15]),o>2&&(f+=t[h>>20&15]+t[h>>16&15])),f}}const r=function(t){let s,i,o,n,h,r,l,c,f,a,u,d,b,k,y,x,B,p,C,z,I,g,w,A,P,E,j,m,q,v,D,F,G,H,J,K,L,M,N,O,Q,R,S,T,U,V,W,X,Y,Z,$,_,tt,st,it,et,ot,nt,ht,rt,lt,ct,ft;for(o=0;o<48;o+=2)n=t[0]^t[10]^t[20]^t[30]^t[40],h=t[1]^t[11]^t[21]^t[31]^t[41],r=t[2]^t[12]^t[22]^t[32]^t[42],l=t[3]^t[13]^t[23]^t[33]^t[43],c=t[4]^t[14]^t[24]^t[34]^t[44],f=t[5]^t[15]^t[25]^t[35]^t[45],a=t[6]^t[16]^t[26]^t[36]^t[46],u=t[7]^t[17]^t[27]^t[37]^t[47],d=t[8]^t[18]^t[28]^t[38]^t[48],b=t[9]^t[19]^t[29]^t[39]^t[49],s=d^(r<<1|l>>>31),i=b^(l<<1|r>>>31),t[0]^=s,t[1]^=i,t[10]^=s,t[11]^=i,t[20]^=s,t[21]^=i,t[30]^=s,t[31]^=i,t[40]^=s,t[41]^=i,s=n^(c<<1|f>>>31),i=h^(f<<1|c>>>31),t[2]^=s,t[3]^=i,t[12]^=s,t[13]^=i,t[22]^=s,t[23]^=i,t[32]^=s,t[33]^=i,t[42]^=s,t[43]^=i,s=r^(a<<1|u>>>31),i=l^(u<<1|a>>>31),t[4]^=s,t[5]^=i,t[14]^=s,t[15]^=i,t[24]^=s,t[25]^=i,t[34]^=s,t[35]^=i,t[44]^=s,t[45]^=i,s=c^(d<<1|b>>>31),i=f^(b<<1|d>>>31),t[6]^=s,t[7]^=i,t[16]^=s,t[17]^=i,t[26]^=s,t[27]^=i,t[36]^=s,t[37]^=i,t[46]^=s,t[47]^=i,s=a^(n<<1|h>>>31),i=u^(h<<1|n>>>31),t[8]^=s,t[9]^=i,t[18]^=s,t[19]^=i,t[28]^=s,t[29]^=i,t[38]^=s,t[39]^=i,t[48]^=s,t[49]^=i,k=t[0],y=t[1],V=t[11]<<4|t[10]>>>28,W=t[10]<<4|t[11]>>>28,m=t[20]<<3|t[21]>>>29,q=t[21]<<3|t[20]>>>29,rt=t[31]<<9|t[30]>>>23,lt=t[30]<<9|t[31]>>>23,R=t[40]<<18|t[41]>>>14,S=t[41]<<18|t[40]>>>14,H=t[2]<<1|t[3]>>>31,J=t[3]<<1|t[2]>>>31,x=t[13]<<12|t[12]>>>20,B=t[12]<<12|t[13]>>>20,X=t[22]<<10|t[23]>>>22,Y=t[23]<<10|t[22]>>>22,v=t[33]<<13|t[32]>>>19,D=t[32]<<13|t[33]>>>19,ct=t[42]<<2|t[43]>>>30,ft=t[43]<<2|t[42]>>>30,st=t[5]<<30|t[4]>>>2,it=t[4]<<30|t[5]>>>2,K=t[14]<<6|t[15]>>>26,L=t[15]<<6|t[14]>>>26,p=t[25]<<11|t[24]>>>21,C=t[24]<<11|t[25]>>>21,Z=t[34]<<15|t[35]>>>17,$=t[35]<<15|t[34]>>>17,F=t[45]<<29|t[44]>>>3,G=t[44]<<29|t[45]>>>3,A=t[6]<<28|t[7]>>>4,P=t[7]<<28|t[6]>>>4,et=t[17]<<23|t[16]>>>9,ot=t[16]<<23|t[17]>>>9,M=t[26]<<25|t[27]>>>7,N=t[27]<<25|t[26]>>>7,z=t[36]<<21|t[37]>>>11,I=t[37]<<21|t[36]>>>11,_=t[47]<<24|t[46]>>>8,tt=t[46]<<24|t[47]>>>8,T=t[8]<<27|t[9]>>>5,U=t[9]<<27|t[8]>>>5,E=t[18]<<20|t[19]>>>12,j=t[19]<<20|t[18]>>>12,nt=t[29]<<7|t[28]>>>25,ht=t[28]<<7|t[29]>>>25,O=t[38]<<8|t[39]>>>24,Q=t[39]<<8|t[38]>>>24,g=t[48]<<14|t[49]>>>18,w=t[49]<<14|t[48]>>>18,t[0]=k^~x&p,t[1]=y^~B&C,t[10]=A^~E&m,t[11]=P^~j&q,t[20]=H^~K&M,t[21]=J^~L&N,t[30]=T^~V&X,t[31]=U^~W&Y,t[40]=st^~et&nt,t[41]=it^~ot&ht,t[2]=x^~p&z,t[3]=B^~C&I,t[12]=E^~m&v,t[13]=j^~q&D,t[22]=K^~M&O,t[23]=L^~N&Q,t[32]=V^~X&Z,t[33]=W^~Y&$,t[42]=et^~nt&rt,t[43]=ot^~ht&lt,t[4]=p^~z&g,t[5]=C^~I&w,t[14]=m^~v&F,t[15]=q^~D&G,t[24]=M^~O&R,t[25]=N^~Q&S,t[34]=X^~Z&_,t[35]=Y^~$&tt,t[44]=nt^~rt&ct,t[45]=ht^~lt&ft,t[6]=z^~g&k,t[7]=I^~w&y,t[16]=v^~F&A,t[17]=D^~G&P,t[26]=O^~R&H,t[27]=Q^~S&J,t[36]=Z^~_&T,t[37]=$^~tt&U,t[46]=rt^~ct&st,t[47]=lt^~ft&it,t[8]=g^~k&x,t[9]=w^~y&B,t[18]=F^~A&E,t[19]=G^~P&j,t[28]=R^~H&K,t[29]=S^~J&L,t[38]=_^~T&V,t[39]=tt^~U&W,t[48]=ct^~st&et,t[49]=ft^~it&ot,t[0]^=e[o],t[1]^=e[o+1]};export{o as sha3_512};\n//# sourceMappingURL=hash.js.map\n","const e=\"\",t=function(){const e={instance:Error,from:e=>{const t=[e.name,e.message];return void 0!==e.stack&&t.push(e.stack),void 0!==e.cause&&(void 0===e.stack&&t.push(void 0),t.push(e.cause)),t},stub:()=>new Error,hydrate:(e,[t,n,a,s])=>{e.name=t,e.message=n,void 0===a?delete e.stack:e.stack=a,void 0!==s&&(e.cause=s)}},t={instance:Uint8Array,from:e=>[btoa(a.decode(e))],create:([e])=>n.encode(atob(e))},s={instance:Map,from:e=>[...e.entries()],stub:()=>new Map,hydrate:(e,t)=>{for(const[n,a]of t)e.set(n,a)}},o={instance:Set,from:e=>[...e.values()],stub:()=>new Set,hydrate:(e,t)=>{for(const n of t)e.add(n)}},r={instance:Date,from:e=>[e.toJSON()],create:([e])=>new Date(e)},c={instance:RegExp,from:({flags:e,source:t})=>e?[t,e]:[t],create:([e,t])=>new RegExp(e,t)},d={instance:URL,from:e=>[e.href],create:([e])=>new URL(e)};return new Map([e,t,s,o,r,c,d].map(e=>[e.instance.name,e]))}(),n=new TextEncoder,a=new TextDecoder(\"utf-8\");export{t as GLOBAL_CONSTRUCTOR_MAP,e as PLAIN_OBJECT_LABEL};\n//# sourceMappingURL=constructors.js.map\n","import{GLOBAL_CONSTRUCTOR_MAP as t,PLAIN_OBJECT_LABEL as n}from\"./constructors.js\";const e=-1,r=-2,o=-3,i=-4,s=-5,c=-6;function f(n=void 0,e=t){return JSON.stringify(a(n,e))}function u(t){if(void 0===t)return-1;if(\"number\"==typeof t){if(Number.isNaN(t))return-3;if(!Number.isFinite(t))return t<0?-5:-4}return null}const l=[];function a(e,r=t){const o=u(e);if(null!==o)return o;const i=[],s=new Map;return function t(e){const o=u(e);if(null!==o)return o;let c=s.get(e);if(void 0!==c)return c;switch(c=i.length,typeof e){case\"number\":case\"string\":case\"boolean\":i[c]=e,s.set(e,c);break;case\"bigint\":i[c]=[-6,e.toString(16)],s.set(e,c);break;case\"object\":if(null===e)i[c]=e,s.set(e,c);else if(Array.isArray(e)){const n=function(t){if(l.length<t){const n=l.length;l.length=t,l.fill(-2,n,t)}return l.slice(0,t)}(e.length);i[c]=n,s.set(e,c);for(const[r,o]of e.entries())n[r]=t(o)}else{const[o,f]=function(t,e){const r=t.constructor;if(\"function\"==typeof r){const n=r.name,o=e.get(n);if(void 0!==o)return[n,o.from(t)]}const o=Object.entries(t),i=o.length,s=Array.from({length:i+i});for(let t=0;t<i;t++){const n=o[t],e=t+t;s[e]=n[0],s[e+1]=n[1]}return[n,s]}(e,r),u=f.length,l=Array.from({length:u+1});l[0]=o,i[c]=l,s.set(e,c);for(let n=0;n<u;n++)l[n+1]=t(f[n])}}return c}(e),i}export{r as ARRAY_HOLE_INDEX,c as BIG_INT_LABEL,o as NAN_INDEX,s as NEG_INF_INDEX,i as POS_INF_INDEX,e as UNDEFINED_INDEX,a as listify,f as stringify};\n//# sourceMappingURL=stringify.js.map\n","import{sha3_512 as r}from\"./hash.js\";import{stringify as n}from\"./oson/stringify.js\";function o(o,t){return r(n([o,t]))}function t(r,o){return n([r,o])}function i(){return\"\"}export{i as getCacheKeyOfEmptyString,o as getCacheKeyOfHash,t as getCacheKeyOfStringified};\n//# sourceMappingURL=getCacheKey.js.map\n","import{getCacheKeyOfHash as t,getCacheKeyOfEmptyString as e}from\"./getCacheKey.js\";const n=r({getCacheKey:t}),c=r({getCacheKey:e});function r({cacheDuration:e=Number.POSITIVE_INFINITY,getCacheKey:n=t}={}){return function(t,c){let r,o,i;return\"getter\"===c?.kind?function(){const c=n(this,[]),a=Date.now();return(i!==c||a-o>e)&&(i=c,r=t.call(this),o=a),r}:function(...a){const u=n(this,a),h=Date.now();return(i!==u||h-o>e)&&(i=u,r=c?t.call(this,...a):t(...a),o=h),r}}}export{n as memoizeOne,r as memoizeOneFactory,c as memoizeOneWithEmptyHash};\n//# sourceMappingURL=memoizeOne.js.map\n","export function isCI(ciEnv: string | undefined): boolean {\n  return !!ciEnv && ciEnv !== '0' && ciEnv !== 'false';\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport { readEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport { memoizeOne } from 'at-decorators';\nimport { globby } from 'globby';\nimport type { PackageJson } from 'type-fest';\n\nimport { isCI } from './utils/ci.js';\n\nexport class Project {\n  private readonly argv: EnvReaderOptions;\n  private readonly loadEnv: boolean;\n  private readonly pathByName = new Map<string, string>();\n\n  private readonly _dirPath: string;\n\n  constructor(dirPath: string, argv: EnvReaderOptions, loadEnv: boolean) {\n    this._dirPath = path.resolve(dirPath);\n    this.argv = argv;\n    this.loadEnv = loadEnv;\n  }\n\n  @memoizeOne\n  get isBunAvailable(): boolean {\n    try {\n      return /(^|\\n)bun\\s/.test(fs.readFileSync(path.join(this.rootDirPath, '.tool-versions'), 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get buildCommand(): string {\n    return this.packageJson.scripts?.build?.includes('buildIfNeeded')\n      ? 'YARN run build'\n      : this.packageJson.scripts?.build\n        ? `YARN wb buildIfNeeded ${this.argv.verbose ? '--verbose' : ''}`\n        : \"echo 'No build script'\";\n  }\n\n  get dirPath(): string {\n    return this._dirPath;\n  }\n\n  @memoizeOne\n  get rootDirPath(): string {\n    return fs.existsSync(path.join(this.dirPath, '..', '..', 'package.json'))\n      ? path.resolve(this.dirPath, '..', '..')\n      : this.dirPath;\n  }\n\n  @memoizeOne\n  get dockerfile(): string {\n    return fs.readFileSync(this.findFile('Dockerfile'), 'utf8');\n  }\n\n  @memoizeOne\n  get hasDockerfile(): boolean {\n    try {\n      return !!this.findFile('Dockerfile');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get hasSourceCode(): boolean {\n    return fs.existsSync(path.join(this.dirPath, 'src'));\n  }\n\n  @memoizeOne\n  get name(): string {\n    return this.packageJson.name || 'unknown';\n  }\n\n  @memoizeOne\n  get dockerImageName(): string {\n    const name = this.packageJson.name || 'unknown';\n    return name.replaceAll('@', '').replaceAll('/', '-');\n  }\n\n  @memoizeOne\n  get env(): Record<string, string | undefined> {\n    if (!this.loadEnv) return process.env;\n\n    const [envVars, envPathAndLoadedEnvVarCountPairs] = readEnvironmentVariables(this.argv, this.dirPath);\n    for (const [envPath, count] of envPathAndLoadedEnvVarCountPairs) {\n      console.info(`Loaded ${count} environment variables from ${envPath}`);\n    }\n    return { ...envVars, ...process.env };\n  }\n\n  @memoizeOne\n  get packageJson(): PackageJson {\n    return JSON.parse(fs.readFileSync(this.packageJsonPath, 'utf8')) as PackageJson;\n  }\n\n  @memoizeOne\n  get packageJsonPath(): string {\n    return path.join(this.dirPath, 'package.json');\n  }\n\n  @memoizeOne\n  get hasPrisma(): boolean {\n    return !!(this.packageJson.dependencies?.prisma ?? this.packageJson.devDependencies?.prisma);\n  }\n\n  @memoizeOne\n  get hasVitest(): boolean {\n    return !!(this.packageJson.dependencies?.vitest ?? this.packageJson.devDependencies?.vitest);\n  }\n\n  @memoizeOne\n  get skipLaunchingServerForPlaywright(): boolean {\n    if (isCI(this.env.CI)) return false;\n    try {\n      const configPath = this.findFile('playwright.config.ts');\n      return /\\bwebServer\\b/.test(fs.readFileSync(configPath, 'utf8'));\n    } catch {\n      return false;\n    }\n  }\n\n  @memoizeOne\n  get dockerPackageJson(): PackageJson {\n    return path.dirname(this.findFile('Dockerfile')) === this.dirPath\n      ? this.packageJson\n      : (JSON.parse(\n          fs.readFileSync(path.join(path.dirname(this.findFile('Dockerfile')), 'package.json'), 'utf8')\n        ) as PackageJson);\n  }\n\n  @memoizeOne\n  get binExists(): boolean {\n    let binFound = false;\n    let currentPath = this.dirPath;\n    for (;;) {\n      const binPath = path.join(currentPath, 'node_modules', '.bin');\n      if (fs.existsSync(binPath)) {\n        this.env.PATH = `${binPath}:${this.env.PATH}`;\n        binFound = true;\n      }\n\n      if (fs.existsSync(path.join(currentPath, '.git'))) {\n        break;\n      }\n      const parentPath = path.dirname(currentPath);\n      if (currentPath === parentPath) {\n        break;\n      }\n      currentPath = parentPath;\n    }\n    return binFound;\n  }\n\n  findFile(fileName: string): string {\n    let filePath = this.pathByName.get(fileName);\n    if (filePath) return filePath;\n\n    filePath = [fileName, path.join('..', '..', fileName)]\n      .map((p) => path.resolve(this.dirPath, p))\n      .find((p) => fs.existsSync(p));\n    if (!filePath) {\n      throw new Error(`File not found: ${fileName}`);\n    }\n    this.pathByName.set(fileName, filePath);\n    return filePath;\n  }\n}\n\nexport interface FoundProjects {\n  root: Project;\n  self: Project;\n  descendants: Project[];\n}\n\nexport function findSelfProject(argv: EnvReaderOptions, loadEnv = true, dirPath?: string): Project | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  return new Project(dirPath, argv, loadEnv);\n}\n\nexport async function findDescendantProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Promise<FoundProjects | undefined> {\n  const rootAndSelfProjects = findRootAndSelfProjects(argv, loadEnv, dirPath);\n  if (!rootAndSelfProjects) return;\n\n  return {\n    ...rootAndSelfProjects,\n    descendants:\n      rootAndSelfProjects.root === rootAndSelfProjects.self\n        ? await getAllDescendantProjects(argv, rootAndSelfProjects.root, loadEnv)\n        : [rootAndSelfProjects.self],\n  };\n}\n\nexport function findRootAndSelfProjects(\n  argv: EnvReaderOptions,\n  loadEnv = true,\n  dirPath?: string\n): Omit<FoundProjects, 'descendants'> | undefined {\n  dirPath ??= process.cwd();\n  if (!fs.existsSync(path.join(dirPath, 'package.json'))) return;\n\n  const thisProject = new Project(dirPath, argv, loadEnv);\n  let rootProject = thisProject;\n  if (!thisProject.packageJson.workspaces && path.dirname(dirPath).endsWith('/packages')) {\n    const rootDirPath = path.resolve(dirPath, '..', '..');\n    if (fs.existsSync(path.join(rootDirPath, 'package.json'))) {\n      rootProject = new Project(rootDirPath, argv, loadEnv);\n    }\n  }\n  return { root: rootProject, self: thisProject };\n}\n\nasync function getAllDescendantProjects(\n  argv: EnvReaderOptions,\n  rootProject: Project,\n  loadEnv: boolean\n): Promise<Project[]> {\n  const projects = [rootProject];\n\n  const workspace = rootProject.packageJson.workspaces;\n  if (!Array.isArray(workspace)) return projects;\n\n  const globPattern: string[] = [];\n  const packageDirs: string[] = [];\n  for (const workspacePath of workspace.map((ws: string) => path.join(rootProject.dirPath, ws))) {\n    if (fs.existsSync(workspacePath)) {\n      packageDirs.push(workspacePath);\n    } else {\n      globPattern.push(workspacePath);\n    }\n  }\n  packageDirs.push(...(await globby(globPattern, { dot: true, onlyDirectories: true })));\n  for (const subPackageDirPath of packageDirs) {\n    if (!fs.existsSync(path.join(subPackageDirPath, 'package.json'))) continue;\n\n    projects.push(new Project(subPackageDirPath, argv, loadEnv));\n  }\n  return projects;\n}\n","export const isRunningOnBun =\n  // Detect `bun --bun run wb ...`. cf. https://bun.sh/guides/util/detect-bun\n  process.versions.bun ||\n  // Detect `bun run wb ...`.\n  process.argv[0]?.endsWith('/bun') ||\n  process.env.npm_execpath?.endsWith('/bun');\n\nexport const runtimeWithArgs = isRunningOnBun ? 'bun --bun run' : 'node';\nexport const packageManager = isRunningOnBun ? 'bun' : 'yarn';\nexport const packageManagerWithRun = isRunningOnBun ? 'bun --bun run' : 'yarn';\n","import child_process from 'node:child_process';\nimport type { BinaryLike, Hash } from 'node:crypto';\nimport { createHash } from 'node:crypto';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport { ignoreEnoentAsync } from '@willbooster/shared-lib/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isRunningOnBun } from '../utils/runtime.js';\n\nconst builder = {\n  command: {\n    description: 'A build command (default: yarn|bun build)',\n    type: 'string',\n    alias: 'c',\n  },\n} as const;\n\nexport const buildIfNeededCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'buildIfNeeded',\n  describe: 'Build code if changes are detected',\n  builder,\n  async handler(argv) {\n    await buildIfNeeded(argv);\n  },\n};\n\nexport async function buildIfNeeded(\n  // Test code requires Partial<...>\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>>>,\n  projectPathForTesting?: string\n): Promise<boolean | undefined> {\n  const project = findSelfProject(argv, true, projectPathForTesting);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    return true;\n  }\n\n  argv = { ...argv, command: argv.command ?? (isRunningOnBun ? 'bun run build' : 'yarn build') };\n\n  if (!fs.existsSync(path.join(project.rootDirPath, '.git'))) {\n    build(project, argv);\n    return true;\n  }\n\n  const [canSkip, cacheFilePath, contentHash] = await canSkipBuild(project, argv);\n  if (canSkip) {\n    console.info(chalk.green(`Skip to run '${argv.command}' 💫`));\n    return false;\n  }\n\n  if (!build(project, argv)) return;\n\n  if (!argv.dryRun) {\n    await fs.promises.writeFile(cacheFilePath, contentHash, 'utf8');\n  }\n  return true;\n}\n\nfunction build(project: Project, argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>): boolean {\n  console.info(chalk.green(`Run '${argv.command}'`));\n  if (!argv.dryRun) {\n    const ret = child_process.spawnSync(argv.command ?? '', {\n      cwd: project.dirPath,\n      env: project.env,\n      shell: true,\n      stdio: 'inherit',\n    });\n    if (ret.status !== 0) {\n      process.exitCode = ret.status ?? 1;\n      return false;\n    }\n  }\n  return true;\n}\n\nconst ignoringEnvVarNames = new Set(['CI', 'PWDEBUG', 'TMPDIR']);\n\nexport async function canSkipBuild(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>\n): Promise<[boolean, string, string]> {\n  const cacheDirectoryPath = path.resolve(project.dirPath, 'node_modules', '.cache', 'build');\n  const cacheFilePath = path.resolve(cacheDirectoryPath, 'last-build');\n  await fs.promises.mkdir(cacheDirectoryPath, { recursive: true });\n\n  const hash = createHash('sha256');\n\n  const commitHash = child_process.execSync('git rev-parse HEAD', { cwd: project.dirPath }).toString().trim();\n  hash.update(commitHash);\n\n  const environmentJson = JSON.stringify(\n    Object.entries(project.env)\n      .filter(([key]) => !ignoringEnvVarNames.has(key))\n      .toSorted(([key1], [key2]) => key1.localeCompare(key2))\n  );\n  hash.update(environmentJson);\n\n  await updateHashWithDiffResult(project, argv, hash);\n  const contentHash = hash.digest('hex');\n\n  const cachedContentHash = await ignoreEnoentAsync(() => fs.promises.readFile(cacheFilePath, 'utf8'));\n  return [cachedContentHash === contentHash, cacheFilePath, contentHash];\n}\n\nconst includePatterns = ['src/', 'public/'];\nconst includeSuffix = [\n  '.js',\n  '.cjs',\n  '.mjs',\n  '.jsx',\n  '.ts',\n  '.cts',\n  '.mts',\n  '.tsx',\n  '.json',\n  '.browserslistrc',\n  // Because some build commands affected by changes in `package.json`\n  'package.json',\n  'yarn.lock',\n];\nconst excludePatterns = ['test/', 'tests/', '__tests__/', 'test-fixtures/', 'test/fixtures/'];\n\nasync function updateHashWithDiffResult(\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  hash: Hash\n): Promise<void> {\n  return new Promise((resolve) => {\n    const ret = child_process.spawnSync('git', ['status', '--porcelain'], {\n      cwd: project.dirPath,\n      env: project.env,\n      stdio: 'pipe',\n      encoding: 'utf8',\n    });\n    const lines = ret.stdout\n      .trim()\n      .split('\\n')\n      .filter((line) => line.length > 0);\n    const filePaths = lines\n      .map((line) => line.slice(2).trim())\n      .map((filePath) =>\n        project.env.WB_ENV === 'test' ? filePath.replace(/packages\\/wb\\/test\\/fixtures\\/[^/]+\\//, '') : filePath\n      );\n    const filteredFilePaths = filePaths.filter(\n      (filePath) =>\n        (includePatterns.some((pattern) => filePath.includes(pattern)) ||\n          includeSuffix.some((suffix) => filePath.endsWith(suffix))) &&\n        !excludePatterns.some((pattern) => filePath.includes(pattern))\n    );\n    if (argv.verbose) {\n      console.info(`Changed files: ${filteredFilePaths.join(', ')}`);\n    }\n\n    // 'git diff --' works only on rootDirPath\n    const proc = child_process.spawn('git', ['diff', '--', ...filteredFilePaths], { cwd: project.rootDirPath });\n    proc.stdout.on('data', (data: BinaryLike) => {\n      hash.update(data);\n      if (argv.verbose) {\n        console.info('Data:', data);\n        console.info('Hash:', hash.copy().digest('hex'));\n      }\n    });\n    proc.on('close', () => {\n      resolve();\n    });\n  });\n}\n","import { sleep } from './sleep.js';\n\n/**\n * Convert an object to an error.\n * @param obj The object to convert.\n */\nexport function errorify(obj: unknown): Error {\n  if (obj instanceof Error) return obj;\n  if (typeof obj === 'string') return new Error(obj);\n  try {\n    return new Error(JSON.stringify(obj));\n  } catch {\n    return new Error(String(obj));\n  }\n}\n\nexport function ignoreError<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport function ignoreEnoent<T>(fn: () => T): T | undefined {\n  try {\n    return fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport async function ignoreErrorAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function ignoreEnoentAsync<T>(fn: () => Promise<T>): Promise<T | undefined> {\n  try {\n    return await fn();\n  } catch (error) {\n    if (typeof error === 'object' && error && 'code' in error && error.code === 'ENOENT') {\n      return;\n    }\n    throw error;\n  }\n}\n\nexport interface RetryOptions {\n  beforeRetry?: (error: unknown) => Promise<void>;\n  handleError?: (error: unknown) => Promise<void>;\n  retryCount?: number;\n  retryLogger?: (message: string) => void;\n  shouldRetry?: (error: unknown) => boolean;\n  sleepMilliseconds?: number;\n  updateSleepMilliseconds?: (sleepMilliseconds: number) => number;\n}\n\n/**\n * Retry the given function.\n * @param func The function to retry.\n * @param beforeRetry The function to call immediately before retrying.\n * @param handleError The function to call when an error occurs.\n * @param retryCount The maximum number of retries.\n * @param retryLogger The function to log retrying.\n * @param sleepMilliseconds The number of milliseconds to sleep before retrying.\n * @param updateSleepMilliseconds The function to update sleep milliseconds after each retry.\n */\nexport async function withRetry<T>(\n  func: (failedCount: number) => T | Promise<T>,\n  {\n    beforeRetry,\n    handleError,\n    retryCount = 3,\n    retryLogger,\n    shouldRetry,\n    sleepMilliseconds = 0,\n    updateSleepMilliseconds,\n  }: RetryOptions = {}\n): Promise<T> {\n  let failedCount = 0;\n  for (;;) {\n    try {\n      return await func(failedCount);\n    } catch (error) {\n      await handleError?.(error);\n      failedCount++;\n      if (failedCount >= retryCount) {\n        throw error;\n      }\n      if (shouldRetry && !shouldRetry(error)) {\n        throw error;\n      }\n      if (sleepMilliseconds > 0) {\n        await sleep(sleepMilliseconds);\n      }\n      if (updateSleepMilliseconds) {\n        sleepMilliseconds = updateSleepMilliseconds(sleepMilliseconds);\n      }\n      retryLogger?.(`Retry due to: ${error}\n${error instanceof Error ? '---\\n' + (error.stack ?? '') : ''}`);\n      await beforeRetry?.(error);\n    }\n  }\n}\n","import chalk from 'chalk';\nimport killPortProcess from 'kill-port';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isCI } from '../utils/ci.js';\n\nconst killPortIfNonCiBuilder = {} as const;\n\nexport const killPortIfNonCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'kill-port-if-non-ci',\n  describe: 'Kill the port specified by PORT environment variable if non-CI.',\n  builder: killPortIfNonCiBuilder,\n  async handler(argv) {\n    await killPortIfNonCi(argv);\n  },\n};\n\nexport async function killPortIfNonCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof killPortIfNonCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const project = findSelfProject(argv);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  if (isCI(project.env.CI)) {\n    console.info(`Skip killing port due to CI: ${project.env.CI}`);\n    return;\n  }\n\n  const portEnv = project.env.PORT;\n  const port = Number(portEnv);\n  if (!Number.isInteger(port) || port <= 0) {\n    console.error(chalk.red(`PORT environment variable is invalid: ${portEnv}`));\n    process.exit(1);\n  }\n\n  console.info(`Killing the port: ${port}`);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n","import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n","import { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { isRunningOnBun, packageManagerWithRun } from '../utils/runtime.js';\n\ninterface Options {\n  ci?: boolean;\n  exitIfFailed?: boolean;\n  onSignal?: (signal: NodeJS.Signals | null) => void;\n  forceColor?: boolean;\n  timeout?: number;\n}\n\nconst defaultOptions: Options = {\n  exitIfFailed: true,\n};\n\nexport async function runWithSpawn(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<number> {\n  const normalizedScript = normalizeScript(script, project);\n  printStart(normalizedScript.printable, project);\n  if (argv.verbose) {\n    printStart(normalizedScript.runnable, project, 'Start (raw)', true);\n  }\n  if (argv.dryRun) {\n    printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts);\n    return 0;\n  }\n\n  const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n    cwd: project.dirPath,\n    env: configureEnv(project.env, opts),\n    shell: true,\n    stdio: 'inherit',\n    timeout: opts.timeout,\n    killOnExit: true,\n    verbose: argv.verbose,\n  });\n  opts.onSignal?.(ret.signal);\n  printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts);\n  return ret.status ?? 1;\n}\n\nexport function runWithSpawnInParallel(\n  script: string,\n  project: Project,\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof sharedOptionsBuilder>>>,\n  opts: Options = defaultOptions\n): Promise<number> {\n  return promisePool.runAndWaitForReturnValue(async () => {\n    const normalizedScript = normalizeScript(script, project);\n    printStart(normalizedScript.printable, project, 'Start (parallel)', true);\n    if (argv.dryRun) {\n      printStart(normalizedScript.printable, project, 'Started (log)');\n      if (argv.verbose) {\n        printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n      }\n      printFinishedAndExitIfNeeded(normalizedScript.printable, 0, opts);\n      return 0;\n    }\n\n    const ret = await spawnAsync(normalizedScript.runnable, undefined, {\n      cwd: project.dirPath,\n      env: configureEnv(project.env, opts),\n      shell: true,\n      stdio: 'pipe',\n      timeout: opts.timeout,\n      mergeOutAndError: true,\n      killOnExit: true,\n      verbose: argv.verbose,\n    });\n    opts.onSignal?.(ret.signal);\n    printStart(normalizedScript.printable, project, 'Started (log)');\n    if (argv.verbose) {\n      printStart(normalizedScript.runnable, project, 'Started (raw)', true);\n    }\n    const out = ret.stdout.trim();\n    if (out) {\n      process.stdout.write(out);\n      process.stdout.write('\\n');\n    }\n    printFinishedAndExitIfNeeded(normalizedScript.printable, ret.status, opts);\n    return ret.status ?? 1;\n  });\n}\n\n/**\n * Replace capitalized commands (e.g., YARN, PRISMA, BUN) with suitable commands.\n */\nfunction normalizeScript(script: string, project: Project): { printable: string; runnable: string } {\n  let newScript = script\n    .replaceAll('\\n', '')\n    .replaceAll(/\\s\\s+/g, ' ')\n    .replaceAll(\n      'PRISMA generate ',\n      project.packageJson.dependencies?.blitz ? 'PRISMA generate ' : 'PRISMA generate --no-hints '\n    )\n    .replaceAll('PRISMA ', project.packageJson.dependencies?.blitz ? 'YARN blitz prisma ' : 'YARN prisma ')\n    .replaceAll('BUN ', project.isBunAvailable ? 'bun --bun run ' : 'YARN ')\n    // Avoid replacing `YARN run` with `run` by replacing `YARN` with `(yarn|bun --bun) run`\n    .replaceAll('YARN run ', isRunningOnBun ? 'bun --bun run ' : 'yarn run ');\n  if (isRunningOnBun) {\n    newScript = newScript\n      .replaceAll('YARN build-ts run', 'bun --bun run')\n      .replaceAll('bun --bun run bun --bun run', 'bun --bun run')\n      // Because bun can run src/index.ts directly.\n      .replaceAll('dist/index.js', 'src/index.ts')\n      .replaceAll(/(?:YARN )?vitest run/g, 'bun test')\n      // '--allowOnly' is sometimes removed.\n      .replaceAll(/ --color --passWithNoTests(?: --allowOnly)?/g, '');\n  }\n  newScript = newScript.trim();\n  const printableScript = fixBunCommand(newScript.replaceAll('YARN ', `${packageManagerWithRun} `));\n  const runnableScript = fixBunCommand(\n    newScript\n      // Because we need to use `yarn playwright` in a project depending on `artillery-engine-playwright`.\n      .replaceAll('YARN playwright ', `${packageManagerWithRun} playwright `)\n      .replaceAll('YARN ', !isRunningOnBun && project.binExists ? '' : `${packageManagerWithRun} `)\n  );\n  // Add cascade option when WB_ENV is defined\n  const cascadeOption = project.env.WB_ENV ? ` -c=${project.env.WB_ENV || 'development'}` : '';\n  return {\n    printable: `${packageManagerWithRun} dotenv${cascadeOption} -- ${printableScript}`,\n    runnable: runnableScript,\n  };\n}\n\nexport function printStart(normalizedScript: string, project: Project, prefix = 'Start', weak = false): void {\n  console.info(\n    '\\n' +\n      (weak ? chalk.gray : chalk.cyan)(chalk.bold(`${prefix}:`), normalizedScript) +\n      chalk.gray(` at ${project.dirPath}`)\n  );\n}\n\nexport function printFinishedAndExitIfNeeded(\n  script: string,\n  exitCode: number | null,\n  opts: Omit<Options, 'timeout'>\n): void {\n  if (exitCode === 0) {\n    console.info(chalk.green(chalk.bold('Finished:'), script));\n  } else {\n    console.info(chalk.red(chalk.bold(`Failed (exit code ${exitCode}): `), script));\n    if (opts.exitIfFailed !== false) {\n      process.exit(exitCode ?? 1);\n    }\n  }\n}\n\nfunction configureEnv(env: Record<string, string | undefined>, opts: Options): Record<string, string | undefined> {\n  const newEnv = { ...env };\n  if (opts.ci) {\n    newEnv.CI = '1';\n  }\n  if (opts.forceColor) {\n    newEnv.FORCE_COLOR = '3';\n  }\n  return newEnv;\n}\n\nfunction fixBunCommand(command: string): string {\n  // cf. https://github.com/oven-sh/bun/issues/14359\n  return command.includes('next dev') ||\n    // cf. https://github.com/oven-sh/bun/issues/8222\n    command.includes('playwright') ||\n    // \"bun --bun prisma generate\" doesn't work\n    command.includes('prisma') ||\n    command.includes('test/e2e-additional')\n    ? command.replaceAll('bun --bun', 'bun')\n    : command;\n}\n","import path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { isRunningOnBun } from '../utils/runtime.js';\n\nconst builder = {\n  fix: {\n    description: 'Fix the linting errors',\n    type: 'boolean',\n  },\n  format: {\n    description: 'Format the code',\n    type: 'boolean',\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  files: {\n    description: 'File and directory paths to lint',\n    type: 'array',\n  },\n} as const;\n\nconst biomeExtensions = new Set(['cjs', 'cts', 'js', 'json', 'jsonc', 'jsx', 'mjs', 'mts', 'ts', 'tsx']);\nconst prettierExtensions = new Set([\n  'cjs',\n  'cts',\n  'htm',\n  'html',\n  'js',\n  'json',\n  'jsonc',\n  'jsx',\n  'md',\n  'mjs',\n  'mts',\n  'scss',\n  'ts',\n  'tsx',\n  'vue',\n  'yaml',\n  'yml',\n]);\nconst prettierOnlyExtensions = new Set([...prettierExtensions].filter((ext) => !biomeExtensions.has(ext)));\n\nexport const lintCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder>\n> = {\n  command: 'lint [files...]',\n  describe: 'Lint code on Bun',\n  builder,\n  async handler(argv) {\n    if (!isRunningOnBun) {\n      console.error(chalk.red('This command is only available on Bun.'));\n      process.exit(1);\n    }\n\n    const projects = await findDescendantProjects(argv, false);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const files = argv.files ?? [];\n    let biomeArgsText: string;\n    let prettierArgsText: string;\n    let sortPackageJsonArgsText: string;\n    if (files.length > 0) {\n      const filePathsToBeCheckedByBiome: string[] = [];\n      const filePathsToBeFormattedByPrettier: string[] = [];\n      const packageJsonFilePaths: string[] = [];\n      for (const file of files) {\n        const filePath = path.resolve(String(file));\n        if (\n          filePath.endsWith('/test/fixtures') ||\n          filePath.includes('/test/fixtures/') ||\n          filePath.endsWith('/test-fixtures') ||\n          filePath.includes('/test-fixtures/')\n        ) {\n          continue;\n        }\n\n        const extension = path.extname(filePath).slice(1);\n        if (filePath.endsWith('/package.json')) {\n          packageJsonFilePaths.push(filePath);\n        } else if (biomeExtensions.has(extension)) {\n          filePathsToBeCheckedByBiome.push(filePath);\n        } else if (prettierExtensions.has(extension)) {\n          filePathsToBeFormattedByPrettier.push(filePath);\n        }\n      }\n      biomeArgsText = filePathsToBeCheckedByBiome.map((f) => `\"${f}\"`).join(' ');\n      prettierArgsText = filePathsToBeFormattedByPrettier.map((f) => `\"${f}\"`).join(' ');\n      sortPackageJsonArgsText = packageJsonFilePaths.map((f) => `\"${f}\"`).join(' ');\n    } else {\n      biomeArgsText = '';\n      prettierArgsText = `\"**/{.*/,}*.{${[...prettierOnlyExtensions].join(',')}}\" \"!**/test{-,/}fixtures/**\"`;\n      sortPackageJsonArgsText = projects.descendants.map((p) => `\"${p.packageJsonPath}\"`).join(' ');\n    }\n\n    const biomeCommand =\n      argv.fix && argv.format ? 'check --fix' : argv.fix ? 'lint --fix' : argv.format ? 'format --fix' : 'lint';\n    let biomePromise: Promise<number> | undefined;\n    if (biomeArgsText || files.length === 0) {\n      biomePromise = runWithSpawnInParallel(\n        `bun --bun biome ${biomeCommand} --colors=force --no-errors-on-unmatched --files-ignore-unknown=true ${biomeArgsText}`,\n        projects.self,\n        argv,\n        { forceColor: true }\n      );\n    }\n    if (argv.format) {\n      if (prettierArgsText) {\n        void runWithSpawnInParallel(\n          `bun --bun prettier --cache --color --no-error-on-unmatched-pattern --write ${prettierArgsText}`,\n          projects.self,\n          argv,\n          { forceColor: true }\n        );\n      }\n      if (sortPackageJsonArgsText) {\n        await biomePromise;\n        void runWithSpawnInParallel(`bun --bun sort-package-json ${sortPackageJsonArgsText}`, projects.self, argv, {\n          forceColor: true,\n        });\n      }\n    }\n  },\n};\n","import type { Project } from '../project.js';\n\nexport function* prepareForRunningCommand(commandName: string, projects: Project[]): Generator<Project, void, unknown> {\n  for (const project of projects) {\n    console.info(`Running \"${commandName}\" for ${project.name} ...`);\n\n    yield project;\n  }\n}\n","import child_process from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { PackageJson } from 'type-fest';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { packageManager } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {\n  outside: {\n    description: 'Whether the optimization is executed outside a docker container or not',\n    type: 'boolean',\n    alias: 'o',\n  },\n} as const;\n\nexport const optimizeForDockerBuildCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'optimizeForDockerBuild',\n  describe: 'Optimize configuration when building a Docker image',\n  builder,\n  async handler(argv) {\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of prepareForRunningCommand('optimizeForDockerBuild', projects.descendants)) {\n      const packageJson: PackageJson = project.packageJson;\n      const keys = ['dependencies', 'devDependencies'] as const;\n      for (const key of keys) {\n        const deps = packageJson[key] ?? {};\n        for (const [name, value] of Object.entries(deps)) {\n          if (value?.startsWith('git@github.com:')) {\n            deps[name] = `./${name}`;\n          }\n        }\n      }\n\n      optimizeDevDependencies(argv, packageJson);\n\n      optimizeScripts(packageJson);\n\n      optimizeRootProps(packageJson);\n\n      if (argv.dryRun) continue;\n\n      const distDirPath = argv.outside ? path.join(project.dirPath, 'dist') : project.dirPath;\n      await fs.promises.mkdir(distDirPath, { recursive: true });\n      await fs.promises.writeFile(path.join(distDirPath, 'package.json'), JSON.stringify(packageJson), 'utf8');\n    }\n    if (!argv.dryRun && !argv.outside) {\n      child_process.spawnSync(packageManager, ['install'], {\n        stdio: 'inherit',\n      });\n      console.info('Installed dependencies.');\n    }\n  },\n};\n\nfunction optimizeDevDependencies(argv: InferredOptionTypes<typeof builder>, packageJson: PackageJson): void {\n  if (!argv.outside) {\n    delete packageJson.devDependencies;\n    console.info('Removed all devDependencies.');\n    return;\n  }\n\n  const devDeps = packageJson.devDependencies ?? {};\n  const nameWordsToBeRemoved = [\n    'artillery',\n    'biome',\n    'concurrently',\n    'conventional-changelog-conventionalcommits',\n    'eslint',\n    'husky',\n    'imagemin',\n    'jest',\n    'kill-port',\n    'lint-staged',\n    'open-cli',\n    'playwright',\n    'prettier',\n    'pinst',\n    'railway',\n    'semantic-release',\n    'sort-package-json',\n    'wait-on',\n    'vitest',\n  ];\n  const removedDeps: string[] = [];\n  for (const name of Object.keys(devDeps)) {\n    if (\n      nameWordsToBeRemoved.some((word) => name.includes(word)) ||\n      (name.includes('willbooster') && name.includes('config'))\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete devDeps[name];\n      removedDeps.push(name);\n    }\n  }\n  console.info('Removed devDependencies:', removedDeps.join(', ') || 'none');\n}\n\nfunction optimizeScripts(packageJson: PackageJson): void {\n  const nameWordsOfUnnecessaryScripts = ['check', 'deploy', 'format', 'lint', 'start', 'test'];\n  const contentWordsOfUnnecessaryScripts = ['pinst ', 'husky '];\n  const scripts = (packageJson.scripts ?? {}) as Record<string, string>;\n  const removedScripts: string[] = [];\n  for (const [name, content] of Object.entries(scripts)) {\n    if (\n      nameWordsOfUnnecessaryScripts.some((word) => name.startsWith(word)) ||\n      // Support \"husky\" since husky v9 requires `\"postinstall\": \"husky\"`\n      contentWordsOfUnnecessaryScripts.some((word) => content.includes(word) || content.trim() === word.trim())\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-dynamic-delete\n      delete scripts[name];\n      removedScripts.push(name);\n    }\n  }\n  console.info('Removed scripts:', removedScripts.join(', ') || 'none');\n}\n\nfunction optimizeRootProps(packageJson: PackageJson): void {\n  delete packageJson.private;\n  delete packageJson.publishConfig;\n  delete packageJson.prettier;\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport type { Project } from '../project.js';\n\n/**\n * A collection of scripts for executing Prisma commands.\n * Note that `PRISMA` is replaced with `YARN prisma` or `YARN blitz prisma`\n * and `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PrismaScripts {\n  cleanUpLitestream(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    // Cleanup existing artifacts to avoid issues with Litestream replication.\n    // Note that don't merge multiple rm commands into one, because if one fails, the subsequent ones won't run.\n    return `rm -Rf ${dirPath}/prod.sqlite3-*; rm -Rf ${dirPath}/prod.sqlite3.*; rm -Rf ${dirPath}/.prod.sqlite3* || true`;\n  }\n\n  deploy(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions}`;\n  }\n\n  deployForce(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    // `prisma migrate reset` can fail depending on the state of the existing database, so we remove it first.\n    // Don't skip \"migrate deploy\" because restored database may be older than the current schema.\n    return `rm -Rf ${dirPath}/prod.sqlite3*; PRISMA migrate reset --force --skip-seed && rm -Rf ${dirPath}/prod.sqlite3*\n      && litestream restore -config litestream.yml -o ${dirPath}/prod.sqlite3 ${dirPath}/prod.sqlite3 && ls -ahl ${dirPath}/prod.sqlite3 && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`;\n  }\n\n  listBackups(project: Project): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `litestream ltx -config litestream.yml ${dirPath}/prod.sqlite3`;\n  }\n\n  migrate(project: Project, additionalOptions = ''): string {\n    return `PRISMA migrate deploy ${additionalOptions} && PRISMA generate && ${this.seed(project)}`;\n  }\n\n  migrateDev(_: Project, additionalOptions = ''): string {\n    return `PRISMA migrate dev ${additionalOptions}`;\n  }\n\n  reset(project: Project, additionalOptions = ''): string {\n    // cf. https://www.prisma.io/docs/guides/database/seed-database#integrated-seeding-with-prisma-migrate\n    if (project.packageJson.dependencies?.blitz) {\n      // Blitz does not trigger seed automatically, so we need to run it manually.\n      return `PRISMA migrate reset --force ${additionalOptions} && ${this.seed(project)}`;\n    }\n    return `PRISMA migrate reset --force ${additionalOptions}`;\n  }\n\n  restore(project: Project, outputPath: string): string {\n    const dirPath = getDatabaseDirPath(project);\n    return `rm -Rf ${outputPath}*; litestream restore -config litestream.yml -o ${outputPath} ${dirPath}/prod.sqlite3`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (project.packageJson.dependencies?.blitz) return `YARN blitz db seed${scriptPath ? ` -f ${scriptPath}` : ''}`;\n    if (scriptPath) return `BUN build-ts run ${scriptPath}`;\n    if ((project.packageJson.prisma as Record<string, string> | undefined)?.seed) return `YARN prisma db seed`;\n    return `if [ -e \"prisma/seeds.ts\" ]; then BUN build-ts run prisma/seeds.ts; fi`;\n  }\n\n  studio(project: Project, dbUrlOrPath?: string, additionalOptions = ''): string {\n    const FILE_SCHEMA = 'file:';\n    let prefix = '';\n    // Deal with Prisma issue: https://github.com/prisma/studio/issues/1273\n    if (dbUrlOrPath) {\n      try {\n        new URL(dbUrlOrPath);\n        prefix = `DATABASE_URL=${dbUrlOrPath} `;\n      } catch {\n        const absolutePath = path.resolve(dbUrlOrPath);\n        prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n      }\n    } else if (project.env.DATABASE_URL?.startsWith(FILE_SCHEMA)) {\n      const POSSIBLE_PATHS = [\n        { schemaPath: path.join('prisma', 'schema.prisma'), dbPath: 'prisma' },\n        { schemaPath: path.join('prisma', 'schema'), dbPath: path.join('prisma', 'schema') },\n        { schemaPath: path.join('db', 'schema.prisma'), dbPath: 'db' },\n      ];\n      for (const { dbPath, schemaPath } of POSSIBLE_PATHS) {\n        if (fs.existsSync(path.resolve(project.dirPath, schemaPath))) {\n          const absolutePath = path.resolve(\n            project.dirPath,\n            dbPath,\n            project.env.DATABASE_URL.slice(FILE_SCHEMA.length)\n          );\n          prefix = `DATABASE_URL=${FILE_SCHEMA}${absolutePath} `;\n          break;\n        }\n      }\n    }\n    return `${prefix}PRISMA studio ${additionalOptions}`;\n  }\n}\n\nfunction getDatabaseDirPath(project: Project): string {\n  return project.packageJson.dependencies?.blitz ? 'db/mount' : 'prisma/mount';\n}\n\nexport const prismaScripts = new PrismaScripts();\n","import { yargsOptionsBuilderForEnv } from '@willbooster/shared-lib-node/src';\n\nexport const sharedOptionsBuilder = {\n  ...yargsOptionsBuilderForEnv,\n  // This option is for debugging mainly.\n  'working-dir': {\n    description: 'A working directory',\n    type: 'string',\n    alias: 'w',\n  },\n  'dry-run': {\n    description: 'Whether to skip actual command execution',\n    type: 'boolean',\n    alias: ['dry', 'd'],\n  },\n} as const;\n","import fs from 'node:fs';\n\nimport type { EnvReaderOptions } from '@willbooster/shared-lib-node/src';\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport { prismaScripts } from '../scripts/prismaScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const prismaCommand: CommandModule = {\n  command: 'prisma',\n  describe: 'Run prisma commands',\n  builder: (yargs) => {\n    return yargs\n      .command(cleanUpLitestreamCommand)\n      .command(createLitestreamConfigCommand)\n      .command(deployCommand)\n      .command(deployForceCommand)\n      .command(listBackupsCommand)\n      .command(migrateCommand)\n      .command(migrateDevCommand)\n      .command(resetCommand)\n      .command(restoreCommand)\n      .command(seedCommand)\n      .command(studioCommand)\n      .command(defaultCommand)\n      .demandCommand()\n      .strict(false); // Allow unknown options to be passed through\n  },\n  handler() {\n    // Do nothing\n  },\n};\n\nconst cleanUpLitestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'cleanup-litestream',\n  describe: 'Clean up temporal Litestream files',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma cleanup-litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.cleanUpLitestream(project), project, argv);\n    }\n  },\n};\n\nconst createLitestreamConfigCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'create-litestream-config',\n  describe: 'Create Litestream configuration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma create-litestream-config', allProjects)) {\n      createLitestreamConfig(project);\n    }\n  },\n};\n\nconst deployCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy',\n  describe: 'Apply migration to DB without initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma deploy', allProjects)) {\n      await runWithSpawn(prismaScripts.deploy(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst deployForceCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'deploy-force',\n  describe: \"Force to apply migration to DB utilizing Litestream's backup without initializing it\",\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma deploy-force', allProjects)) {\n      await runWithSpawn(prismaScripts.deployForce(project), project, argv);\n    }\n  },\n};\n\nconst listBackupsCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'list-backups',\n  describe: 'List Litestream backups',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma list-backups', allProjects)) {\n      await runWithSpawn(prismaScripts.listBackups(project), project, argv);\n    }\n  },\n};\n\nconst migrateCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate',\n  describe: 'Apply migration to DB with initializing it',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma migrate', allProjects)) {\n      await runWithSpawn(prismaScripts.migrate(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst migrateDevCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'migrate-dev',\n  describe: 'Create a migration file',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma migrate-dev', allProjects)) {\n      await runWithSpawn(prismaScripts.migrateDev(project, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst resetCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'reset',\n  describe: 'Reset DB',\n  builder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv);\n    for (const project of prepareForRunningCommand('prisma reset', allProjects)) {\n      await runWithSpawn(prismaScripts.reset(project, unknownOptions), project, argv);\n    }\n    // Force to reset test database\n    if (process.env.WB_ENV !== 'test') {\n      process.env.WB_ENV = 'test';\n      for (const project of prepareForRunningCommand('WB_ENV=test prisma reset', await findPrismaProjects(argv))) {\n        await runWithSpawn(prismaScripts.reset(project, unknownOptions), project, argv);\n      }\n    }\n  },\n};\n\nconst restoreBuilder = {\n  ...builder,\n  output: {\n    description: 'Output path of the restored database. Defaults to \"<db|prisma>/restored.sqlite3\".',\n    type: 'string',\n  },\n} as const;\n\nconst restoreCommand: CommandModule<unknown, InferredOptionTypes<typeof restoreBuilder>> = {\n  command: 'restore',\n  describe: \"Restore DB from Litestream's backup\",\n  builder: restoreBuilder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma restore', allProjects)) {\n      const output =\n        argv.output ?? (project.packageJson.dependencies?.blitz ? 'db/restored.sqlite3' : 'prisma/restored.sqlite3');\n      await runWithSpawn(prismaScripts.restore(project, output), project, argv);\n    }\n  },\n};\n\nconst seedBuilder = {\n  ...builder,\n  file: {\n    alias: 'f',\n    description: 'Path of the seed script.',\n    type: 'string',\n  },\n} as const;\n\nconst seedCommand: CommandModule<unknown, InferredOptionTypes<typeof seedBuilder>> = {\n  command: 'seed',\n  describe: 'Populate DB with seed data',\n  builder: seedBuilder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    for (const project of prepareForRunningCommand('prisma seed', allProjects)) {\n      await runWithSpawn(prismaScripts.seed(project, argv.file), project, argv);\n    }\n  },\n};\n\nconst studioBuilder = {\n  ...builder,\n  'db-url-or-path': {\n    description: 'URL or path to the database',\n    type: 'string',\n  },\n  restored: {\n    description: 'Whether to open the default restored database (<db|prisma>/restored.sqlite3).',\n    type: 'boolean',\n  },\n} as const;\n\nconst studioCommand: CommandModule<unknown, InferredOptionTypes<typeof studioBuilder>> = {\n  command: 'studio [db-url-or-path]',\n  describe: 'Open Prisma Studio',\n  builder: studioBuilder,\n  async handler(argv) {\n    if (argv.restored && argv.dbUrlOrPath) {\n      throw new Error('You cannot specify both --restored and --db-url-or-path.');\n    }\n\n    const allProjects = await findPrismaProjects(argv);\n    const unknownOptions = extractUnknownOptions(argv, ['db-url-or-path', 'restored']);\n    for (const project of prepareForRunningCommand('prisma studio', allProjects)) {\n      const dbUrlOrPath = argv.restored\n        ? project.packageJson.dependencies?.blitz\n          ? 'db/restored.sqlite3'\n          : 'prisma/restored.sqlite3'\n        : argv.dbUrlOrPath?.toString();\n      await runWithSpawn(prismaScripts.studio(project, dbUrlOrPath, unknownOptions), project, argv);\n    }\n  },\n};\n\nconst defaultCommandBuilder = { args: { type: 'array' } } as const;\n\nconst defaultCommand: CommandModule<unknown, InferredOptionTypes<typeof defaultCommandBuilder>> = {\n  command: '$0 <args..>',\n  describe: 'Pass the command and arguments to prisma as is',\n  builder: defaultCommandBuilder,\n  async handler(argv) {\n    const allProjects = await findPrismaProjects(argv);\n    const script = (argv.args?.join(' ') ?? '').trimEnd();\n    const unknownOptions = extractUnknownOptions(argv, ['args']);\n    const fullCommand = [script, unknownOptions].filter(Boolean).join(' ');\n    for (const project of prepareForRunningCommand(`prisma ${fullCommand}`, allProjects)) {\n      await runWithSpawn(`PRISMA ${fullCommand}`, project, argv);\n    }\n  },\n};\n\nfunction createLitestreamConfig(project: Project): void {\n  const dirName = project.packageJson.dependencies?.blitz ? 'db' : 'prisma';\n  const dbPath = `${dirName}/mount/prod.sqlite3`;\n  const requiredEnvVars = {\n    CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID,\n    CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME: project.env.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME,\n    CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID: project.env.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID,\n    CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY: project.env.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY,\n  } as const;\n  const missingEnvVars = Object.entries(requiredEnvVars)\n    .filter(([, value]) => !value)\n    .map(([key]) => key);\n  if (missingEnvVars.length > 0) {\n    throw new Error(`Missing environment variables for Litestream: ${missingEnvVars.join(', ')}`);\n  }\n\n  const retentionCheckInterval = project.env.WB_ENV === 'staging' ? '5m' : '1h';\n  const litestreamConfig = `dbs:\n  - path: ${dbPath}\n    replica:\n      type: s3\n      endpoint: https://${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID}.r2.cloudflarestorage.com\n      bucket: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME}\n      access-key-id: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID}\n      secret-access-key: ${requiredEnvVars.CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY}\n      snapshot-interval: 24h  # Create a backup per day\n      retention: 72h          # Keep backups for 3 days\n      retention-check-interval: ${retentionCheckInterval}\n      sync-interval: 60s\n`;\n\n  const configPath = '/etc/litestream.yml';\n  try {\n    fs.writeFileSync(configPath, litestreamConfig);\n    console.info(`Generated ${configPath}`);\n  } catch (error) {\n    const reason = error instanceof Error ? error.message : String(error);\n    throw new Error(`Failed to write ${configPath}: ${reason}`);\n  }\n}\n\nasync function findPrismaProjects(argv: EnvReaderOptions): Promise<Project[]> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  const filtered = projects.descendants.filter(\n    (project) => project.packageJson.dependencies?.prisma ?? project.packageJson.devDependencies?.prisma\n  );\n  if (filtered.length === 0) {\n    console.error(chalk.red('No prisma project found.'));\n    process.exit(1);\n  }\n  return filtered;\n}\n\n/**\n * Extract unknown options from argv to pass to prisma command\n */\nexport function extractUnknownOptions(argv: Record<string, unknown>, knownOptions: string[] = []): string {\n  const unknownOptions: string[] = [];\n\n  // Build list of known options from shared options builders\n  const sharedOptionKeys = Object.keys(sharedOptionsBuilder);\n  const sharedOptionAliases = Object.values(sharedOptionsBuilder)\n    .flatMap((option) => {\n      if ('alias' in option) {\n        return Array.isArray(option.alias) ? option.alias : [option.alias];\n      }\n      return [];\n    })\n    .map(String);\n\n  const allKnownOptions = new Set([\n    ...knownOptions,\n    ...sharedOptionKeys,\n    ...sharedOptionAliases,\n    // Internal yargs properties\n    '_',\n    '$0',\n  ]);\n\n  for (const [key, value] of Object.entries(argv)) {\n    if (!allKnownOptions.has(key)) {\n      // Skip camelCase versions of kebab-case options to avoid duplication\n      // If we have both 'create-only' and 'createOnly', prefer the kebab-case version\n      const kebabCaseKey = key.replaceAll(/[A-Z]/g, (match) => `-${match.toLowerCase()}`);\n      if (kebabCaseKey !== key && argv[kebabCaseKey] !== undefined) {\n        continue; // Skip camelCase version if kebab-case exists\n      }\n\n      // Handle boolean flags\n      if (typeof value === 'boolean' && value) {\n        unknownOptions.push(`--${key}`);\n      }\n      // Handle string/number values\n      else if (typeof value === 'string' || typeof value === 'number') {\n        unknownOptions.push(`--${key}`, String(value));\n      }\n      // Handle arrays\n      else if (Array.isArray(value)) {\n        for (const item of value) {\n          unknownOptions.push(`--${key}`, String(item));\n        }\n      }\n    }\n  }\n\n  return unknownOptions.join(' ');\n}\n","import chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findSelfProject } from '../project.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {\n  retry: {\n    description: 'A maximum retry count',\n    type: 'number',\n    alias: 'r',\n    default: 3,\n  },\n} as const;\n\nconst _argumentsBuilder = {\n  command: {\n    description: 'A command to retry',\n    type: 'string',\n  },\n  args: {\n    description: 'Arguments for the command',\n    type: 'array',\n  },\n} as const;\n\nexport const retryCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof _argumentsBuilder>\n> = {\n  command: 'retry [command] [args...]',\n  describe: 'Retry the given command until it succeeds',\n  builder,\n  async handler(argv) {\n    const project = findSelfProject(argv);\n    if (!project) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    const cmdAndArgs = [argv.command, ...(argv.args ?? []), ...argv._.slice(1)].filter(Boolean);\n    let lastStatus = 0;\n    for (let i = 0; i < argv.retry; i++) {\n      if (i > 0) {\n        console.info(`\\n${chalk.yellow(`#${i} Retrying: ${cmdAndArgs.join(' ')}`)}`);\n      }\n      // TODO: should we add single quotes around each argument?\n      lastStatus = await runWithSpawn(cmdAndArgs.join(' '), project, argv, {\n        exitIfFailed: false,\n        onSignal: (signal) => {\n          if (signal) {\n            process.exit(1);\n          }\n        },\n      });\n      if (lastStatus === 0) return;\n    }\n    process.exit(lastStatus);\n  },\n};\n","import child_process from 'node:child_process';\nimport fs from 'node:fs/promises';\nimport os from 'node:os';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { packageManagerWithRun } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\n\nconst builder = {} as const;\n\nexport const setupCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: 'setup',\n  describe: 'Setup development environment. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    await setup(argv);\n  },\n};\n\n// Test code requires Partial<...>\nexport async function setup(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>,\n  projectPathForTesting?: string\n): Promise<void> {\n  const projects = await findDescendantProjects(argv, false, projectPathForTesting);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  for (const project of prepareForRunningCommand('setup', projects.descendants)) {\n    const dirents = await fs.readdir(project.dirPath, { withFileTypes: true });\n    if (project === projects.root) {\n      if (os.platform() === 'darwin') {\n        const packages = ['pstree'];\n        await runWithSpawnInParallel(`brew install ${packages.join(' ')}`, project, argv);\n      }\n\n      if (dirents.some((d) => d.isFile() && d.name.includes('-version'))) {\n        await runWithSpawn('asdf install', project, argv, { exitIfFailed: false });\n      }\n    }\n\n    if (dirents.some((d) => d.isFile() && d.name === 'pyproject.toml')) {\n      await runWithSpawnInParallel('poetry config virtualenvs.in-project true', project, argv);\n      const [, version] = child_process.execSync('asdf current python').toString().trim().split(/\\s+/);\n      await runWithSpawnInParallel(`poetry env use ${version}`, project, argv);\n      await promisePool.promiseAll();\n      await runWithSpawn('poetry run pip install --upgrade pip', project, argv);\n      await runWithSpawn('poetry install --ansi', project, argv);\n    }\n\n    if (\n      (project === projects.root || !projects.root.packageJson.scripts?.['gen-code']) &&\n      project.packageJson.scripts?.['gen-code']\n    ) {\n      await runWithSpawn(`${packageManagerWithRun} gen-code`, project, argv);\n    }\n  }\n\n  const project = projects.descendants.find((p) => p.packageJson.devDependencies?.playwright);\n  if (project) {\n    await runWithSpawn(`${packageManagerWithRun} playwright install --with-deps`, project, argv);\n  }\n}\n","import type { ArgumentsCamelCase, InferredOptionTypes } from 'yargs';\n\nexport const scriptOptionsBuilder = {\n  watch: {\n    description: 'Whether to watch files',\n    type: 'boolean',\n  },\n  args: {\n    description: 'Arguments for core command',\n    type: 'array',\n    alias: 'a',\n    default: [],\n  },\n  'docker-options': {\n    description: 'Arguments for \"docker run\"',\n    type: 'array',\n    default: [],\n  },\n} as const;\n\nexport type ScriptArgv = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>> & {\n  normalizedArgsText?: string;\n  normalizedDockerOptionsText?: string;\n  silent?: boolean;\n  verbose?: boolean;\n};\n\nexport function normalizeArgs(\n  argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof scriptOptionsBuilder>>>\n): void {\n  (argv as ScriptArgv).normalizedArgsText = [...(argv.args ?? []), ...(argv._?.slice(1) ?? [])]\n    .map((arg) => `'${arg}'`)\n    .join(' ');\n  (argv as ScriptArgv).normalizedDockerOptionsText = (argv.dockerOptions ?? []).map((arg) => `'${arg}'`).join(' ');\n}\n\nexport function toDevNull(argv: unknown): string {\n  return (argv as { silent: boolean }).silent ? ` > /dev/null` : '';\n}\n","import { spawnSync } from 'node:child_process';\n\nimport { spawnAsync } from '@willbooster/shared-lib-node/src';\nimport killPortProcess from 'kill-port';\n\nimport type { Project } from '../project.js';\nimport { printFinishedAndExitIfNeeded, printStart } from '../scripts/run.js';\n\nimport { isPortAvailable } from './port.js';\n\nconst killed = new Set<number | string>();\n\nexport async function killPortProcessImmediatelyAndOnExit(port: number, project: Project): Promise<void> {\n  const available = await isPortAvailable(port);\n  if (!available) {\n    await killPortContainerAndProcess(port, project);\n  }\n\n  const killFunc = async (): Promise<void> => {\n    if (killed.has(port)) return;\n\n    killed.add(port);\n    await killPortContainerAndProcess(port, project);\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n\nasync function killPortContainerAndProcess(port: number, project: Project): Promise<void> {\n  // We should stop Docker containers first because `kill-port` may fail to stop Docker containers.\n  await stopDockerContainerByPort(port, project);\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n\nexport async function stopDockerContainerByImageName(imageName: string, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `name=${imageName}`], project);\n}\n\nexport async function stopDockerContainerByPort(port: number, project: Project): Promise<void> {\n  await removeDockerContainers(['--filter', `publish=${port}`], project);\n}\n\nasync function removeDockerContainers(filterArgs: string[], project: Project): Promise<void> {\n  try {\n    const containerIds = await listDockerContainerIds(filterArgs, project);\n    if (containerIds.length === 0) return;\n\n    await spawnAsync('docker', ['rm', '-f', ...containerIds], {\n      cwd: project.dirPath,\n      env: project.env,\n    });\n  } catch {\n    // do nothing\n  }\n}\n\nasync function listDockerContainerIds(filterArgs: string[], project: Project): Promise<string[]> {\n  const { stdout } = await spawnAsync('docker', ['ps', '-q', ...filterArgs], {\n    cwd: project.dirPath,\n    env: project.env,\n  });\n  return stdout\n    .split(/\\s+/)\n    .map((id) => id.trim())\n    .filter(Boolean);\n}\n\nexport function spawnSyncOnExit(script: string, project: Project): void {\n  const killFunc = (): void => {\n    if (killed.has(script)) return;\n\n    killed.add(script);\n    printStart(script, project);\n    const { status } = spawnSync(script, { cwd: project.dirPath, shell: true, stdio: 'inherit' });\n    printFinishedAndExitIfNeeded(script, status, {});\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n","import { createServer } from 'node:net';\n\nimport type { Project } from '../project.js';\n\nimport { killPortProcessImmediatelyAndOnExit } from './process.js';\n\n/**\n * Checks the given port and kills any process using it.\n * Note wb always requires PORT environment variable.\n */\nexport async function checkAndKillPortProcess(rawPort: unknown, project: Project): Promise<number> {\n  const port = Number(rawPort);\n  if (!port) throw new Error(`The given port (${port}) is invalid.`);\n\n  await killPortProcessImmediatelyAndOnExit(port, project);\n  return port;\n}\n\n/**\n * Checks if a port is available.\n * @param port - The port number to check\n * @returns A promise that resolves to true if the port is available, false otherwise\n */\nexport async function isPortAvailable(port: number): Promise<boolean> {\n  // Check both stacks to catch processes bound only on IPv6 or IPv4.\n  for (const host of ['127.0.0.1', '::']) {\n    const available = await probePort(host, port);\n    if (!available) return false;\n  }\n  return true;\n}\n\nasync function probePort(host: string, port: number): Promise<boolean> {\n  return new Promise((resolve) => {\n    const server = createServer();\n\n    server.once('error', (err: NodeJS.ErrnoException) => {\n      if (err.code === 'EADDRINUSE') {\n        resolve(false);\n        return;\n      }\n      if (err.code === 'EAFNOSUPPORT') {\n        resolve(true);\n        return;\n      }\n      resolve(false);\n    });\n\n    server.once('listening', () => {\n      server.close(() => {\n        resolve(true);\n      });\n    });\n\n    server.listen(port, host);\n  });\n}\n","import path from 'node:path';\n\nimport type { Project } from '../project.js';\nimport { spawnSyncOnExit } from '../utils/process.js';\n\n/**\n * A collection of scripts for executing Docker commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass DockerScripts {\n  buildImage(project: Project, version: string): string {\n    // e.g. coding-booster uses `\"docker/build/prepare\": \"touch drill-users.csv\",`\n    const prefix = project.dockerPackageJson.scripts?.['docker/build/prepare']\n      ? 'YARN run docker/build/prepare && '\n      : '';\n    return `cd ${path.dirname(project.findFile('Dockerfile'))}\n    && ${prefix}YARN wb optimizeForDockerBuild --outside\n    && YARN wb retry -- docker build -t ${project.dockerImageName}\n        --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo x86_64)\n        --build-arg WB_ENV=${project.env.WB_ENV}\n        --build-arg WB_VERSION=${version} .`;\n  }\n\n  stopAndStart(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    return `${this.stop(project)} && ${this.start(project, additionalOptions, additionalArgs)}`;\n  }\n\n  start(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    spawnSyncOnExit(this.stop(project), project);\n    const allocateTty = additionalArgs.includes('/bin/bash');\n    return `docker run --rm ${allocateTty ? '-it ' : ''}--publish ${project.env.PORT}:8080 --name ${project.dockerImageName} ${additionalOptions} ${project.dockerImageName} ${additionalArgs}`;\n  }\n\n  stop(project: Project): string {\n    return `true $(docker rm -f $(docker container ls -q -f name=${project.dockerImageName}) 2> /dev/null)`;\n  }\n\n  stopAll(): string {\n    return `true $(docker rm -f $(docker ps -q) 2> /dev/null)`;\n  }\n}\n\nexport const dockerScripts = new DockerScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { toDevNull } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nexport interface TestE2EOptions {\n  /** '--e2e generate' calls 'codegen http://localhost:8080' */\n  playwrightArgs?: string;\n}\n\n/**\n * A collection of scripts for executing an app.\n * Note that YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nexport abstract class BaseScripts {\n  private readonly shouldWaitAndOpenApp: boolean;\n  protected constructor(shouldWaitAndOpenApp: boolean) {\n    this.shouldWaitAndOpenApp = shouldWaitAndOpenApp;\n  }\n\n  buildDocker(project: Project, version: string): string {\n    return dockerScripts.buildImage(project, version);\n  }\n\n  // ------------ START: start commands ------------\n  async startDev(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startDevProtected(project, argv);\n\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"${this.startDevProtected(project, argv)}\"\n      \"${this.waitAndOpenApp(project)}\"`;\n  }\n  async startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) return this.startProductionProtected(project, argv);\n\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"${this.startProductionProtected(project, argv)}\"\n      \"${this.waitAndOpenApp(project)}\"`;\n  }\n  async startTest(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    return this.startProductionProtected(project, argv);\n  }\n  async startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    if (!this.shouldWaitAndOpenApp) {\n      return `${this.buildDocker(project, 'development')}\n      && ${dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? '')}`;\n    }\n\n    return `${this.buildDocker(project, 'development')}\n      && YARN concurrently --raw --kill-others-on-fail\n        \"${dockerScripts.stopAndStart(project, argv.normalizedDockerOptionsText ?? '', argv.normalizedArgsText ?? '')}\"\n        \"${this.waitAndOpenApp(project)}\"`;\n  }\n\n  protected abstract startDevProtected(_: Project, argv: ScriptArgv): string;\n  protected startProductionProtected(project: Project, argv: ScriptArgv): string {\n    const ecosystemConfigPath = findEcosystemConfigPath(project);\n    const commands =\n      ecosystemConfigPath === undefined\n        ? [\n            `YARN wb buildIfNeeded ${argv.verbose ? '--verbose' : ''}`.trim(),\n            `node dist/index.js ${argv.normalizedArgsText ?? ''}`.trim(),\n          ]\n        : [project.buildCommand, `pm2-runtime start --no-autorestart ${ecosystemConfigPath}`];\n\n    return [...(project.hasPrisma ? prismaScripts.migrate(project).split('&&') : []), ...commands]\n      .filter(Boolean)\n      .map((cmd) => `${cmd} ${toDevNull(argv)}`.trim())\n      .join(' && ');\n  }\n  // ------------ END: start commands ------------\n\n  // ------------ START: test (e2e) commands ------------\n  testE2EDev(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startDevProtected(project, argv), options);\n  }\n  testE2EProduction(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, this.startProductionProtected(project, argv), options);\n  }\n  testE2EDocker(project: Project, argv: TestArgv, options: TestE2EOptions): Promise<string> {\n    return this.testE2EProtected(project, argv, dockerScripts.stopAndStart(project), options);\n  }\n  async testStart(project: Project, argv: ScriptArgv): Promise<string> {\n    await checkAndKillPortProcess(project.env.PORT, project);\n    // Use empty NODE_ENV to avoid \"production\" mode in some frameworks like Blitz.js.\n    return `NODE_ENV=\"\" YARN concurrently --kill-others --raw --success first \"${this.startDevProtected(project, argv)}\" \"${this.waitApp(project)}\"`;\n  }\n\n  async testE2EProtected(\n    project: Project,\n    argv: TestArgv,\n    startCommand: string,\n    { playwrightArgs = 'test test/e2e/' }: TestE2EOptions\n  ): Promise<string> {\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const playwrightCommand = buildPlaywrightCommand(playwrightArgs, argv.targets);\n    if (project.skipLaunchingServerForPlaywright) {\n      return `${playwrightCommand}${suffix}`;\n    }\n\n    return `YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port}\n        && ${playwrightCommand}${suffix}\"`;\n  }\n  // ------------ END: test (e2e) commands ------------\n\n  testUnit(project: Project, argv: TestArgv): string {\n    const testTarget = argv.targets?.join(' ') || 'test/unit/';\n    if (project.hasVitest) {\n      // Since this command is referred from other commands, we have to use \"vitest run\" (non-interactive mode).\n      return `YARN vitest run ${testTarget} --color --passWithNoTests --allowOnly`;\n    } else if (project.isBunAvailable) {\n      return `bun test ${testTarget}`;\n    }\n    return 'echo \"No tests.\"';\n  }\n\n  protected waitApp(project: Project): string {\n    const port = project.env.PORT;\n    return `wait-on -t 10000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 500 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${port} 2> /dev/null\n      || wait-on -t 90000 -i 10000 http-get://127.0.0.1:${port}`;\n  }\n\n  protected waitAndOpenApp(project: Project): string {\n    const port = project.env.PORT;\n    return `${this.waitApp(\n      project\n    )} || wait-on http-get://127.0.0.1:${port} && open-cli http://\\${HOST:-localhost}:${port}`;\n  }\n}\n\nfunction findEcosystemConfigPath(project: Project): string | undefined {\n  try {\n    return project.findFile('ecosystem.config.cjs');\n  } catch {\n    return;\n  }\n}\n\nfunction buildPlaywrightCommand(playwrightArgs: string, targets: TestArgv['targets']): string {\n  const base = 'BUN playwright';\n  const target = targets?.join(' ') || 'test/e2e/';\n  if (!playwrightArgs.startsWith('test ') || !targets?.length) {\n    return `${base} ${playwrightArgs}`;\n  }\n\n  const rest = playwrightArgs.slice('test '.length).trim();\n  const parts = rest.length > 0 ? rest.split(/\\s+/) : [];\n  if (!parts[0] || parts[0].startsWith('-')) {\n    parts.unshift(target);\n  } else {\n    parts[0] = target;\n  }\n  return `${base} test ${parts.join(' ')}`;\n}\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Blitz.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass BlitzScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `blitz dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const blitzScripts = new BlitzScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { checkAndKillPortProcess } from '../../utils/port.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass HttpServerScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  async testE2EProtected(project: Project, argv: TestArgv, startCommand: string): Promise<string> {\n    const port = await checkAndKillPortProcess(project.env.PORT, project);\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    const testTarget = argv.targets && argv.targets.length > 0 ? argv.targets.join(' ') : 'test/e2e/';\n\n    return `YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:${port}\n        && vitest run ${testTarget} --color --passWithNoTests --allowOnly${suffix}\"`;\n  }\n}\n\nexport const httpServerScripts = new HttpServerScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Next.js commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass NextScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `next dev --turbopack ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const nextScripts = new NextScripts();\n","import type { Project } from '../../project.js';\nimport { SERVER_LOG_FILE } from '../../utils/log.js';\nimport { runtimeWithArgs } from '../../utils/runtime.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing an app that utilizes an HTTP server like express.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass PlainAppScripts extends BaseScripts {\n  constructor() {\n    super(false);\n  }\n\n  protected startDevProtected(_1: Project, _2: ScriptArgv): string {\n    throw new Error('This method should not be called.');\n  }\n\n  override startDev(_: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `YARN build-ts run ${argv.watch ? '--watch' : ''} src/index.ts -- ${argv.normalizedArgsText ?? ''}`\n    );\n  }\n  override startProduction(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${project.buildCommand} && ${runtimeWithArgs} dist/index.js ${argv.normalizedArgsText ?? ''} | tee ${SERVER_LOG_FILE}`\n    );\n  }\n  override startTest(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override startDocker(project: Project, argv: ScriptArgv): Promise<string> {\n    return Promise.resolve(\n      `${this.buildDocker(project, 'development')} && ${dockerScripts.stopAndStart(\n        project,\n        argv.normalizedDockerOptionsText ?? '',\n        argv.normalizedArgsText ?? ''\n      )}`\n    );\n  }\n\n  override testE2EDev(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EProduction(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testE2EDocker(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n  override testStart(): Promise<string> {\n    return Promise.resolve(`echo 'do nothing.'`);\n  }\n}\n\nexport const plainAppScripts = new PlainAppScripts();\n","import type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\n\nimport { BaseScripts } from './baseScripts.js';\n\n/**\n * A collection of scripts for executing Remix commands.\n * Note that `YARN zzz` is replaced with `yarn zzz` or `node_modules/.bin/zzz`.\n */\nclass RemixScripts extends BaseScripts {\n  constructor() {\n    super(true);\n  }\n\n  protected override startDevProtected(_: Project, argv: ScriptArgv): string {\n    return `remix dev ${argv.normalizedArgsText ?? ''}`;\n  }\n}\n\nexport const remixScripts = new RemixScripts();\n","export const httpServerPackages = ['express', 'fastify', 'elysia', 'hono'];\n","import chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { normalizeArgs, scriptOptionsBuilder } from '../scripts/builder.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst builder = {\n  ...scriptOptionsBuilder,\n  mode: {\n    description: 'Start mode: dev[elopment] (default) | staging | docker | docker-debug | test',\n    type: 'string',\n    alias: 'm',\n  },\n} as const;\n\nexport const startCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  command: 'start [args..]',\n  describe: 'Start app',\n  builder,\n  async handler(argv) {\n    normalizeArgs(argv);\n\n    const projects = await findDescendantProjects(argv);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    for (const project of projects.descendants) {\n      const deps = project.packageJson.dependencies ?? {};\n      const devDeps = project.packageJson.devDependencies ?? {};\n      let scripts: BaseScripts;\n      if (deps.blitz) {\n        scripts = blitzScripts;\n      } else if (deps.next) {\n        scripts = nextScripts;\n      } else if (devDeps['@remix-run/dev']) {\n        scripts = remixScripts;\n      } else if (\n        (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) ||\n        (project.hasDockerfile && /EXPOSE\\s+8080/.test(project.dockerfile))\n      ) {\n        scripts = httpServerScripts;\n      } else if (deps['build-ts'] || devDeps['build-ts']) {\n        scripts = plainAppScripts;\n      } else {\n        continue;\n      }\n      console.info(`Running \"start\" for ${project.name} ...`);\n\n      switch (argv.mode ?? 'dev') {\n        case 'dev':\n        case 'development': {\n          process.env.WB_ENV ||= 'development';\n          await runWithSpawn(await scripts.startDev(project, argv), project, argv);\n          break;\n        }\n        case 'staging': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startProduction(project, argv), project, argv);\n          break;\n        }\n        case 'docker': {\n          process.env.WB_ENV ||= 'staging';\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'docker-debug': {\n          process.env.WB_ENV ||= 'staging';\n          argv.normalizedArgsText = `'/bin/bash'`;\n          await runWithSpawn(await scripts.startDocker(project, argv), project, argv);\n          break;\n        }\n        case 'test': {\n          process.env.WB_ENV ||= 'test';\n          const script = await scripts.startTest(project, argv);\n          await runWithSpawn(script, project, argv);\n          break;\n        }\n        default: {\n          throw new Error(`Unknown start mode: ${argv.mode}`);\n        }\n      }\n    }\n  },\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport type { Project } from '../project.js';\nimport { findDescendantProjects } from '../project.js';\nimport type { scriptOptionsBuilder } from '../scripts/builder.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { runWithSpawn } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst builder = {\n  e2e: {\n    description:\n      'E2e test mode: headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace',\n    type: 'string',\n    choices: [\n      'headless',\n      'headless-dev',\n      'headed',\n      'headed-dev',\n      'docker',\n      'docker-debug',\n      'debug',\n      'generate',\n      'trace',\n    ],\n    default: 'headless',\n  },\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n  'unit-timeout': {\n    description: 'Timeout for unit tests',\n    type: 'number',\n  },\n} as const;\n\nconst argumentsBuilder = {\n  targets: {\n    description: 'Test target paths',\n    type: 'array',\n  },\n} as const;\n\nexport type TestArgv = Partial<\n  ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof scriptOptionsBuilder & typeof argumentsBuilder>>\n>;\n\nexport const testCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof argumentsBuilder>\n> = {\n  command: 'test [targets...]',\n  describe: 'Test project. If you pass no arguments, it will run all tests.',\n  builder: { ...builder, ...argumentsBuilder },\n  async handler(argv) {\n    await test(argv);\n  },\n};\n\nexport async function test(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder & typeof argumentsBuilder>>\n): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  if (projects.descendants.length > 1) {\n    // Disable interactive mode\n    process.env.CI = '1';\n  }\n  process.env.FORCE_COLOR ||= '3';\n  process.env.WB_ENV ||= 'test';\n\n  // Get test targets from positional arguments\n  const testTargets = (argv.targets ?? []) as string[];\n  const shouldRunAllTests = testTargets.length === 0;\n\n  // Detect test modes from target paths\n  const hasE2eTargets = testTargets.some((target) => target.includes('/e2e'));\n  const hasUnitTargets = testTargets.some((target) => target.includes('/unit'));\n  const shouldRunUnit = shouldRunAllTests || hasUnitTargets;\n  const shouldRunE2e = shouldRunAllTests || hasE2eTargets;\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test\" for ${project.name} ...`);\n\n    // Run unit tests if needed\n    if (shouldRunUnit && fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n      const unitTargets = testTargets.filter((target) => target.includes('/unit'));\n      const unitArgv = { ...argv, targets: unitTargets.length > 0 ? unitTargets : undefined };\n      await runWithSpawn(scripts.testUnit(project, unitArgv), project, argv, { timeout: argv.unitTimeout });\n    }\n    // Skip e2e tests if not needed or no e2e directory exists\n    if (!shouldRunE2e || !fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      continue;\n    }\n\n    // Get e2e targets for this project\n    const e2eTargets = testTargets.filter((target) => target.includes('/e2e'));\n    const e2eArgv = { ...argv, targets: e2eTargets.length > 0 ? e2eTargets : undefined };\n\n    switch (argv.e2e) {\n      case 'headless': {\n        await runWithSpawn(await scripts.testE2EProduction(project, e2eArgv, {}), project, argv);\n        continue;\n      }\n      case 'headless-dev': {\n        await runWithSpawn(await scripts.testE2EDev(project, e2eArgv, {}), project, argv);\n        continue;\n      }\n      case 'docker': {\n        await testOnDocker(project, e2eArgv, scripts);\n        continue;\n      }\n      case 'docker-debug': {\n        const e2eTarget = e2eTargets.length > 0 ? e2eTargets.join(' ') : 'test/e2e/';\n        await testOnDocker(project, e2eArgv, scripts, `test ${e2eTarget} --debug`);\n        continue;\n      }\n    }\n    if (deps.blitz || deps.next || devDeps['@remix-run/dev']) {\n      const e2eTarget = e2eTargets.length > 0 ? e2eTargets.join(' ') : 'test/e2e/';\n      switch (argv.e2e) {\n        case 'headed': {\n          await runWithSpawn(\n            await scripts.testE2EProduction(project, e2eArgv, { playwrightArgs: `test ${e2eTarget} --headed` }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'headed-dev': {\n          await runWithSpawn(\n            await scripts.testE2EDev(project, e2eArgv, { playwrightArgs: `test ${e2eTarget} --headed` }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'debug': {\n          await runWithSpawn(\n            await scripts.testE2EProduction(project, e2eArgv, { playwrightArgs: `test ${e2eTarget} --debug` }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'generate': {\n          await runWithSpawn(\n            await scripts.testE2EProduction(project, e2eArgv, {\n              playwrightArgs: `codegen http://localhost:${project.env.PORT}`,\n            }),\n            project,\n            argv\n          );\n          break;\n        }\n        case 'trace': {\n          await runWithSpawn(`BUN playwright show-trace`, project, argv);\n          break;\n        }\n      }\n    }\n  }\n}\n\nasync function testOnDocker(\n  project: Project,\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof argumentsBuilder>>,\n  scripts: BaseScripts,\n  playwrightArgs?: string\n): Promise<void> {\n  project.env.WB_DOCKER ||= '1';\n  await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n  process.exitCode = await runWithSpawn(\n    await scripts.testE2EDocker(project, argv, {\n      playwrightArgs,\n    }),\n    project,\n    argv,\n    { exitIfFailed: false }\n  );\n  await runWithSpawn(dockerScripts.stop(project), project, argv);\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { ArgumentsCamelCase, CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { toDevNull } from '../scripts/builder.js';\nimport { dockerScripts } from '../scripts/dockerScripts.js';\nimport type { BaseScripts } from '../scripts/execution/baseScripts.js';\nimport { blitzScripts } from '../scripts/execution/blitzScripts.js';\nimport { httpServerScripts } from '../scripts/execution/httpServerScripts.js';\nimport { nextScripts } from '../scripts/execution/nextScripts.js';\nimport { plainAppScripts } from '../scripts/execution/plainAppScripts.js';\nimport { remixScripts } from '../scripts/execution/remixScripts.js';\nimport { runWithSpawn, runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\nimport { promisePool } from '../utils/promisePool.js';\n\nimport { httpServerPackages } from './httpServerPackages.js';\n\nconst testOnCiBuilder = {\n  silent: {\n    description: 'Reduce redundant outputs',\n    type: 'boolean',\n  },\n} as const;\nexport const testOnCiCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>\n> = {\n  command: 'test-on-ci',\n  describe: 'Test project on CI with no options.',\n  builder: testOnCiBuilder,\n  async handler(argv) {\n    await testOnCi(argv);\n  },\n};\n\nexport async function testOnCi(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof testOnCiBuilder & typeof sharedOptionsBuilder>>\n): Promise<void> {\n  const projects = await findDescendantProjects(argv);\n  if (!projects) {\n    console.error(chalk.red('No project found.'));\n    process.exit(1);\n  }\n\n  process.env.CI ||= '1';\n  process.env.FORCE_COLOR ||= '3';\n  process.env.WB_ENV ||= 'test';\n\n  for (const project of projects.descendants) {\n    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies ?? {};\n    let scripts: BaseScripts;\n    if (deps.blitz) {\n      scripts = blitzScripts;\n    } else if (deps.next) {\n      scripts = nextScripts;\n    } else if (devDeps['@remix-run/dev']) {\n      scripts = remixScripts;\n    } else if (httpServerPackages.some((p) => deps[p]) && !deps['firebase-functions']) {\n      scripts = httpServerScripts;\n    } else {\n      scripts = plainAppScripts;\n    }\n\n    console.info(`Running \"test-on-ci\" for ${project.name} ...`);\n\n    await runWithSpawnInParallel(dockerScripts.stopAll(), project, argv);\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'unit'))) {\n      // CI mode disallows `only` to avoid including debug tests\n      await runWithSpawnInParallel(scripts.testUnit(project, argv).replaceAll(' --allowOnly', ''), project, argv);\n    }\n    await runWithSpawnInParallel(await scripts.testStart(project, argv), project, argv);\n    await promisePool.promiseAll();\n    if (fs.existsSync(path.join(project.dirPath, 'test', 'e2e'))) {\n      if (project.hasDockerfile) {\n        project.env.WB_DOCKER ||= '1';\n        await runWithSpawn(`${scripts.buildDocker(project, 'test')}${toDevNull(argv)}`, project, argv);\n      }\n      const script = project.hasDockerfile\n        ? await scripts.testE2EDocker(project, argv, {})\n        : await scripts.testE2EProduction(project, argv, {});\n      process.exitCode = await runWithSpawn(\n        // CI mode disallows `only` to avoid including debug tests\n        script.replaceAll(' --allowOnly', ''),\n        project,\n        argv,\n        {\n          exitIfFailed: false,\n        }\n      );\n      await runWithSpawn(dockerScripts.stop(project), project, argv);\n    }\n  }\n}\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport chalk from 'chalk';\nimport type { CommandModule, InferredOptionTypes } from 'yargs';\n\nimport { findDescendantProjects } from '../project.js';\nimport { runWithSpawnInParallel } from '../scripts/run.js';\nimport type { sharedOptionsBuilder } from '../sharedOptionsBuilder.js';\n\nconst builder = {} as const;\n\nexport const typeCheckCommand: CommandModule<\n  unknown,\n  InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>\n> = {\n  command: 'typecheck',\n  describe: 'Run type checking. .env files are ignored.',\n  builder,\n  async handler(argv) {\n    const projects = await findDescendantProjects(argv, false);\n    if (!projects) {\n      console.error(chalk.red('No project found.'));\n      process.exit(1);\n    }\n\n    let removedNextDir = false as boolean;\n    const promises = projects.descendants.map(async (project) => {\n      const commands: string[] = [];\n      if (!project.packageJson.workspaces) {\n        if (project.packageJson.dependencies?.typescript || project.packageJson.devDependencies?.typescript) {\n          commands.push('BUN tsc --noEmit --Pretty');\n        }\n        if (project.packageJson.devDependencies?.pyright) {\n          commands.push('YARN pyright');\n        }\n      } else if (\n        project.hasSourceCode &&\n        (project.packageJson.dependencies?.typescript || project.packageJson.devDependencies?.typescript)\n      ) {\n        commands.push('BUN tsc --noEmit --Pretty');\n      }\n      while (commands.length > 0) {\n        const exitCode = await runWithSpawnInParallel(commands.join(' && '), project, argv, {\n          // Disable interactive mode\n          ci: projects.descendants.length > 1,\n          exitIfFailed: false,\n          forceColor: true,\n        });\n\n        // Re-try type checking after removing `.next` directory\n        const nextDirPath = path.join(project.dirPath, '.next');\n        if (exitCode && fs.existsSync(nextDirPath)) {\n          fs.rmSync(nextDirPath, { force: true, recursive: true });\n          console.info(chalk.yellow('Removed `.next` directory. We will re-try type checking.'));\n          removedNextDir = true;\n          continue;\n        }\n\n        return exitCode;\n      }\n    });\n    const exitCodes = await Promise.all(promises);\n    let finalExitCode = 0;\n    for (const [i, exitCode] of exitCodes.entries()) {\n      if (exitCode) {\n        const deps = projects.descendants[i]?.packageJson.dependencies ?? {};\n        if (deps.blitz) {\n          console.info(chalk.yellow('Please try \"yarn gen-code\" if you face unknown type errors.'));\n        }\n        finalExitCode = exitCode;\n      }\n    }\n    if (!finalExitCode)\n      console.info(\n        chalk.green(\n          removedNextDir\n            ? '-----\\nNo type errors found. Please ignore the previous type errors, as they were caused by outdated Next.js cache files.'\n            : 'No type errors found.'\n        )\n      );\n    process.exit(finalExitCode);\n  },\n};\n\nexport const tcCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  ...typeCheckCommand,\n  command: 'tc',\n};\n","import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport treeKill from 'tree-kill';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { buildIfNeededCommand } from './commands/buildIfNeeded.js';\nimport { killPortIfNonCiCommand } from './commands/killPortIfNonCi.js';\nimport { lintCommand } from './commands/lint.js';\nimport { optimizeForDockerBuildCommand } from './commands/optimizeForDockerBuild.js';\nimport { prismaCommand } from './commands/prisma.js';\nimport { retryCommand } from './commands/retry.js';\nimport { setupCommand } from './commands/setup.js';\nimport { startCommand } from './commands/start.js';\nimport { testCommand } from './commands/test.js';\nimport { testOnCiCommand } from './commands/testOnCi.js';\nimport { tcCommand, typeCheckCommand } from './commands/typecheck.js';\nimport { sharedOptionsBuilder } from './sharedOptionsBuilder.js';\n\nawait yargs(hideBin(process.argv))\n  .scriptName('wb')\n  .options(sharedOptionsBuilder)\n  .middleware((argv) => {\n    const workingDir = argv['working-dir'];\n    if (workingDir) {\n      const dirPath = path.resolve(workingDir);\n      process.chdir(dirPath);\n    }\n\n    removeNpmAndYarnEnvironmentVariables(process.env);\n  })\n  .command(buildIfNeededCommand)\n  .command(killPortIfNonCiCommand)\n  .command(lintCommand)\n  .command(optimizeForDockerBuildCommand)\n  .command(prismaCommand)\n  .command(retryCommand)\n  .command(setupCommand)\n  .command(startCommand)\n  .command(testCommand)\n  .command(testOnCiCommand)\n  .command(typeCheckCommand)\n  .command(tcCommand)\n  .demandCommand()\n  .strict()\n  .version(getVersion())\n  .help().argv;\n\nfunction getVersion(): string {\n  let packageJsonDir = path.dirname(new URL(import.meta.url).pathname);\n  while (!fs.existsSync(path.join(packageJsonDir, 'package.json'))) {\n    packageJsonDir = path.dirname(packageJsonDir);\n  }\n  const packageJson = JSON.parse(fs.readFileSync(path.join(packageJsonDir, 'package.json'), 'utf8')) as {\n    version: string;\n  };\n  return packageJson.version;\n}\n\nfor (const signal of ['SIGINT', 'SIGTERM', 'SIGQUIT']) {\n  process.on(signal, () => {\n    treeKill(process.pid);\n    process.exit();\n  });\n}\n"],"names":["cachedEnvVars","Map","readEnvFile","filePath","cached","get","parsed","config","path","resolve","processEnv","set","async","spawnAsync","command","args","options","Promise","reject","proc","spawn","stdout","setEncoding","stderr","on","data","printingStdout","process","write","mergeOutAndError","printingStderr","stopped","stopProcess","pid","verbose","console","info","treeKill","killOnExit","error","removeListener","removeAllListeners","code","signal","undefined","Error","status","input","stdin","end","t","s","i","e","n","entries","h","blocks","reset","finalized","block","start","lastByteIndex","constructor","this","padding","outputBits","blockCount","byteCount","outputBlocks","extraBytes","update","o","length","l","c","f","codePointAt","r","finalize","hex","a","u","d","b","k","y","x","B","p","C","z","I","g","w","A","P","E","j","m","q","v","D","F","G","H","J","K","L","M","N","O","Q","R","S","T","U","V","W","X","Y","Z","$","_","tt","st","it","et","ot","nt","ht","rt","lt","ct","ft","instance","from","name","message","stack","push","cause","stub","hydrate","Uint8Array","btoa","decode","create","encode","atob","Set","values","add","Date","toJSON","RegExp","flags","source","URL","href","map","TextEncoder","TextDecoder","JSON","stringify","Number","isNaN","isFinite","toString","Array","isArray","fill","slice","Object","cacheDuration","POSITIVE_INFINITY","getCacheKey","kind","now","call","isCI","ciEnv","Project","_initProto","_applyDecs","memoizeOne","argv","pathByName","dirPath","loadEnv","_dirPath","isBunAvailable","test","fs","readFileSync","join","rootDirPath","buildCommand","packageJson","scripts","build","includes","existsSync","dockerfile","findFile","hasDockerfile","hasSourceCode","dockerImageName","replaceAll","env","envVars","envPathAndLoadedEnvVarCountPairs","cwd","envPaths","envPath","cascade","cascadeEnv","cascadeNodeEnv","NODE_ENV","autoCascadeEnv","WB_ENV","includeRootEnv","rootPath","flatMap","filter","relative","envPathAndEnvVarCountPairs","count","key","value","checkEnv","missingKeys","keys","expand","readEnvironmentVariables","parse","packageJsonPath","hasPrisma","dependencies","prisma","devDependencies","hasVitest","vitest","skipLaunchingServerForPlaywright","CI","configPath","dockerPackageJson","dirname","binExists","binFound","currentPath","binPath","PATH","parentPath","fileName","find","findSelfProject","findDescendantProjects","rootAndSelfProjects","thisProject","rootProject","workspaces","endsWith","root","self","findRootAndSelfProjects","descendants","getAllDescendantProjects","projects","workspace","globPattern","packageDirs","workspacePath","ws","globby","dot","onlyDirectories","subPackageDirPath","isRunningOnBun","versions","bun","npm_execpath","runtimeWithArgs","packageManager","packageManagerWithRun","buildIfNeededCommand","describe","description","type","alias","handler","projectPathForTesting","project","chalk","red","canSkip","cacheFilePath","contentHash","cacheDirectoryPath","promises","mkdir","recursive","hash","createHash","commitHash","child_process","execSync","trim","environmentJson","ignoringEnvVarNames","has","toSorted","key1","key2","localeCompare","filteredFilePaths","spawnSync","stdio","encoding","split","line","replace","includePatterns","some","pattern","includeSuffix","suffix","excludePatterns","copy","digest","updateHashWithDiffResult","cachedContentHash","fn","ignoreEnoentAsync","readFile","canSkipBuild","green","dryRun","writeFile","buildIfNeeded","ret","shell","exitCode","killPortIfNonCiCommand","builder","exit","portEnv","PORT","port","isInteger","killPortProcess","killPortIfNonCi","promisePool","PromisePool","defaultOptions","exitIfFailed","runWithSpawn","script","opts","normalizedScript","normalizeScript","printStart","printable","runnable","printFinishedAndExitIfNeeded","configureEnv","timeout","onSignal","runWithSpawnInParallel","runAndWaitForReturnValue","out","newScript","blitz","printableScript","fixBunCommand","runnableScript","cascadeOption","prefix","weak","gray","cyan","bold","newEnv","ci","forceColor","FORCE_COLOR","biomeExtensions","prettierExtensions","prettierOnlyExtensions","ext","lintCommand","fix","format","files","biomeArgsText","prettierArgsText","sortPackageJsonArgsText","filePathsToBeCheckedByBiome","filePathsToBeFormattedByPrettier","packageJsonFilePaths","file","String","extension","extname","biomeCommand","biomePromise","prepareForRunningCommand","commandName","optimizeForDockerBuildCommand","outside","deps","startsWith","optimizeDevDependencies","optimizeScripts","optimizeRootProps","distDirPath","devDeps","nameWordsToBeRemoved","removedDeps","word","nameWordsOfUnnecessaryScripts","contentWordsOfUnnecessaryScripts","removedScripts","content","private","publishConfig","prettier","getDatabaseDirPath","prismaScripts","cleanUpLitestream","deploy","additionalOptions","deployForce","listBackups","migrate","seed","migrateDev","restore","outputPath","scriptPath","studio","dbUrlOrPath","FILE_SCHEMA","DATABASE_URL","POSSIBLE_PATHS","schemaPath","dbPath","sharedOptionsBuilder","default","prismaCommand","yargs","cleanUpLitestreamCommand","createLitestreamConfigCommand","deployCommand","deployForceCommand","listBackupsCommand","migrateCommand","migrateDevCommand","resetCommand","restoreCommand","seedCommand","studioCommand","defaultCommand","demandCommand","strict","allProjects","findPrismaProjects","createLitestreamConfig","unknownOptions","extractUnknownOptions","output","restored","fullCommand","trimEnd","Boolean","requiredEnvVars","CLOUDFLARE_R2_LITESTREAM_ACCOUNT_ID","CLOUDFLARE_R2_LITESTREAM_BUCKET_NAME","CLOUDFLARE_R2_LITESTREAM_ACCESS_KEY_ID","CLOUDFLARE_R2_LITESTREAM_SECRET_ACCESS_KEY","missingEnvVars","retentionCheckInterval","litestreamConfig","writeFileSync","reason","filtered","knownOptions","sharedOptionKeys","sharedOptionAliases","option","allKnownOptions","kebabCaseKey","match","toLowerCase","item","retryCommand","retry","cmdAndArgs","lastStatus","yellow","setupCommand","dirents","readdir","withFileTypes","os","platform","packages","isFile","version","promiseAll","playwright","setup","toDevNull","silent","killed","killPortProcessImmediatelyAndOnExit","available","host","probePort","isPortAvailable","killPortContainerAndProcess","killFunc","filterArgs","containerIds","id","listDockerContainerIds","removeDockerContainers","stopDockerContainerByPort","checkAndKillPortProcess","rawPort","server","createServer","once","err","close","listen","dockerScripts","buildImage","stopAndStart","additionalArgs","stop","spawnSyncOnExit","stopAll","BaseScripts","shouldWaitAndOpenApp","buildDocker","startDev","startDevProtected","waitAndOpenApp","startProduction","startProductionProtected","startTest","startDocker","normalizedDockerOptionsText","normalizedArgsText","ecosystemConfigPath","findEcosystemConfigPath","commands","cmd","testE2EDev","testE2EProtected","testE2EProduction","testE2EDocker","testStart","waitApp","startCommand","playwrightArgs","playwrightCommand","targets","base","target","rest","parts","unshift","buildPlaywrightCommand","testUnit","testTarget","blitzScripts","super","httpServerScripts","watch","nextScripts","plainAppScripts","_1","_2","remixScripts","httpServerPackages","mode","arg","dockerOptions","normalizeArgs","next","testCommand","e2e","choices","testTargets","shouldRunAllTests","hasE2eTargets","hasUnitTargets","shouldRunUnit","shouldRunE2e","unitTargets","unitArgv","unitTimeout","e2eTargets","e2eArgv","testOnDocker","e2eTarget","WB_DOCKER","testOnCiCommand","testOnCi","typeCheckCommand","removedNextDir","typescript","pyright","nextDirPath","rmSync","force","exitCodes","all","finalExitCode","tcCommand","hideBin","scriptName","middleware","workingDir","chdir","BERRY_BIN_FOLDER","upperKey","toUpperCase","removeNpmAndYarnEnvironmentVariables","packageJsonDir","url","pathname","getVersion","help"],"mappings":"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","x_google_ignoreList":[2,3,4,5,6]}
|