@willbooster/wb 7.8.10 → 7.8.11
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 +2 -2
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import e from"node:path";import t from"yargs";import{hideBin as n}from"yargs/helpers";import r,{spawn as s,spawnSync as o}from"node:child_process";import{createHash as i}from"node:crypto";import a from"node:fs";import c from"chalk";import{globby as d}from"globby";import{config as l}from"dotenv";import u from"kill-port";import{PromisePool as p}from"minimal-promise-pool";import m from"tree-kill";import f from"node:fs/promises";import h from"node:os";function g(t,n,r=!0){let s=(t.env??[]).map((t=>e.resolve(n,t.toString())));const o=t.cascadeEnv??(t.cascadeNodeEnv?process.env.NODE_ENV||"development":t.autoCascadeEnv?process.env.WB_ENV||process.env.NODE_ENV||"development":void 0);if("string"==typeof o){if(0===s.length&&(s.push(e.join(n,".env")),t.includeRootEnv)){const t=e.resolve(n,"..","..");a.existsSync(e.join(t,"package.json"))&&s.push(e.join(t,".env"))}s=s.flatMap((e=>o?[`${e}.${o}.local`,`${e}.local`,`${e}.${o}`,e]:[`${e}.local`,e]))}s=s.map((t=>e.relative(n,t))),t.verbose&&(console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`),console.info("Reading env files:",s));let i={};const c={...process.env};for(const t of s){i={...y(e.join(n,t),r),...i};let s=0;for(const[e,t]of Object.entries(i))c[e]!==t&&(c[e]=t,s++);s>0&&console.info(`Read ${s} environment variables:`,t)}if(t.checkEnv){const o=Object.keys(y(e.join(n,t.checkEnv),r)||{}).filter((e=>!(e in i)));if(o.length>0)throw new Error(`Missing environment variables in [${s.join(", ")}]: [${o.join(", ")}]`)}return i}const w=new Map;function y(t,n=!0){const r=n&&w.get(t);if(r)return r;const s=l({path:e.resolve(t),processEnv:{}}).parsed??{};return n&&w.set(t,s),s}async function b(e,t,n){return new Promise(((r,o)=>{try{const i=s(e,t??[],n??{});i.stdout?.setEncoding?.("utf8"),i.stderr?.setEncoding?.("utf8");let a="",c="";i.stdout?.on("data",(e=>{a+=e})),i.stderr?.on("data",(e=>{n?.mergeOutAndError?a+=e:c+=e}));let d=!1;const l=()=>{!d&&i.pid&&(d=!0,n?.verbose&&console.info(`treeKill(${i.pid})`),m(i.pid))};n?.killOnExit&&(process.on("beforeExit",l),process.on("SIGINT",l)),i.on("error",(e=>{process.removeListener("beforeExit",l),process.removeListener("SIGINT",l),i.removeAllListeners("close"),o(e)})),i.on("close",((e,t)=>{process.removeListener("beforeExit",l),process.removeListener("SIGINT",l),void 0===i.pid?o(new Error("Process has no pid.")):r({pid:i.pid,stdout:a,stderr:c,status:e,signal:t})})),n?.input&&(i.stdin?.write(n.input),i.stdin?.end())}catch(e){o(e)}}))}function v(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 k(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 $(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||"default");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+""}let E;const A=function({cacheDuration:e=Number.POSITIVE_INFINITY,caches:t,calcKey:n=e=>function(e,t=0){const[n,r]=function(e,t=0){let n=3735928559^t,r=1103547991^t;for(let t,s=0;s<e.length;s++)t=e.codePointAt(s),n=Math.imul(n^t,2654435761),r=Math.imul(r^t,1597334677);return n=Math.imul(n^n>>>16,2246822507),n^=Math.imul(r^r>>>13,3266489909),r=Math.imul(r^r>>>16,2246822507),r^=Math.imul(n^n>>>13,3266489909),[r>>>0,n>>>0]}(e,t);return e.length.toString(36)+n.toString(36).padStart(7,"0")+r.toString(36).padStart(7,"0")}(JSON.stringify(e)),maxCachedArgsSize:r=100,maxCachedThisSize:s=10}={}){return function(o,i){if("getter"===i?.kind){const n=new Map;return t?.push(n),function(){const t=Date.now();if(n.has(this)){const[r,s]=n.get(this);if(t-s<=e)return r}const r=o.call(this);if(n.size>=s){const e=n.keys().next().value;n.delete(e)}return n.set(this,[r,t]),r}}{const a=new Map;return t?.push(a),function(...t){const c=n(t);let d=a.get(this);const l=Date.now();if(d){if(d.has(c)){const[t,n]=d.get(c);if(l-n<=e)return t}}else{if(d=new Map,a.size>=s){const e=a.keys().next().value;a.delete(e)}a.set(this,d)}const u=i?o.call(this,...t):o(...t);if(d.size>=r){const e=d.keys().next().value;d.delete(e)}return d.set(c,[u,l]),u}}}}({maxCachedThisSize:Number.MAX_SAFE_INTEGER,maxCachedArgsSize:1});class N{static{[E]=function(e,t,n,r,s){var o,i,a,c,d,l,u,p=Symbol.metadata||Symbol.for("Symbol.metadata"),m=Object.defineProperty,f=Object.create,h=[f(null),f(null)],g=t.length;function w(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 y(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 b(e,t,n,r,s,a,c,d,l,u,p){function f(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),b=t[3],v=!c,$=1===s,E=3===s,A=4===s,N=2===s;function x(t,n,r){return function(s,o){return n&&(o=s,s=e),r&&r(s),P[t].call(s,o)}}if(!v){var P={},j=[],S=E?"get":A||$?"set":"value";if(l?(u||$?P={get:k((function(){return b(this)}),r,"get"),set:function(e){t[4](this,e)}}:P[S]=b,u||k(P[S],r,N?"":S)):u||(P=Object.getOwnPropertyDescriptor(e,r)),!u&&!l){if((i=h[+d][r])&&7!=(i^s))throw Error("Decorating two elements with the same name ("+P[S].name+") is not supported yet");h[+d][r]=s<3?1:s}}for(var D=e,R=g.length-1;R>=0;R-=n?2:1){var _=y(g[R],"A decorator","be",!0),O=n?g[R-1]:void 0,T={},B={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");y(t,"An initializer","be",!0),a.push(t)}.bind(null,T)};if(v)i=_.call(O,D,B),T.v=1,y(i,"class decorators","return")&&(D=i);else if(B.static=d,B.private=l,i=B.access={has:l?p.bind():function(e){return r in e}},A||(i.get=l?N?function(e){return f(e),P.value}:x("get",0,f):function(e){return e[r]}),N||E||(i.set=l?x("set",0,f):function(e,t){e[r]=t}),D=_.call(O,$?{get:P.get,set:P.set}:P[S],B),T.v=1,$){if("object"==typeof D&&D)(i=y(D.get,"accessor.get"))&&(P.get=i),(i=y(D.set,"accessor.set"))&&(P.set=i),(i=y(D.init,"accessor.init"))&&j.unshift(i);else if(void 0!==D)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(D,(u?"field":"method")+" decorators","return")&&(u?j.unshift(D):P[S]=D)}return s<2&&c.push(w(j,d,1),w(a,d,0)),u||v||(l?$?c.splice(-1,0,x("get",d),x("set",d)):c.push(N?P[S]:y.call.bind(P[S])):m(e,r,P)),D}function E(e){return m(e,p,{configurable:!0,enumerable:!0,value:o})}return o=f(null==o?null:o),d=[],l=function(e){e&&d.push(w(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],m=!!i[3],f=16&l;b(t?e:e.prototype,i,f,m?"#"+p:$(p),u,u<2?[]:t?c=c||[]:a=a||[],d,!!t,m,r,t&&m?function(t){return v(t)===e}:s)}}},u(8,0),u(0,0),u(8,1),u(0,1),l(a),l(c),i=d,g||E(e),{e:i,get c(){var n=[];return g&&[E(e=b(e,[t],r,e.name,5,n)),w(n,1)]}}}(this,[],[[A,3,"isBunAvailable"],[A,3,"buildCommand"],[A,3,"rootDirPath"],[A,3,"dockerfile"],[A,3,"hasDockerfile"],[A,3,"hasSourceCode"],[A,3,"name"],[A,3,"dockerImageName"],[A,3,"env"],[A,3,"packageJson"],[A,3,"packageJsonPath"],[A,3,"hasPrisma"],[A,3,"dockerPackageJson"],[A,3,"binExists"]]).e}argv=void E(this);pathByName=new Map;constructor(t,n,r){this._dirPath=e.resolve(t),this.argv=n,this.loadEnv=r}get isBunAvailable(){try{return/(^|\n)bun\s/.test(a.readFileSync(e.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 a.existsSync(e.join(this.dirPath,"..","..","package.json"))?e.resolve(this.dirPath,"..",".."):this.dirPath}get dockerfile(){return a.readFileSync(this.findFile("Dockerfile"),"utf8")}get hasDockerfile(){try{return!!this.findFile("Dockerfile")}catch{return!1}}get hasSourceCode(){return a.existsSync(e.join(this.dirPath,"src"))}get name(){return this.packageJson.name||"unknown"}get dockerImageName(){return(this.packageJson.name||"unknown").replaceAll("@","").replaceAll("/","-")}get env(){return this.loadEnv?{...g(this.argv,this.dirPath),...process.env}:process.env}get packageJson(){return JSON.parse(a.readFileSync(this.packageJsonPath,"utf8"))}get packageJsonPath(){return e.join(this.dirPath,"package.json")}get hasPrisma(){return!(!this.packageJson.dependencies?.prisma&&!this.packageJson.devDependencies?.prisma)}get dockerPackageJson(){return e.dirname(this.findFile("Dockerfile"))===this.dirPath?this.packageJson:JSON.parse(a.readFileSync(e.join(e.dirname(this.findFile("Dockerfile")),"package.json"),"utf8"))}get binExists(){let t=!1,n=this.dirPath;for(;;){const r=e.join(n,"node_modules",".bin");if(a.existsSync(r)&&(this.env.PATH=`${r}:${this.env.PATH}`,t=!0),a.existsSync(e.join(n,".git")))break;const s=e.dirname(n);if(n===s)break;n=s}return t}findFile(t){let n=this.pathByName.get(t);if(n)return n;if(n=[t,e.join("..","..",t)].map((t=>e.resolve(this.dirPath,t))).find((e=>a.existsSync(e))),!n)throw new Error(`File not found: ${t}`);return this.pathByName.set(t,n),n}}function x(t,n=!0,r){if(r??=process.cwd(),a.existsSync(e.join(r,"package.json")))return new N(r,t,n)}async function P(t,n=!0,r){const s=function(t,n=!0,r){if(r??=process.cwd(),!a.existsSync(e.join(r,"package.json")))return;const s=new N(r,t,n);let o=s;if(!s.packageJson.workspaces&&e.dirname(r).endsWith("/packages")){const s=e.resolve(r,"..","..");a.existsSync(e.join(s,"package.json"))&&(o=new N(s,t,n))}return{root:o,self:s}}(t,n,r);if(s)return{...s,descendants:s.root===s.self?await j(t,s.root,n):[s.self]}}async function j(t,n,r){const s=[n],o=n.packageJson.workspaces;if(!Array.isArray(o))return s;const i=[],c=[];for(const t of o.map((t=>e.join(n.dirPath,t))))a.existsSync(t)?c.push(t):i.push(t);c.push(...await d(i,{dot:!0,onlyDirectories:!0}));for(const n of c)a.existsSync(e.join(n,"package.json"))&&s.push(new N(n,t,r));return s}const S=process.argv[0].endsWith("/bun")||process.env.npm_execpath?.endsWith("/bun"),D=S?"bun --bun run":"node",R=S?"bun":"yarn",_=S?"bun --bun run":"yarn",O={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(t){await async function(t,n){const s=await x(t,!0,n);if(!s)return console.error(c.red("No project found.")),!0;if(!a.existsSync(e.join(s.rootDirPath,".git")))return T(s,t),!0;const[o,d,l]=await async function(t,n){const s=e.resolve(t.dirPath,"node_modules",".cache","build"),o=e.resolve(s,"last-build");await a.promises.mkdir(s,{recursive:!0});const c=i("sha256"),d=r.execSync("git rev-parse HEAD",{cwd:t.dirPath}).toString().trim();c.update(d);const l=JSON.stringify(Object.entries(t.env).filter((([e])=>!B.has(e))).sort((([e],[t])=>e.localeCompare(t))));c.update(l),await async function(e,t,n){return new Promise((s=>{const o=r.spawnSync("git",["diff","--name-only"],{cwd:e.dirPath,env:e.env,stdio:"pipe",encoding:"utf8"}).stdout.trim().split("\n").map((t=>"test"===e.env.WB_ENV?t.replace(/packages\/scripts\/test-fixtures\/[^/]+\//,""):t)).filter((e=>(I.some((t=>e.includes(t)))||C.some((t=>e.endsWith(t))))&&!W.some((t=>e.includes(t)))));t.verbose&&console.info(`Changed files: ${o.join(", ")}`);const i=r.spawn("git",["diff","--",...o],{cwd:e.rootDirPath});i.stdout?.on("data",(e=>{n.update(e),t.verbose&&(console.info(e.toString()),console.info("Hash:",n.copy().digest("hex")))})),i.on("close",(()=>{s()}))}))}(t,n,c);const u=c.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}}((()=>a.promises.readFile(o,"utf8")));return[p===u,o,u]}(s,t);if(o)return console.info(c.green(`Skip to run '${t.command}' 💫`)),!1;if(!T(s,t))return;t.dryRun||await a.promises.writeFile(d,l,"utf8");return!0}(t)}};function T(e,t){if(t={...t,command:t.command??(S?"bun run build":"yarn build")},console.info(c.green(`Run '${t.command}'`)),!t.dryRun){const n=r.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 B=new Set(["CI","PWDEBUG","TMPDIR"]);const I=["src/","public/"],C=[".js",".cjs",".mjs",".jsx",".ts",".cts",".mts",".tsx",".json",".browserslistrc","package.json","yarn.lock"],W=["test/","tests/","__tests__/","test-fixtures/"];const z=new Set;async function V(e){try{await u(e)}catch{}}const J=new p,F={exitIfFailed:!0};async function Y(e,t,n,r=F){const[s,o]=U(e,t);if(L(s,t),n.verbose&&L(o,t,"Start (raw)",!0),n.dryRun)return G(s,0,r),0;const i=o.match(/http-get:\/\/127.0.0.1:(\d+)/)?.[1];o.includes("wait-on")&&i&&!o.includes("docker run")&&await async function(e){await V(e);const t=async()=>{z.has(e)||(z.add(e),await V(e))};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,t)}(Number(i));const a=await b(o,void 0,{cwd:t.dirPath,env:q(t.env,r),shell:!0,stdio:"inherit",timeout:r?.timeout,killOnExit:!0,verbose:n.verbose});return G(s,a.status,r),a.status??1}function M(e,t,n,r=F){return J.runAndWaitForReturnValue((async()=>{const[s,o]=U(e,t);if(L(s,t,"Start (parallel)",!0),n.dryRun)return L(s,t,"Started (log)"),n.verbose&&L(o,t,"Started (raw)",!0),G(s,0,r),0;const i=await b(o,void 0,{cwd:t.dirPath,env:q(t.env,r),shell:!0,stdio:"pipe",timeout:r?.timeout,mergeOutAndError:!0,killOnExit:!0,verbose:n.verbose});L(s,t,"Started (log)"),n.verbose&&L(o,t,"Started (raw)",!0);const a=i.stdout.trim();return a&&(process.stdout.write(a),process.stdout.write("\n")),G(s,i.status,r),i.status??1}))}function U(e,t){let n=e.replaceAll("\n","").replaceAll(/\s\s+/g," ").replaceAll("PRISMA ",t.packageJson.dependencies?.blitz?"YARN blitz prisma ":"YARN prisma ").replaceAll("BUN ",t.isBunAvailable?"bun --bun run ":"YARN ").replaceAll("YARN run ",t.isBunAvailable?"bun --bun run ":"yarn run ");return S&&(n=n.replaceAll("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(),[H(n.replaceAll("YARN ",`${_} `)),H(n.replaceAll("YARN ",!S&&t.binExists?"":`${_} `))]}function L(e,t,n="Start",r=!1){console.info("\n"+(r?c.gray:c.cyan)(c.bold(`${n}:`),e)+c.gray(` at ${t.dirPath}`))}function G(e,t,n){0===t?console.info(c.green(c.bold("Finished:"),e)):(console.info(c.red(c.bold(`Failed (exit code ${t}): `),e)),!1!==n.exitIfFailed&&process.exit(t??1))}function q(e,t){const n={...e};return t.ci&&(n.CI="1"),t.forceColor&&(n.FORCE_COLOR="3"),n}function H(e){return e.includes("next dev")||e.includes("pm2-runtime")?e.replaceAll("bun --bun","bun"):e}const X=new Set(["cjs","cts","js","json","jsonc","jsx","mjs","mts","ts","tsx"]),K=new Set(["cjs","cts","htm","html","js","json","jsonc","jsx","md","mjs","mts","scss","ts","tsx","vue","yaml","yml"]),Q=new Set([...K].filter((e=>!X.has(e)))),Z={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(t){S||(console.error(c.red("This command is only available on Bun.")),process.exit(1));const n=await P(t,!1);n||(console.error(c.red("No project found.")),process.exit(1));const r=t.files??[];let s,o,i;if(r.length>0){const t=[],n=[],a=[];for(const s of r){const r=e.resolve(String(s));if(r.endsWith("/test-fixtures")||r.includes("/test-fixtures/"))continue;const o=e.extname(r).slice(1);r.endsWith("/package.json")?a.push(r):X.has(o)?t.push(r):K.has(o)&&n.push(r)}s=t.map((e=>`"${e}"`)).join(" "),o=n.map((e=>`"${e}"`)).join(" "),i=a.map((e=>`"${e}"`)).join(" ")}else s="",o=`"**/{.*/,}*.{${[...Q].join(",")}" "!**/test-fixtures/**"`,i=n.descendants.map((e=>`"${e.packageJsonPath}"`)).join(" ");const a=t.fix&&t.format?"check --fix":t.fix?"lint --fix":"lint";let d;(s||0===r.length)&&(d=M(`bun --bun biome ${a} --colors=force --no-errors-on-unmatched --files-ignore-unknown=true ${s}`,n.self,t,{forceColor:!0})),t.format&&(o&&M(`bun --bun prettier --cache --color --no-error-on-unmatched-pattern --write ${o}`,n.self,t,{forceColor:!0}),i&&(await d,M(`bun --bun sort-package-json ${i}`,n.self,t,{forceColor:!0})))}};function*ee(e,t){for(const n of t)console.info(`Running "${e}" for ${n.name} ...`),yield n}const te={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(t){const n=await P(t);n||(console.error(c.red("No project found.")),process.exit(1));for(const r of ee("optimizeForDockerBuild",n.descendants)){const n=r.packageJson,s=["dependencies","devDependencies"];for(const e of s){const t=n[e]||{};for(const[e,n]of Object.entries(t))n?.startsWith("git@github.com:")&&(t[e]=`./${e}`)}if(ne(t,n),re(n),se(n),t.dryRun)continue;const o=t.outside?e.join(r.dirPath,"dist"):r.dirPath;await a.promises.mkdir(o,{recursive:!0}),await a.promises.writeFile(e.join(o,"package.json"),JSON.stringify(n),"utf8")}t.dryRun||t.outside||r.spawnSync("yarn",{stdio:"inherit"})}};function ne(e,t){if(!e.outside)return void delete t.devDependencies;const n=t.devDependencies||{},r=["artillery","concurrently","conventional-changelog-conventionalcommits","eslint","husky","imagemin","jest","kill-port","lint-staged","open-cli","playwright","prettier","pinst","sort-package-json","wait-on","semantic-release","vitest"];for(const t of Object.keys(n))(r.some((e=>t.includes(e)))||!e.outside&&t.includes("willbooster")&&t.includes("config"))&&delete n[t]}function re(e){const t=["check","deploy","format","lint","start","test"],n=["pinst ","husky "],r=e.scripts||{};for(const[e,s]of Object.entries(r))(t.some((t=>e.includes(t)))||n.some((e=>s.includes(e)||s.trim()===e.trim())))&&delete r[e]}function se(e){delete e.private,delete e.publishConfig,delete e.prettier}const oe=new class{deploy(e){return"PRISMA migrate deploy"}deployForce(e,t){const n=e.packageJson.dependencies?.blitz?"db":"prisma";return`rm -Rf ${n}/mount/prod.sqlite3*; PRISMA migrate reset --force && rm -Rf ${n}/mount/prod.sqlite3*\n && litestream restore -o ${n}/mount/prod.sqlite3 ${t} && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`}litestream(e){return`${D} -e '\nconst { PrismaClient } = require("@prisma/client");\nnew PrismaClient().$queryRaw\`PRAGMA journal_mode = WAL;\`\n .catch((error) => { console.log("Failed due to:", error); process.exit(1); });\n'`}migrate(e){return`PRISMA migrate deploy && PRISMA generate && ${this.seed(e)}`}migrateDev(e){return"PRISMA migrate dev"}reset(e){return`PRISMA migrate reset --force --skip-seed && ${this.seed(e)}`}restore(e,t,n){return`rm -Rf ${e.packageJson.dependencies?.blitz?"db":"prisma"}/restored.sqlite3; GOOGLE_APPLICATION_CREDENTIALS=gcp-sa-key.json litestream restore -o ${n} ${t}`}seed(e,t){return e.packageJson.dependencies?.blitz?"YARN blitz db seed"+(t?` -f ${t}`:""):t?"BUN build-ts run prisma/seeds.ts":e.packageJson.prisma?.seed?"YARN prisma db seed":'if [ -e "prisma/seeds.ts" ]; then BUN build-ts run prisma/seeds.ts; fi'}studio(t,n){let r="";if(n)try{new URL(n),r=`DATABASE_URL=${n} `}catch{const t=e.resolve(n);console.info(n,t),r=`DATABASE_URL=file://${t} `}return`${r}PRISMA studio`}},ie={},ae={command:"prisma",describe:"Run prisma commands",builder:e=>e.command(ce).command(le).command(ue).command(pe).command(me).command(fe).command(he).command(ge).command(we).command(ye).demandCommand(),handler(){}},ce={command:"deploy",describe:"Apply migration to DB without initializing it",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma deploy",t))await Y(oe.deploy(n),n,e)}},de={...ie,"backup-path":{description:"Whether to skip actual command execution",demandOption:!0,type:"string",alias:"b"}},le={command:"deploy-force <backup-path>",describe:"Force to apply migration to DB utilizing Litestream's backup without initializing it",builder:de,async handler(e){const t=await be(e);for(const n of ee("prisma deploy-force",t))await Y(oe.deployForce(n,e.backupPath),n,e)}},ue={command:"litestream",describe:"Setup DB for Litestream",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma litestream",t))await Y(oe.litestream(n),n,e)}},pe={command:"migrate",describe:"Apply migration to DB with initializing it",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma migrate",t))await Y(oe.migrate(n),n,e)}},me={command:"migrate-dev",describe:"Create a migration file",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma migrate-dev",t))await Y(oe.migrateDev(n),n,e)}},fe={command:"reset",describe:"Reset DB",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma reset",t))await Y(oe.reset(n),n,e)}},he={command:"restore <backup-path>",describe:"Restore DB from Litestream's backup",builder:{...de,output:{description:'Output path of the restored database. Defaults to "<db|prisma>/restored.sqlite3".',type:"string"}},async handler(e){const t=await be(e);for(const n of ee("prisma restore",t)){const t=e.output||(n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3");await Y(oe.restore(n,e.backupPath,t),n,e)}}},ge={command:"seed",describe:"Populate DB with seed data",builder:{...ie,file:{alias:"f",description:"Path of the seed script.",type:"string"}},async handler(e){const t=await be(e);for(const n of ee("prisma seed",t))await Y(oe.seed(n,e.file),n,e)}},we={command:"studio [db-url-or-path]",describe:"Open Prisma Studio",builder:{...ie,"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 be(e);for(const n of ee("prisma studio",t)){const t=e.restored?n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3":e.dbUrlOrPath?.toString();await Y(oe.studio(n,t),n,e)}}},ye={command:"$0 [args..]",describe:"Pass the command and arguments to prisma as is",builder:{args:{type:"array"}},async handler(e){const t=await be(e),n=`${e.args?.join(" ")??""}`.trimEnd();for(const r of ee(`prisma ${n}`,t))await Y(`PRISMA ${n}`,r,e)}};async function be(e){const t=await P(e);t||(console.error(c.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(c.red("No prisma project found.")),process.exit(1)),n}const ve={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=x(e);t||(console.error(c.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${c.yellow(`#${s} Retrying: ${n.join(" ")}`)}`),r=await Y(n.join(" "),t,e,{exitIfFailed:!1}),0===r)return;process.exit(r)}},ke=["express","fastify","elysia"],$e={command:"setup",describe:"Setup development environment. .env files are ignored.",builder:{},async handler(e){await async function(e,t){const n=await P(e,!1,t);n||(console.error(c.red("No project found.")),process.exit(1));for(const t of ee("setup",n.descendants)){const s=await f.readdir(t.dirPath,{withFileTypes:!0});if(t===n.root){if("darwin"===h.platform()){const n=["pstree"];t.hasDockerfile&&n.push("expect"),await M(`brew install ${n.join(" ")}`,t,e)}s.some((e=>e.isFile()&&e.name.includes("-version")))&&await Y("asdf install",t,e)}if(s.some((e=>e.isFile()&&"pyproject.toml"===e.name))){await M("poetry config virtualenvs.in-project true",t,e),await M("poetry config virtualenvs.prefer-active-python true",t,e);const[,n]=r.execSync("asdf current python").toString().trim().split(/\s+/);await M(`poetry env use ${n}`,t,e),await J.promiseAll(),await Y("poetry run pip install --upgrade pip",t,e),await Y("poetry install --ansi",t,e)}const o=t.packageJson.dependencies??{},i=t.packageJson.devDependencies||{},a=t.packageJson.scripts??{},c=[];let d=[];o.blitz||o.next||i["@remix-run/dev"]?(c.push("pm2"),d.push("concurrently","open-cli","vitest","wait-on")):ke.some((e=>o[e]))&&(c.push("pm2"),d.push("concurrently","vitest","wait-on")),S&&(d=d.filter((e=>"vitest"!==e))),c.length>0&&await Y(`${R} add ${c.join(" ")}`,t,e),d.length>0&&await Y(`${R} add -D ${d.join(" ")}`,t,e),a["gen-code"]&&await Y(`${_} gen-code`,t,e)}}(e)}};const Ee=new class{buildDevImage(t,n){const r=t.dockerPackageJson.scripts?.["docker/build/prepare"]?"yarn run docker/build/prepare && ":"";return`cd ${e.dirname(t.findFile("Dockerfile"))}\n && ${r}YARN wb optimizeForDockerBuild --outside\n && YARN wb retry -- docker build -t ${t.dockerImageName}\n --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo amd64)\n --build-arg WB_ENV=${t.env.WB_ENV}\n --build-arg WB_VERSION=${n} .`}stopAndStart(e,t=!1,n="",r=""){return`${this.stop(e)} && ${t?"unbuffer ":""}${this.start(e,n,r)}`}start(e,t="",n=""){return function(e,t){const n=async()=>{if(z.has(e))return;z.add(e),L(e,t);const{status:n}=o(e,{cwd:t.dirPath,shell:!0,stdio:"inherit"});G(e,n,{})};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,n)}(this.stop(e),e),`docker run --rm -it -p 8080: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 Ae{constructor(e=Number(process.env.PORT)||3e3){this.defaultPort=e}buildDocker(e,t="development"){return Ee.buildDevImage(e,t)}startDocker(e,t){return`${this.buildDocker(e)}\n && YARN concurrently --raw --kill-others-on-fail\n "${Ee.stopAndStart(e,!1,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}"\n "${this.waitAndOpenApp(e,t,8080)}"`}testE2E(e,t,{playwrightArgs:n="test tests/e2e",prismaDirectory:r,startCommand:s}){const o=e.env.WB_ENV;return`WB_ENV=${o} NEXT_PUBLIC_WB_ENV=${o} APP_ENV=${o} PORT=8080 YARN concurrently --kill-others --raw --success first\n "rm -Rf ${r}/mount && ${s} && exit 1"\n "concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n && BUN playwright ${"test tests/e2e"===n&&t.target?n.replace("tests/e2e",t.target):n}"`}testE2EDev(e,t,{playwrightArgs:n="test tests/e2e",startCommand:r}){const s=e.env.WB_ENV;return`WB_ENV=${s} NEXT_PUBLIC_WB_ENV=${s} APP_ENV=${s} PORT=8080 YARN concurrently --kill-others --raw --success first\n "${r} && exit 1"\n "concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n && BUN playwright ${"test tests/e2e"===n&&t.target?n.replace("tests/e2e",t.target):n}"`}testUnit(e,t){return`WB_ENV=${e.env.WB_ENV} YARN vitest run ${t.target||"tests/unit"} --color --passWithNoTests --allowOnly`}waitApp(e,t,n=this.defaultPort){return`wait-on -t 10000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 10000 -i 500 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${n}`}waitAndOpenApp(e,t,n=this.defaultPort){return`${this.waitApp(e,t,n)} || wait-on http-get://127.0.0.1:${n} && open-cli http://\${HOST:-localhost}:${n}`}}const Ne=new class extends Ae{constructor(){super()}start(e,t){return`${e.env.WB_ENV?`APP_ENV=${e.env.WB_ENV} `:""}YARN concurrently --raw --kill-others-on-fail\n "blitz dev ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t)}"`}startProduction(e,t,n){return`${e.env.WB_ENV?`APP_ENV=${e.env.WB_ENV} `:""}NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n "${oe.reset(e)} && ${e.buildCommand} && PORT=${n} pm2-runtime start ${e.findFile("ecosystem.config.cjs")} ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t,n)}"`}testE2E(e,t,{playwrightArgs:n,startCommand:r=`${oe.reset(e)} && ${e.buildCommand} && pm2-runtime start ${e.findFile("ecosystem.config.cjs")}`}){return super.testE2E(e,t,{playwrightArgs:n,prismaDirectory:"db",startCommand:r})}testE2EDev(e,t,{playwrightArgs:n,startCommand:r="blitz dev -p 8080"}){return super.testE2EDev(e,t,{playwrightArgs:n,startCommand:r})}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "blitz dev" "${this.waitApp(e,t)}"`}};const xe=new class extends Ae{constructor(){super()}start(e,t){return`YARN build-ts run src/index.ts ${t.watch?"--watch":""} -- ${t.normalizedArgsText??""}`}startDocker(e,t){return`${this.buildDocker(e)} && ${Ee.stopAndStart(e,!1,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProduction(e,t,n=8080){return`NODE_ENV=production ${e.buildCommand} && NODE_ENV=production PORT=\${PORT:-${n}} ${D} dist/index.js ${t.normalizedArgsText??""}`}testE2E(e,t,{startCommand:n=`${e.hasPrisma?"prisma migrate reset --force --skip-generate && ":""}(${this.startProduction(e,t)})`}){return`NODE_ENV=production WB_ENV=${e.env.WB_ENV} PORT=8080 YARN concurrently --kill-others --raw --success first\n "${n} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${t.target||"tests/e2e"} --color --passWithNoTests --allowOnly"`}testE2EDev(e,t,{startCommand:n}){return`NODE_ENV=production WB_ENV=${e.env.WB_ENV} PORT=8080 YARN concurrently --kill-others --raw --success first\n "${n||this.start(e,t)} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${t.target||"tests/e2e"} --color --passWithNoTests --allowOnly"`}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "${this.start(e,t)}" "${this.waitApp(e,t)}"`}};const Pe=new class extends Ae{constructor(){super()}start(e,t){return`YARN concurrently --raw --kill-others-on-fail\n "next dev --turbo ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t)}"`}startProduction(e,t,n){return`NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n "${[...e.hasPrisma?[oe.reset(e)]:[],e.buildCommand,`PORT=${n} pm2-runtime start ${e.findFile("ecosystem.config.cjs")} ${t.normalizedArgsText??""}`].join(" && ")}"\n "${this.waitAndOpenApp(e,t,n)}"`}testE2E(e,t,n){return super.testE2E(e,t,{playwrightArgs:n.playwrightArgs,prismaDirectory:"db",startCommand:n.startCommand??[...e.hasPrisma?[oe.reset(e)]:[],e.buildCommand,`pm2-runtime start ${e.findFile("ecosystem.config.cjs")}`].join(" && ")})}testE2EDev(e,t,{startCommand:n="next dev --turbo -p 8080"}){return super.testE2EDev(e,t,{startCommand:n})}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "next dev --turbo" "${this.waitApp(e,t)}"`}};const je=new class extends Ae{constructor(){super()}start(e,t){return`YARN build-ts run src/index.ts ${t.watch?"--watch":""} -- ${t.normalizedArgsText??""}`}startDocker(e,t){return`${this.buildDocker(e)} && ${Ee.stopAndStart(e,!1,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProduction(e,t){return`NODE_ENV=production ${e.buildCommand} && NODE_ENV=production ${D} dist/index.js ${t.normalizedArgsText??""}`}testE2E(){return"echo 'do nothing.'"}testE2EDev(){return"echo 'do nothing.'"}testStart(){return"echo 'do nothing.'"}};const Se=new class extends Ae{constructor(){super()}start(e,t){return`YARN concurrently --raw --kill-others-on-fail\n "remix dev ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t)}"`}startProduction(e,t,n){return`NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n "${oe.reset(e)} && ${e.buildCommand} && PORT=${n} pm2-runtime start ${e.findFile("ecosystem.config.cjs")} ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t,n)}"`}testE2E(e,t,{playwrightArgs:n,startCommand:r=`${oe.reset(e)} && ${e.buildCommand} && pm2-runtime start ${e.findFile("ecosystem.config.cjs")}`}){return super.testE2E(e,t,{playwrightArgs:n,prismaDirectory:"prisma",startCommand:r})}testE2EDev(e,t,{playwrightArgs:n,startCommand:r="remix dev"}){return super.testE2EDev(e,t,{playwrightArgs:n,startCommand:r})}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "remix dev" "${this.waitApp(e,t)}"`}},De={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",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 P(e);t||(console.error(c.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=Ne;else if(t.next)s=Pe;else if(r["@remix-run/dev"])s=Se;else if(ke.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=je}switch(console.info(`Running "start" for ${n.name} ...`),e.mode||"dev"){case"dev":case"development":{const r=Re(t,"development");await Y(`${r}${s.start(n,e)}`,n,e);break}case"staging":{const r=Re(t,"staging");await Y(`${r}${s.startProduction(n,e,8080)}`,n,e);break}case"docker":{const r=Re(t,"staging");await Y(`${r}${s.startDocker(n,e)}`,n,e);break}case"docker-debug":{const r=Re(t,"staging");e.normalizedArgsText="'/bin/bash'",await Y(`${r}${s.startDocker(n,e)}`,n,e);break}default:throw new Error(`Unknown start mode: ${e.mode}`)}}}};function Re(e,t){process.env.WB_ENV||=t;let n=`WB_ENV=${process.env.WB_ENV} `;return e.next&&(process.env.NEXT_PUBLIC_WB_ENV=process.env.WB_ENV,n+=`NEXT_PUBLIC_WB_ENV=${process.env.WB_ENV} `),n}const _e={command:"test",describe:"Test project. If you pass no arguments, it will run all tests.",builder:{ci:{description:"Whether to run tests on CI",type:"boolean"},e2e:{description:"Whether to run e2e tests. You may pass mode as argument: none | headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace",type:"string"},start:{description:"Whether to run start tests",type:"boolean"},unit:{description:"Whether to run unit tests",type:"boolean"},"unit-timeout":{description:"Timeout for unit tests",type:"number"},target:{description:"Test target",type:"string",alias:"t"}},async handler(t){await async function(t){const n=await P(t);n||(console.error(c.red("No project found.")),process.exit(1));n.descendants.length>1&&(process.env.CI="1");process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";const r=void 0===t.e2e&&void 0===t.start&&void 0===t.unit;for(const s of n.descendants){const n=s.packageJson.dependencies||{},o=s.packageJson.devDependencies||{};let i;i=n.blitz?Ne:n.next?Pe:o["@remix-run/dev"]?Se:ke.some((e=>n[e]))&&!n["firebase-functions"]?xe:je,r&&(t={...t,e2e:a.existsSync(e.join(s.dirPath,"tests","e2e"))&&!t.target?.includes("/unit/")?"headless":"none",start:!0,unit:a.existsSync(e.join(s.dirPath,"tests","unit"))&&!t.target?.includes("/e2e/")}),console.info(`Running "test" for ${s.name} ...`);const c=[];if(!t.ci){switch(t.unit&&c.push(Y(i.testUnit(s,t),s,t,{timeout:t.unitTimeout})),t.start&&c.push(Y(i.testStart(s,t),s,t)),await Promise.all(c),t.e2e){case void 0:case"none":continue;case"":case"headless":await Y(i.testE2E(s,t,{}),s,t);continue;case"headless-dev":await Y(i.testE2EDev(s,t,{}),s,t);continue;case"docker":await Oe(s,t,i);continue;case"docker-debug":await Oe(s,t,i,`test ${t.target||"tests/e2e"} --debug`);continue}if(n.blitz||n.next||o["@remix-run/dev"])switch(t.e2e){case"headed":await Y(i.testE2E(s,t,{playwrightArgs:`test ${t.target||"tests/e2e"} --headed`}),s,t);continue;case"headed-dev":await Y(i.testE2EDev(s,t,{playwrightArgs:`test ${t.target||"tests/e2e"} --headed`}),s,t);continue;case"debug":await Y(i.testE2E(s,t,{playwrightArgs:`test ${t.target||"tests/e2e"} --debug`}),s,t);continue;case"generate":await Y(i.testE2E(s,t,{playwrightArgs:"codegen http://localhost:8080"}),s,t);continue;case"trace":await Y("BUN playwright show-trace",s,t);continue}throw new Error(`Unknown e2e mode: ${t.e2e}`)}if(await M(Ee.stopAll(),s,t),t.unit&&await M(i.testUnit(s,t).replaceAll(" --allowOnly",""),s,t,{timeout:t.unitTimeout}),t.start&&await M(i.testStart(s,t),s,t),await J.promiseAll(),"none"!==t.e2e){s.hasDockerfile&&await Y(`${i.buildDocker(s,"test")}`,s,t);const e=s.hasDockerfile?{startCommand:Ee.stopAndStart(s,!0)}:{};process.exitCode=await Y(i.testE2E(s,t,e).replaceAll(" --allowOnly",""),s,t,{exitIfFailed:!1}),await Y(Ee.stop(s),s,t)}}}(t)}};async function Oe(e,t,n,r){await Y(`${n.buildDocker(e,"test")}`,e,t),process.exitCode=await Y(`${n.testE2E(e,t,{playwrightArgs:r,startCommand:Ee.stopAndStart(e,!0)})}`,e,t,{exitIfFailed:!1}),await Y(Ee.stop(e),e,t)}const Te={command:"typecheck",describe:"Run type checking. .env files are ignored.",builder:{},async handler(e){const t=await P(e,!1);t||(console.error(c.red("No project found.")),process.exit(1));const n=t.descendants.map((n=>{const r=[];if(n.packageJson.workspaces?n.hasSourceCode&&(n.packageJson.dependencies?.typescript||n.packageJson.devDependencies?.typescript)&&r.push("BUN tsc --noEmit --Pretty"):((n.packageJson.dependencies?.typescript||n.packageJson.devDependencies?.typescript)&&r.push("BUN tsc --noEmit --Pretty"),n.packageJson.devDependencies?.pyright&&r.push("YARN pyright")),r.length>0)return M(r.join(" && "),n,e,{ci:t.descendants.length>1,forceColor:!0})})),r=await Promise.all(n);let s=0;for(const[e,n]of r.entries())if(n){(t.descendants[e].packageJson.dependencies||{}).blitz&&console.info(c.yellow('Please try "yarn gen-code" if you face unknown type errors.')),s=n}s&&process.exit(s)}},Be={...Te,command:"tc"},Ie={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"]}};await t(n(process.argv)).scriptName("wb").options(Ie).middleware((t=>{const n=t["working-dir"];if(n){const t=e.resolve(n);process.chdir(t)}!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(O).command(Z).command(te).command(ae).command(ve).command($e).command(De).command(_e).command(Te).command(Be).demandCommand().strict().help().argv;for(const e of["SIGINT","SIGTERM","SIGQUIT"])process.on(e,(()=>process.exit()));
|
|
2
|
-
//# 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","../src/project.ts","../../../node_modules/at-decorators/dist/memoize.js","../../../node_modules/at-decorators/dist/hash.js","../src/utils/runtime.ts","../src/commands/buildIfNeeded.ts","../../shared-lib/src/error.ts","../src/utils/process.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/commands/prisma.ts","../src/commands/retry.ts","../src/commands/constants.ts","../src/commands/setup.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/start.ts","../src/scripts/builder.ts","../src/commands/test.ts","../src/commands/typecheck.ts","../src/sharedOptionsBuilder.ts","../src/index.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { config } from 'dotenv';\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. Note it does not assign them in `process.env`.\n * */\nexport function readEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string,\n  cacheEnabled = true\n): Record<string, string> {\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.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);\n  }\n\n  let envVars: Record<string, string> = {};\n  const orgEnvVars = { ...process.env };\n  for (const envPath of envPaths) {\n    envVars = { ...readEnvFile(path.join(cwd, envPath), cacheEnabled), ...envVars };\n    let count = 0;\n    for (const [key, value] of Object.entries(envVars)) {\n      if (orgEnvVars[key] !== value) {\n        orgEnvVars[key] = value;\n        count++;\n      }\n    }\n    if (count > 0) {\n      console.info(`Read ${count} environment variables:`, envPath);\n    }\n  }\n\n  if (argv.checkEnv) {\n    const exampleKeys = Object.keys(readEnvFile(path.join(cwd, argv.checkEnv), cacheEnabled) || {});\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 envVars;\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  cacheEnabled = true\n): Record<string, string | undefined> {\n  const envVars = readEnvironmentVariables(argv, cwd, cacheEnabled);\n  Object.assign(process.env, envVars);\n  return envVars;\n}\n\nconst cachedEnvVars = new Map<string, Record<string, string>>();\n\nfunction readEnvFile(filePath: string, cacheEnabled = true): Record<string, string> {\n  const cached = cacheEnabled && cachedEnvVars.get(filePath);\n  if (cached) return cached;\n\n  const parsed = config({ path: path.resolve(filePath), processEnv: {} }).parsed ?? {};\n  if (cacheEnabled) {\n    cachedEnvVars.set(filePath, parsed);\n  }\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      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\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\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;\n  mergeOutAndError?: boolean;\n  killOnExit?: boolean;\n  verbose?: boolean;\n};\n\nexport async function spawnAsync(\n  command: string,\n  args?: ReadonlyArray<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      proc.stdout?.setEncoding?.('utf8');\n      proc.stderr?.setEncoding?.('utf8');\n\n      let stdout = '';\n      let stderr = '';\n      proc.stdout?.on('data', (data) => {\n        stdout += data;\n      });\n      proc.stderr?.on('data', (data) => {\n        if (options?.mergeOutAndError) {\n          stdout += data;\n        } else {\n          stderr += 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      reject(error);\n    }\n  });\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 { memoizeFactory } from 'at-decorators';\nimport { globby } from 'globby';\nimport type { PackageJson } from 'type-fest';\n\nconst memoize = memoizeFactory({ maxCachedThisSize: Number.MAX_SAFE_INTEGER, maxCachedArgsSize: 1 });\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  @memoize\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  @memoize\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  @memoize\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  @memoize\n  get dockerfile(): string {\n    return fs.readFileSync(this.findFile('Dockerfile'), 'utf8');\n  }\n\n  @memoize\n  get hasDockerfile(): boolean {\n    try {\n      return !!this.findFile('Dockerfile');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoize\n  get hasSourceCode(): boolean {\n    return fs.existsSync(path.join(this.dirPath, 'src'));\n  }\n\n  @memoize\n  get name(): string {\n    return this.packageJson.name || 'unknown';\n  }\n\n  @memoize\n  get dockerImageName(): string {\n    const name = this.packageJson.name || 'unknown';\n    return name.replaceAll('@', '').replaceAll('/', '-');\n  }\n\n  @memoize\n  get env(): Record<string, string | undefined> {\n    return this.loadEnv ? { ...readEnvironmentVariables(this.argv, this.dirPath), ...process.env } : process.env;\n  }\n\n  @memoize\n  get packageJson(): PackageJson {\n    return JSON.parse(fs.readFileSync(this.packageJsonPath, 'utf8'));\n  }\n\n  @memoize\n  get packageJsonPath(): string {\n    return path.join(this.dirPath, 'package.json');\n  }\n\n  @memoize\n  get hasPrisma(): boolean {\n    return !!(this.packageJson.dependencies?.['prisma'] || this.packageJson.devDependencies?.['prisma']);\n  }\n\n  @memoize\n  get dockerPackageJson(): PackageJson {\n    return path.dirname(this.findFile('Dockerfile')) === this.dirPath\n      ? this.packageJson\n      : JSON.parse(fs.readFileSync(path.join(path.dirname(this.findFile('Dockerfile')), 'package.json'), 'utf8'));\n  }\n\n  @memoize\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","import{cyrb64HashWithLength as e}from\"./hash.js\";const t=s();function s({cacheDuration:t=Number.POSITIVE_INFINITY,caches:s,calcKey:n=(t=>e(JSON.stringify(t))),maxCachedArgsSize:i=100,maxCachedThisSize:c=10}={}){return function(e,o){if(\"getter\"===o?.kind){const n=new Map;return s?.push(n),function(){const s=Date.now();if(n.has(this)){const[e,i]=n.get(this);if(s-i<=t)return e}const i=e.call(this);if(n.size>=c){const e=n.keys().next().value;n.delete(e)}return n.set(this,[i,s]),i}}{const r=new Map;return s?.push(r),function(...s){const a=n(s);let h=r.get(this);const u=Date.now();if(h){if(h.has(a)){const[e,s]=h.get(a);if(u-s<=t)return e}}else{if(h=new Map,r.size>=c){const e=r.keys().next().value;r.delete(e)}r.set(this,h)}const f=o?e.call(this,...s):e(...s);if(h.size>=i){const e=h.keys().next().value;h.delete(e)}return h.set(a,[f,u]),f}}}}export{t as memoize,s as memoizeFactory};\n//# sourceMappingURL=memoize.js.map\n","function t(t,n=0){const[i,r]=function(t,n=0){let i=3735928559^n,r=1103547991^n;for(let n,a=0;a<t.length;a++)n=t.codePointAt(a),i=Math.imul(i^n,2654435761),r=Math.imul(r^n,1597334677);return i=Math.imul(i^i>>>16,2246822507),i^=Math.imul(r^r>>>13,3266489909),r=Math.imul(r^r>>>16,2246822507),r^=Math.imul(i^i>>>13,3266489909),[r>>>0,i>>>0]}(t,n);return t.length.toString(36)+i.toString(36).padStart(7,\"0\")+r.toString(36).padStart(7,\"0\")}export{t as cyrb64HashWithLength};\n//# sourceMappingURL=hash.js.map\n","export const isRunningOnBun = process.argv[0].endsWith('/bun') || 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 { 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\nfunction build(project: Project, argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>): boolean {\n  argv = { ...argv, command: argv.command ?? (isRunningOnBun ? 'bun run build' : 'yarn build') };\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\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 = await findSelfProject(argv, true, projectPathForTesting);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    return true;\n  }\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\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      .sort(([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/'];\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', ['diff', '--name-only'], {\n      cwd: project.dirPath,\n      env: project.env,\n      stdio: 'pipe',\n      encoding: 'utf8',\n    });\n    const filePaths = ret.stdout\n      .trim()\n      .split('\\n')\n      .map((filePath) =>\n        project.env.WB_ENV === 'test' ? filePath.replace(/packages\\/scripts\\/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) => {\n      hash.update(data);\n      if (argv.verbose) {\n        console.info(data.toString());\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  sleepMilliseconds?: 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 */\nexport async function withRetry<T>(\n  func: (failedCount: number) => Promise<T>,\n  { beforeRetry, handleError, retryCount = 3, retryLogger, sleepMilliseconds = 0 }: 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 (sleepMilliseconds > 0) {\n        await sleep(sleepMilliseconds);\n      }\n      retryLogger?.(`Retry due to: ${error instanceof Error ? error.stack : error}`);\n      await beforeRetry?.(error);\n    }\n  }\n}\n","import { spawnSync } from 'node:child_process';\n\nimport killPortProcess from 'kill-port';\n\nimport type { Project } from '../project.js';\nimport { printFinishedAndExitIfNeeded, printStart } from '../scripts/run.js';\n\nconst killed = new Set<number | string>();\n\nexport async function killPortProcessImmediatelyAndOnExit(port: number): Promise<void> {\n  await killPortProcessHandlingErrors(port);\n  const killFunc = async (): Promise<void> => {\n    if (killed.has(port)) return;\n\n    killed.add(port);\n    await killPortProcessHandlingErrors(port);\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n\nasync function killPortProcessHandlingErrors(port: number): Promise<void> {\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n\nexport function spawnSyncOnExit(script: string, project: Project): void {\n  const killFunc = async (): Promise<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 { 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 { killPortProcessImmediatelyAndOnExit } from '../utils/process.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { isRunningOnBun, packageManagerWithRun } from '../utils/runtime.js';\n\ninterface Options {\n  ci?: boolean;\n  exitIfFailed?: boolean;\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 [printableScript, runnableScript] = normalizeScript(script, project);\n  printStart(printableScript, project);\n  if (argv.verbose) {\n    printStart(runnableScript, project, 'Start (raw)', true);\n  }\n  if (argv.dryRun) {\n    printFinishedAndExitIfNeeded(printableScript, 0, opts);\n    return 0;\n  }\n\n  const port = runnableScript.match(/http-get:\\/\\/127.0.0.1:(\\d+)/)?.[1];\n  if (runnableScript.includes('wait-on') && port && !runnableScript.includes('docker run')) {\n    await killPortProcessImmediatelyAndOnExit(Number(port));\n  }\n  const ret = await spawnAsync(runnableScript, 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  printFinishedAndExitIfNeeded(printableScript, 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 [printableScript, runnableScript] = normalizeScript(script, project);\n    printStart(printableScript, project, 'Start (parallel)', true);\n    if (argv.dryRun) {\n      printStart(printableScript, project, 'Started (log)');\n      if (argv.verbose) {\n        printStart(runnableScript, project, 'Started (raw)', true);\n      }\n      printFinishedAndExitIfNeeded(printableScript, 0, opts);\n      return 0;\n    }\n\n    const ret = await spawnAsync(runnableScript, 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    printStart(printableScript, project, 'Started (log)');\n    if (argv.verbose) {\n      printStart(runnableScript, 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(printableScript, 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): [string, string] {\n  let newScript = script\n    .replaceAll('\\n', '')\n    .replaceAll(/\\s\\s+/g, ' ')\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 ', project.isBunAvailable ? 'bun --bun run ' : 'yarn run ');\n  if (isRunningOnBun) {\n    newScript = newScript\n      .replaceAll('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  return [\n    fixBunCommand(newScript.replaceAll('YARN ', `${packageManagerWithRun} `)),\n    fixBunCommand(\n      newScript.replaceAll('YARN ', !isRunningOnBun && project.binExists ? '' : `${packageManagerWithRun} `)\n    ),\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  return command.includes('next dev') || command.includes('pm2-runtime')\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 (filePath.endsWith('/test-fixtures') || filePath.includes('/test-fixtures/')) {\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 = argv.fix && argv.format ? 'check --fix' : argv.fix ? 'lint --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';\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('yarn', {\n        stdio: 'inherit',\n      });\n    }\n  },\n};\n\nfunction optimizeDevDependencies(argv: InferredOptionTypes<typeof builder>, packageJson: PackageJson): void {\n  if (!argv.outside) {\n    delete packageJson.devDependencies;\n    return;\n  }\n\n  const devDeps = packageJson.devDependencies || {};\n  const nameWordsToBeRemoved = [\n    'artillery',\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    'sort-package-json',\n    'wait-on',\n    'semantic-release',\n    'vitest',\n  ];\n  for (const name of Object.keys(devDeps)) {\n    if (\n      nameWordsToBeRemoved.some((word) => name.includes(word)) ||\n      (!argv.outside && name.includes('willbooster') && name.includes('config'))\n    ) {\n      delete devDeps[name];\n    }\n  }\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  for (const [name, content] of Object.entries(scripts)) {\n    if (\n      nameWordsOfUnnecessaryScripts.some((word) => name.includes(word)) ||\n      // Support \"husky\" since husky v9 requires `\"postinstall\": \"husky\"`\n      contentWordsOfUnnecessaryScripts.some((word) => content.includes(word) || content.trim() === word.trim())\n    ) {\n      delete scripts[name];\n    }\n  }\n}\n\nfunction optimizeRootProps(packageJson: PackageJson): void {\n  delete packageJson.private;\n  delete packageJson.publishConfig;\n  delete packageJson.prettier;\n}\n","import 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  deploy(_: Project): string {\n    return 'PRISMA migrate deploy';\n  }\n\n  deployForce(project: Project, backupPath: string): string {\n    const dirName = project.packageJson.dependencies?.['blitz'] ? 'db' : 'prisma';\n    // Don't skip \"migrate deploy\" because restored database may be older than the current schema.\n    return `rm -Rf ${dirName}/mount/prod.sqlite3*; PRISMA migrate reset --force && rm -Rf ${dirName}/mount/prod.sqlite3*\n      && litestream restore -o ${dirName}/mount/prod.sqlite3 ${backupPath} && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`;\n  }\n\n  litestream(_: Project): string {\n    return `${runtimeWithArgs} -e '\nconst { PrismaClient } = require(\"@prisma/client\");\nnew PrismaClient().$queryRaw\\`PRAGMA journal_mode = WAL;\\`\n  .catch((error) => { console.log(\"Failed due to:\", error); process.exit(1); });\n'`;\n  }\n\n  migrate(project: Project): string {\n    return `PRISMA migrate deploy && PRISMA generate && ${this.seed(project)}`;\n  }\n\n  migrateDev(_: Project): string {\n    return `PRISMA migrate dev`;\n  }\n\n  reset(project: Project): string {\n    // cf. https://www.prisma.io/docs/guides/database/seed-database#integrated-seeding-with-prisma-migrate\n    // Blitz does not trigger seed automatically, so we need to run it manually.\n    return `PRISMA migrate reset --force --skip-seed && ${this.seed(project)}`;\n    // I'm not sure why we need to remove all sqlite files, so I commented out the following line.\n    // return `true $(rm -Rf db/**/*.sqlite* 2> /dev/null) && true $(rm -Rf prisma/**/*.sqlite* 2> /dev/null) && PRISMA migrate reset --force --skip-seed && ${this.seed()}`;\n  }\n\n  restore(project: Project, backupPath: string, outputPath: string): string {\n    const dirName = project.packageJson.dependencies?.['blitz'] ? 'db' : 'prisma';\n    return `rm -Rf ${dirName}/restored.sqlite3; GOOGLE_APPLICATION_CREDENTIALS=gcp-sa-key.json litestream restore -o ${outputPath} ${backupPath}`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (project.packageJson.dependencies?.['blitz'])\n      return `YARN blitz db seed${scriptPath ? ` -f ${scriptPath}` : ''}`;\n    if (scriptPath) return 'BUN build-ts run prisma/seeds.ts';\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, dbUrlOrPath?: string): string {\n    let prefix = '';\n    if (dbUrlOrPath) {\n      try {\n        new URL(dbUrlOrPath);\n        prefix = `DATABASE_URL=${dbUrlOrPath} `;\n      } catch {\n        const absolutePath = path.resolve(dbUrlOrPath);\n        console.info(dbUrlOrPath, absolutePath);\n        prefix = `DATABASE_URL=file://${absolutePath} `;\n      }\n    }\n    return `${prefix}PRISMA studio`;\n  }\n}\n\nexport const prismaScripts = new PrismaScripts();\n","import 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';\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(deployCommand)\n      .command(deployForceCommand)\n      .command(litestreamCommand)\n      .command(migrateCommand)\n      .command(migrateDevCommand)\n      .command(resetCommand)\n      .command(restoreCommand)\n      .command(seedCommand)\n      .command(studioCommand)\n      .command(defaultCommand)\n      .demandCommand();\n  },\n  handler() {\n    // Do nothing\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    for (const project of prepareForRunningCommand('prisma deploy', allProjects)) {\n      await runWithSpawn(prismaScripts.deploy(project), project, argv);\n    }\n  },\n};\n\nconst deployForceBuilder = {\n  ...builder,\n  'backup-path': {\n    description: 'Whether to skip actual command execution',\n    demandOption: true,\n    type: 'string',\n    alias: 'b',\n  },\n} as const;\n\nconst deployForceCommand: CommandModule<unknown, InferredOptionTypes<typeof deployForceBuilder>> = {\n  command: 'deploy-force <backup-path>',\n  describe: \"Force to apply migration to DB utilizing Litestream's backup without initializing it\",\n  builder: deployForceBuilder,\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, argv.backupPath), project, argv);\n    }\n  },\n};\n\nconst litestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: '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 litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.litestream(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    for (const project of prepareForRunningCommand('prisma migrate', allProjects)) {\n      await runWithSpawn(prismaScripts.migrate(project), 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    for (const project of prepareForRunningCommand('prisma migrate-dev', allProjects)) {\n      await runWithSpawn(prismaScripts.migrateDev(project), 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    for (const project of prepareForRunningCommand('prisma reset', allProjects)) {\n      await runWithSpawn(prismaScripts.reset(project), project, argv);\n    }\n  },\n};\n\nconst restoreBuilder = {\n  ...deployForceBuilder,\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 <backup-path>',\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 ||\n        (project.packageJson.dependencies?.['blitz'] ? 'db/restored.sqlite3' : 'prisma/restored.sqlite3');\n      await runWithSpawn(prismaScripts.restore(project, argv.backupPath, 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    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), 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    for (const project of prepareForRunningCommand(`prisma ${script}`, allProjects)) {\n      await runWithSpawn(`PRISMA ${script}`, project, argv);\n    }\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","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      });\n      if (lastStatus === 0) return;\n    }\n    process.exit(lastStatus);\n  },\n};\n","export const httpServerPackages = ['express', 'fastify', 'elysia'];\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 { isRunningOnBun, packageManagerWithRun, packageManager } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\nimport { httpServerPackages } from './constants.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        if (project.hasDockerfile) {\n          packages.push('expect');\n        }\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);\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      await runWithSpawnInParallel('poetry config virtualenvs.prefer-active-python 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    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies || {};\n    const scripts = project.packageJson.scripts ?? {};\n    const newDeps: string[] = [];\n    let newDevDeps: string[] = [];\n    if (deps['blitz'] || deps['next']) {\n      newDeps.push('pm2');\n      newDevDeps.push('concurrently', 'open-cli', 'vitest', 'wait-on');\n    } else if (devDeps['@remix-run/dev']) {\n      newDeps.push('pm2');\n      newDevDeps.push('concurrently', 'open-cli', 'vitest', 'wait-on');\n    } else if (httpServerPackages.some((p) => deps[p])) {\n      newDeps.push('pm2');\n      newDevDeps.push('concurrently', 'vitest', 'wait-on');\n    }\n    if (isRunningOnBun) {\n      newDevDeps = newDevDeps.filter((dep) => dep !== 'vitest');\n    }\n    if (newDeps.length > 0) {\n      await runWithSpawn(`${packageManager} add ${newDeps.join(' ')}`, project, argv);\n    }\n    if (newDevDeps.length > 0) {\n      await runWithSpawn(`${packageManager} add -D ${newDevDeps.join(' ')}`, project, argv);\n    }\n    if (scripts['gen-code']) {\n      await runWithSpawn(`${packageManagerWithRun} gen-code`, project, argv);\n    }\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  buildDevImage(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 amd64)\n        --build-arg WB_ENV=${project.env.WB_ENV}\n        --build-arg WB_VERSION=${version} .`;\n  }\n  stopAndStart(project: Project, unbuffer = false, additionalOptions = '', additionalArgs = ''): string {\n    return `${this.stop(project)} && ${unbuffer ? 'unbuffer ' : ''}${this.start(\n      project,\n      additionalOptions,\n      additionalArgs\n    )}`;\n  }\n  start(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    spawnSyncOnExit(this.stop(project), project);\n    return `docker run --rm -it -p 8080: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 type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nexport interface TestE2EDevOptions {\n  // '--e2e generate' calls 'codegen http://localhost:8080'\n  playwrightArgs?: string;\n  startCommand?: string;\n}\n\nexport interface TestE2EOptions extends TestE2EDevOptions {\n  prismaDirectory?: 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  protected constructor(private readonly defaultPort = Number(process.env.PORT) || 3000) {}\n\n  buildDocker(project: Project, version = 'development'): string {\n    return dockerScripts.buildDevImage(project, version);\n  }\n\n  abstract start(project: Project, argv: ScriptArgv): string;\n\n  abstract startProduction(project: Project, argv: ScriptArgv, port: number): string;\n\n  startDocker(project: Project, argv: ScriptArgv): string {\n    return `${this.buildDocker(project)}\n      && YARN concurrently --raw --kill-others-on-fail\n        \"${dockerScripts.stopAndStart(\n          project,\n          false,\n          argv.normalizedDockerOptionsText ?? '',\n          argv.normalizedArgsText ?? ''\n        )}\"\n        \"${this.waitAndOpenApp(project, argv, 8080)}\"`;\n  }\n\n  testE2E(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs = 'test tests/e2e', prismaDirectory, startCommand }: TestE2EOptions\n  ): string {\n    // Basically, `playwright` (not `yarn playwright`) should work,\n    // but it doesn't work on a project depending on `artillery-engine-playwright`.\n    // So we use `yarn playwright` instead of `playwright` here.\n    const env = project.env.WB_ENV;\n    return `WB_ENV=${env} NEXT_PUBLIC_WB_ENV=${env} APP_ENV=${env} PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"rm -Rf ${prismaDirectory}/mount && ${startCommand} && exit 1\"\n      \"concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n        && BUN playwright ${playwrightArgs === 'test tests/e2e' && argv.target ? playwrightArgs.replace('tests/e2e', argv.target) : playwrightArgs}\"`;\n  }\n\n  testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs = 'test tests/e2e', startCommand }: TestE2EDevOptions\n  ): string {\n    const env = project.env.WB_ENV;\n    return `WB_ENV=${env} NEXT_PUBLIC_WB_ENV=${env} APP_ENV=${env} PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n        && BUN playwright ${playwrightArgs === 'test tests/e2e' && argv.target ? playwrightArgs.replace('tests/e2e', argv.target) : playwrightArgs}\"`;\n  }\n\n  abstract testStart(project: Project, argv: ScriptArgv): string;\n\n  testUnit(project: Project, argv: TestArgv): string {\n    // Since this command is referred from other commands, we have to use \"vitest run\" (non-interactive mode).\n    return `WB_ENV=${project.env.WB_ENV} YARN vitest run ${argv.target || 'tests/unit'} --color --passWithNoTests --allowOnly`;\n  }\n\n  protected waitApp(project: Project, argv: ScriptArgv, port = this.defaultPort): string {\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}`;\n  }\n\n  protected waitAndOpenApp(project: Project, argv: ScriptArgv, port = this.defaultPort): string {\n    return `${this.waitApp(\n      project,\n      argv,\n      port\n    )} || wait-on http-get://127.0.0.1:${port} && open-cli http://\\${HOST:-localhost}:${port}`;\n  }\n}\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    const appEnv = project.env.WB_ENV ? `APP_ENV=${project.env.WB_ENV} ` : '';\n    return `${appEnv}YARN concurrently --raw --kill-others-on-fail\n      \"blitz dev ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv)}\"`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port: number): string {\n    const appEnv = project.env.WB_ENV ? `APP_ENV=${project.env.WB_ENV} ` : '';\n    return `${appEnv}NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n      \"${prismaScripts.reset(project)} && ${project.buildCommand} && PORT=${port} pm2-runtime start ${project.findFile(\n        'ecosystem.config.cjs'\n      )} ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv, port)}\"`;\n  }\n\n  override testE2E(\n    project: Project,\n    argv: TestArgv,\n    {\n      playwrightArgs,\n      startCommand = `${prismaScripts.reset(project)} && ${\n        project.buildCommand\n      } && pm2-runtime start ${project.findFile('ecosystem.config.cjs')}`,\n    }: TestE2EOptions\n  ): string {\n    return super.testE2E(project, argv, {\n      playwrightArgs,\n      prismaDirectory: 'db',\n      startCommand,\n    });\n  }\n\n  override testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs, startCommand = 'blitz dev -p 8080' }: TestE2EDevOptions\n  ): string {\n    return super.testE2EDev(project, argv, { playwrightArgs, startCommand });\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"blitz dev\" \"${this.waitApp(project, argv)}\"`;\n  }\n}\n\nexport const blitzScripts = new BlitzScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { runtimeWithArgs } from '../../utils/runtime.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run src/index.ts ${argv.watch ? '--watch' : ''} -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  override startDocker(project: Project, argv: ScriptArgv): string {\n    return `${this.buildDocker(project)} && ${dockerScripts.stopAndStart(\n      project,\n      false,\n      argv.normalizedDockerOptionsText ?? '',\n      argv.normalizedArgsText ?? ''\n    )}`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port = 8080): string {\n    return `NODE_ENV=production ${\n      project.buildCommand\n    } && NODE_ENV=production PORT=\\${PORT:-${port}} ${runtimeWithArgs} dist/index.js ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  override testE2E(\n    project: Project,\n    argv: TestArgv,\n    {\n      startCommand = `${project.hasPrisma ? 'prisma migrate reset --force --skip-generate && ' : ''}(${this.startProduction(\n        project,\n        argv\n      )})`,\n    }: TestE2EOptions\n  ): string {\n    return `NODE_ENV=production WB_ENV=${project.env.WB_ENV} PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${argv.target || 'tests/e2e'} --color --passWithNoTests --allowOnly\"`;\n  }\n\n  override testE2EDev(project: Project, argv: TestArgv, { startCommand }: TestE2EDevOptions): string {\n    return `NODE_ENV=production WB_ENV=${\n      project.env.WB_ENV\n    } PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"${startCommand || this.start(project, argv)} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${argv.target || 'tests/e2e'} --color --passWithNoTests --allowOnly\"`;\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"${this.start(project, argv)}\" \"${this.waitApp(\n      project,\n      argv\n    )}\"`;\n  }\n}\n\nexport const httpServerScripts = new HttpServerScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"next dev --turbo ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv)}\"`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port: number): string {\n    return `NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n      \"${[\n        ...(project.hasPrisma ? [prismaScripts.reset(project)] : []),\n        project.buildCommand,\n        `PORT=${port} pm2-runtime start ${project.findFile('ecosystem.config.cjs')} ${argv.normalizedArgsText ?? ''}`,\n      ].join(' && ')}\"\n      \"${this.waitAndOpenApp(project, argv, port)}\"`;\n  }\n\n  override testE2E(project: Project, argv: TestArgv, options: TestE2EOptions): string {\n    return super.testE2E(project, argv, {\n      playwrightArgs: options.playwrightArgs,\n      prismaDirectory: 'db',\n      startCommand:\n        options.startCommand ??\n        [\n          ...(project.hasPrisma ? [prismaScripts.reset(project)] : []),\n          project.buildCommand,\n          `pm2-runtime start ${project.findFile('ecosystem.config.cjs')}`,\n        ].join(' && '),\n    });\n  }\n\n  override testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { startCommand = 'next dev --turbo -p 8080' }: TestE2EDevOptions\n  ): string {\n    return super.testE2EDev(project, argv, { startCommand });\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"next dev --turbo\" \"${this.waitApp(project, argv)}\"`;\n  }\n}\n\nexport const nextScripts = new NextScripts();\n","import type { Project } from '../../project.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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run src/index.ts ${argv.watch ? '--watch' : ''} -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  override startDocker(project: Project, argv: ScriptArgv): string {\n    return `${this.buildDocker(project)} && ${dockerScripts.stopAndStart(\n      project,\n      false,\n      argv.normalizedDockerOptionsText ?? '',\n      argv.normalizedArgsText ?? ''\n    )}`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv): string {\n    return `NODE_ENV=production ${project.buildCommand} && NODE_ENV=production ${runtimeWithArgs} dist/index.js ${\n      argv.normalizedArgsText ?? ''\n    }`;\n  }\n\n  override testE2E(): string {\n    return `echo 'do nothing.'`;\n  }\n\n  override testE2EDev(): string {\n    return `echo 'do nothing.'`;\n  }\n\n  override testStart(): string {\n    return `echo 'do nothing.'`;\n  }\n}\n\nexport const plainAppScripts = new PlainAppScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"remix dev ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv)}\"`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port: number): string {\n    return `NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n      \"${prismaScripts.reset(project)} && ${project.buildCommand} && PORT=${port} pm2-runtime start ${project.findFile(\n        'ecosystem.config.cjs'\n      )} ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv, port)}\"`;\n  }\n\n  override testE2E(\n    project: Project,\n    argv: TestArgv,\n    {\n      playwrightArgs,\n      startCommand = `${prismaScripts.reset(project)} && ${\n        project.buildCommand\n      } && pm2-runtime start ${project.findFile('ecosystem.config.cjs')}`,\n    }: TestE2EOptions\n  ): string {\n    return super.testE2E(project, argv, { playwrightArgs, prismaDirectory: 'prisma', startCommand });\n  }\n\n  override testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs, startCommand = 'remix dev' }: TestE2EDevOptions\n  ): string {\n    return super.testE2EDev(project, argv, { playwrightArgs, startCommand });\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"remix dev\" \"${this.waitApp(project, argv)}\"`;\n  }\n}\n\nexport const remixScripts = new RemixScripts();\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 './constants.js';\n\nconst builder = {\n  ...scriptOptionsBuilder,\n  mode: {\n    description: 'Start mode: dev[elopment] (default) | staging | docker | docker-debug',\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          const prefix = configureEnvironmentVariables(deps, 'development');\n          await runWithSpawn(`${prefix}${scripts.start(project, argv)}`, project, argv);\n          break;\n        }\n        case 'staging': {\n          const prefix = configureEnvironmentVariables(deps, 'staging');\n          await runWithSpawn(`${prefix}${scripts.startProduction(project, argv, 8080)}`, project, argv);\n          break;\n        }\n        case 'docker': {\n          const prefix = configureEnvironmentVariables(deps, 'staging');\n          await runWithSpawn(`${prefix}${scripts.startDocker(project, argv)}`, project, argv);\n          break;\n        }\n        case 'docker-debug': {\n          const prefix = configureEnvironmentVariables(deps, 'staging');\n          argv.normalizedArgsText = `'/bin/bash'`;\n          await runWithSpawn(`${prefix}${scripts.startDocker(project, argv)}`, project, argv);\n          break;\n        }\n        default: {\n          throw new Error(`Unknown start mode: ${argv.mode}`);\n        }\n      }\n    }\n  },\n};\n\nfunction configureEnvironmentVariables(deps: Partial<Record<string, string>>, wbEnv: string): string {\n  process.env.WB_ENV ||= wbEnv;\n  let prefix = `WB_ENV=${process.env.WB_ENV} `;\n  if (deps['next']) {\n    process.env.NEXT_PUBLIC_WB_ENV = process.env.WB_ENV;\n    prefix += `NEXT_PUBLIC_WB_ENV=${process.env.WB_ENV} `;\n  }\n  return prefix;\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};\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","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 { 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 './constants.js';\n\nconst builder = {\n  ci: {\n    description: 'Whether to run tests on CI',\n    type: 'boolean',\n  },\n  e2e: {\n    description:\n      'Whether to run e2e tests. You may pass mode as argument: none | headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace',\n    type: 'string',\n  },\n  start: {\n    description: 'Whether to run start tests',\n    type: 'boolean',\n  },\n  unit: {\n    description: 'Whether to run unit tests',\n    type: 'boolean',\n  },\n  'unit-timeout': {\n    description: 'Timeout for unit tests',\n    type: 'number',\n  },\n  target: {\n    description: 'Test target',\n    type: 'string',\n    alias: 't',\n  },\n} as const;\n\nexport type TestArgv = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof scriptOptionsBuilder>>>;\n\nexport const testCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  command: 'test',\n  describe: 'Test project. If you pass no arguments, it will run all tests.',\n  builder,\n  async handler(argv) {\n    await test(argv);\n  },\n};\n\nexport async function test(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & 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  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  const shouldRunAllTests = argv.e2e === undefined && argv.start === undefined && argv.unit === undefined;\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    if (shouldRunAllTests) {\n      argv = {\n        ...argv,\n        e2e:\n          fs.existsSync(path.join(project.dirPath, 'tests', 'e2e')) && !argv.target?.includes('/unit/')\n            ? 'headless'\n            : 'none',\n        start: true,\n        unit: fs.existsSync(path.join(project.dirPath, 'tests', 'unit')) && !argv.target?.includes('/e2e/'),\n      };\n    }\n\n    console.info(`Running \"test\" for ${project.name} ...`);\n\n    const promises: Promise<unknown>[] = [];\n    if (argv.ci) {\n      await runWithSpawnInParallel(dockerScripts.stopAll(), project, argv);\n      if (argv.unit) {\n        // CI mode disallows `only` to avoid including debug tests\n        await runWithSpawnInParallel(scripts.testUnit(project, argv).replaceAll(' --allowOnly', ''), project, argv, {\n          timeout: argv.unitTimeout,\n        });\n      }\n      if (argv.start) {\n        await runWithSpawnInParallel(scripts.testStart(project, argv), project, argv);\n      }\n      await promisePool.promiseAll();\n      if (argv.e2e !== 'none') {\n        if (project.hasDockerfile) {\n          await runWithSpawn(`${scripts.buildDocker(project, 'test')}`, project, argv);\n        }\n        const options = project.hasDockerfile\n          ? {\n              startCommand: dockerScripts.stopAndStart(project, true),\n            }\n          : {};\n        process.exitCode = await runWithSpawn(\n          // CI mode disallows `only` to avoid including debug tests\n          scripts.testE2E(project, argv, options).replaceAll(' --allowOnly', ''),\n          project,\n          argv,\n          {\n            exitIfFailed: false,\n          }\n        );\n        await runWithSpawn(dockerScripts.stop(project), project, argv);\n      }\n      continue;\n    }\n\n    if (argv.unit) {\n      promises.push(runWithSpawn(scripts.testUnit(project, argv), project, argv, { timeout: argv.unitTimeout }));\n    }\n    if (argv.start) {\n      promises.push(runWithSpawn(scripts.testStart(project, argv), project, argv));\n    }\n    await Promise.all(promises);\n    switch (argv.e2e) {\n      case undefined:\n      case 'none': {\n        continue;\n      }\n      case '':\n      case 'headless': {\n        await runWithSpawn(scripts.testE2E(project, argv, {}), project, argv);\n        continue;\n      }\n      case 'headless-dev': {\n        await runWithSpawn(scripts.testE2EDev(project, argv, {}), project, argv);\n        continue;\n      }\n      case 'docker': {\n        await testOnDocker(project, argv, scripts);\n        continue;\n      }\n      case 'docker-debug': {\n        await testOnDocker(project, argv, scripts, `test ${argv.target || 'tests/e2e'} --debug`);\n        continue;\n      }\n    }\n    if (deps['blitz'] || deps['next'] || devDeps['@remix-run/dev']) {\n      switch (argv.e2e) {\n        case 'headed': {\n          await runWithSpawn(\n            scripts.testE2E(project, argv, { playwrightArgs: `test ${argv.target || 'tests/e2e'} --headed` }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'headed-dev': {\n          await runWithSpawn(\n            scripts.testE2EDev(project, argv, { playwrightArgs: `test ${argv.target || 'tests/e2e'} --headed` }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'debug': {\n          await runWithSpawn(\n            scripts.testE2E(project, argv, { playwrightArgs: `test ${argv.target || 'tests/e2e'} --debug` }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'generate': {\n          await runWithSpawn(\n            scripts.testE2E(project, argv, { playwrightArgs: 'codegen http://localhost:8080' }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'trace': {\n          await runWithSpawn(`BUN playwright show-trace`, project, argv);\n          continue;\n        }\n      }\n    }\n    throw new Error(`Unknown e2e mode: ${argv.e2e}`);\n  }\n}\n\nasync function testOnDocker(\n  project: Project,\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder>>,\n  scripts: BaseScripts,\n  playwrightArgs?: string\n): Promise<void> {\n  await runWithSpawn(`${scripts.buildDocker(project, 'test')}`, project, argv);\n  process.exitCode = await runWithSpawn(\n    `${scripts.testE2E(project, argv, {\n      playwrightArgs,\n      startCommand: dockerScripts.stopAndStart(project, true),\n    })}`,\n    project,\n    argv,\n    { exitIfFailed: false }\n  );\n  await runWithSpawn(dockerScripts.stop(project), project, argv);\n}\n","import 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    const promises = projects.descendants.map((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      if (commands.length > 0) {\n        return runWithSpawnInParallel(commands.join(' && '), project, argv, {\n          // Disable interactive mode\n          ci: projects.descendants.length > 1,\n          forceColor: true,\n        });\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) process.exit(finalExitCode);\n  },\n};\n\nexport const tcCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  ...typeCheckCommand,\n  command: 'tc',\n};\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 path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { buildIfNeededCommand } from './commands/buildIfNeeded.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 { 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(lintCommand)\n  .command(optimizeForDockerBuildCommand)\n  .command(prismaCommand)\n  .command(retryCommand)\n  .command(setupCommand)\n  .command(startCommand)\n  .command(testCommand)\n  .command(typeCheckCommand)\n  .command(tcCommand)\n  .demandCommand()\n  .strict()\n  .help().argv;\n\nfor (const signal of ['SIGINT', 'SIGTERM', 'SIGQUIT']) {\n  process.on(signal, () => process.exit());\n}\n"],"names":["readEnvironmentVariables","argv","cwd","cacheEnabled","envPaths","env","map","envPath","path","resolve","toString","cascade","cascadeEnv","cascadeNodeEnv","process","NODE_ENV","autoCascadeEnv","WB_ENV","undefined","length","push","join","includeRootEnv","rootPath","fs","existsSync","flatMap","relative","verbose","console","info","envVars","orgEnvVars","readEnvFile","count","key","value","Object","entries","checkEnv","missingKeys","keys","filter","Error","cachedEnvVars","Map","filePath","cached","get","parsed","config","processEnv","set","async","spawnAsync","command","args","options","Promise","reject","proc","spawn","stdout","setEncoding","stderr","on","data","mergeOutAndError","stopped","stopProcess","pid","treeKill","killOnExit","error","removeListener","removeAllListeners","code","signal","status","input","stdin","write","end","memoize","cacheDuration","t","Number","POSITIVE_INFINITY","caches","s","calcKey","n","i","r","a","codePointAt","Math","imul","padStart","e","JSON","stringify","maxCachedArgsSize","maxCachedThisSize","c","o","kind","Date","now","has","this","call","size","next","delete","h","u","f","memoizeFactory","MAX_SAFE_INTEGER","Project","_initProto","_applyDecs","pathByName","constructor","dirPath","loadEnv","_dirPath","isBunAvailable","test","readFileSync","rootDirPath","buildCommand","packageJson","scripts","build","includes","dockerfile","findFile","hasDockerfile","hasSourceCode","name","dockerImageName","replaceAll","parse","packageJsonPath","hasPrisma","dependencies","devDependencies","dockerPackageJson","dirname","binExists","binFound","currentPath","binPath","PATH","parentPath","fileName","p","find","findSelfProject","findDescendantProjects","rootAndSelfProjects","thisProject","rootProject","workspaces","endsWith","root","self","findRootAndSelfProjects","descendants","getAllDescendantProjects","projects","workspace","Array","isArray","globPattern","packageDirs","workspacePath","ws","globby","dot","onlyDirectories","subPackageDirPath","isRunningOnBun","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","update","environmentJson","ignoringEnvVarNames","sort","key1","key2","localeCompare","filteredFilePaths","spawnSync","stdio","encoding","split","replace","includePatterns","some","pattern","includeSuffix","suffix","excludePatterns","copy","digest","updateHashWithDiffResult","cachedContentHash","fn","ignoreEnoentAsync","readFile","canSkipBuild","green","dryRun","writeFile","buildIfNeeded","ret","shell","exitCode","Set","killed","killPortProcessHandlingErrors","port","killPortProcess","promisePool","PromisePool","defaultOptions","exitIfFailed","runWithSpawn","script","opts","printableScript","runnableScript","normalizeScript","printStart","printFinishedAndExitIfNeeded","match","killFunc","add","killPortProcessImmediatelyAndOnExit","configureEnv","timeout","runWithSpawnInParallel","runAndWaitForReturnValue","out","newScript","fixBunCommand","normalizedScript","prefix","weak","gray","cyan","bold","exit","newEnv","ci","forceColor","biomeExtensions","prettierExtensions","prettierOnlyExtensions","ext","lintCommand","fix","format","files","biomeArgsText","prettierArgsText","sortPackageJsonArgsText","filePathsToBeCheckedByBiome","filePathsToBeFormattedByPrettier","packageJsonFilePaths","file","String","extension","extname","slice","biomeCommand","biomePromise","prepareForRunningCommand","commandName","optimizeForDockerBuildCommand","outside","deps","startsWith","optimizeDevDependencies","optimizeScripts","optimizeRootProps","distDirPath","devDeps","nameWordsToBeRemoved","word","nameWordsOfUnnecessaryScripts","contentWordsOfUnnecessaryScripts","content","private","publishConfig","prettier","prismaScripts","deploy","_","deployForce","backupPath","dirName","litestream","migrate","seed","migrateDev","reset","restore","outputPath","scriptPath","prisma","studio","dbUrlOrPath","URL","absolutePath","builder","prismaCommand","yargs","deployCommand","deployForceCommand","litestreamCommand","migrateCommand","migrateDevCommand","resetCommand","restoreCommand","seedCommand","studioCommand","defaultCommand","demandCommand","allProjects","findPrismaProjects","deployForceBuilder","demandOption","output","restored","trimEnd","filtered","retryCommand","retry","default","cmdAndArgs","Boolean","lastStatus","yellow","httpServerPackages","setupCommand","dirents","readdir","withFileTypes","os","platform","packages","d","isFile","version","promiseAll","newDeps","newDevDeps","dep","setup","dockerScripts","buildDevImage","stopAndStart","unbuffer","additionalOptions","additionalArgs","stop","start","spawnSyncOnExit","stopAll","BaseScripts","defaultPort","PORT","buildDocker","startDocker","normalizedDockerOptionsText","normalizedArgsText","waitAndOpenApp","testE2E","playwrightArgs","prismaDirectory","startCommand","target","testE2EDev","testUnit","waitApp","blitzScripts","super","startProduction","testStart","httpServerScripts","watch","nextScripts","plainAppScripts","remixScripts","mode","arg","dockerOptions","normalizeArgs","configureEnvironmentVariables","wbEnv","NEXT_PUBLIC_WB_ENV","testCommand","e2e","unit","CI","FORCE_COLOR","shouldRunAllTests","unitTimeout","all","testOnDocker","typeCheckCommand","commands","typescript","pyright","exitCodes","finalExitCode","tcCommand","sharedOptionsBuilder","hideBin","scriptName","middleware","workingDir","chdir","BERRY_BIN_FOLDER","upperKey","toUpperCase","removeNpmAndYarnEnvironmentVariables","strict","help"],"mappings":"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","x_google_ignoreList":[3,4]}
|
|
1
|
+
import e from"node:path";import t from"yargs";import{hideBin as n}from"yargs/helpers";import r,{spawn as s,spawnSync as o}from"node:child_process";import{createHash as i}from"node:crypto";import a from"node:fs";import c from"chalk";import{globby as d}from"globby";import{config as l}from"dotenv";import u from"kill-port";import{PromisePool as p}from"minimal-promise-pool";import m from"tree-kill";import f from"node:fs/promises";import h from"node:os";function g(t,n,r=!0){let s=(t.env??[]).map((t=>e.resolve(n,t.toString())));const o=t.cascadeEnv??(t.cascadeNodeEnv?process.env.NODE_ENV||"development":t.autoCascadeEnv?process.env.WB_ENV||process.env.NODE_ENV||"development":void 0);if("string"==typeof o){if(0===s.length&&(s.push(e.join(n,".env")),t.includeRootEnv)){const t=e.resolve(n,"..","..");a.existsSync(e.join(t,"package.json"))&&s.push(e.join(t,".env"))}s=s.flatMap((e=>o?[`${e}.${o}.local`,`${e}.local`,`${e}.${o}`,e]:[`${e}.local`,e]))}s=s.map((t=>e.relative(n,t))),t.verbose&&(console.info(`WB_ENV: ${process.env.WB_ENV}, NODE_ENV: ${process.env.NODE_ENV}`),console.info("Reading env files:",s));let i={};const c={...process.env};for(const t of s){i={...y(e.join(n,t),r),...i};let s=0;for(const[e,t]of Object.entries(i))c[e]!==t&&(c[e]=t,s++);s>0&&console.info(`Read ${s} environment variables:`,t)}if(t.checkEnv){const o=Object.keys(y(e.join(n,t.checkEnv),r)||{}).filter((e=>!(e in i)));if(o.length>0)throw new Error(`Missing environment variables in [${s.join(", ")}]: [${o.join(", ")}]`)}return i}const w=new Map;function y(t,n=!0){const r=n&&w.get(t);if(r)return r;const s=l({path:e.resolve(t),processEnv:{}}).parsed??{};return n&&w.set(t,s),s}async function b(e,t,n){return new Promise(((r,o)=>{try{const i=s(e,t??[],n??{});i.stdout?.setEncoding?.("utf8"),i.stderr?.setEncoding?.("utf8");let a="",c="";i.stdout?.on("data",(e=>{a+=e})),i.stderr?.on("data",(e=>{n?.mergeOutAndError?a+=e:c+=e}));let d=!1;const l=()=>{!d&&i.pid&&(d=!0,n?.verbose&&console.info(`treeKill(${i.pid})`),m(i.pid))};n?.killOnExit&&(process.on("beforeExit",l),process.on("SIGINT",l)),i.on("error",(e=>{process.removeListener("beforeExit",l),process.removeListener("SIGINT",l),i.removeAllListeners("close"),o(e)})),i.on("close",((e,t)=>{process.removeListener("beforeExit",l),process.removeListener("SIGINT",l),void 0===i.pid?o(new Error("Process has no pid.")):r({pid:i.pid,stdout:a,stderr:c,status:e,signal:t})})),n?.input&&(i.stdin?.write(n.input),i.stdin?.end())}catch(e){o(e)}}))}function v(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 k(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 $(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||"default");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+""}let E;const A=function({cacheDuration:e=Number.POSITIVE_INFINITY,caches:t,calcKey:n=e=>function(e,t=0){const[n,r]=function(e,t=0){let n=3735928559^t,r=1103547991^t;for(let t,s=0;s<e.length;s++)t=e.codePointAt(s),n=Math.imul(n^t,2654435761),r=Math.imul(r^t,1597334677);return n=Math.imul(n^n>>>16,2246822507),n^=Math.imul(r^r>>>13,3266489909),r=Math.imul(r^r>>>16,2246822507),r^=Math.imul(n^n>>>13,3266489909),[r>>>0,n>>>0]}(e,t);return e.length.toString(36)+n.toString(36).padStart(7,"0")+r.toString(36).padStart(7,"0")}(JSON.stringify(e)),maxCachedArgsSize:r=100,maxCachedThisSize:s=10}={}){return function(o,i){if("getter"===i?.kind){const n=new Map;return t?.push(n),function(){const t=Date.now();if(n.has(this)){const[r,s]=n.get(this);if(t-s<=e)return r}const r=o.call(this);if(n.size>=s){const e=n.keys().next().value;n.delete(e)}return n.set(this,[r,t]),r}}{const a=new Map;return t?.push(a),function(...t){const c=n(t);let d=a.get(this);const l=Date.now();if(d){if(d.has(c)){const[t,n]=d.get(c);if(l-n<=e)return t}}else{if(d=new Map,a.size>=s){const e=a.keys().next().value;a.delete(e)}a.set(this,d)}const u=i?o.call(this,...t):o(...t);if(d.size>=r){const e=d.keys().next().value;d.delete(e)}return d.set(c,[u,l]),u}}}}({maxCachedThisSize:Number.MAX_SAFE_INTEGER,maxCachedArgsSize:1});class N{static{[E]=function(e,t,n,r,s){var o,i,a,c,d,l,u,p=Symbol.metadata||Symbol.for("Symbol.metadata"),m=Object.defineProperty,f=Object.create,h=[f(null),f(null)],g=t.length;function w(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 y(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 b(e,t,n,r,s,a,c,d,l,u,p){function f(e){if(!p(e))throw new TypeError("Attempted to access private element on non-instance")}var g=[].concat(t[0]),b=t[3],v=!c,$=1===s,E=3===s,A=4===s,N=2===s;function x(t,n,r){return function(s,o){return n&&(o=s,s=e),r&&r(s),P[t].call(s,o)}}if(!v){var P={},j=[],S=E?"get":A||$?"set":"value";if(l?(u||$?P={get:k((function(){return b(this)}),r,"get"),set:function(e){t[4](this,e)}}:P[S]=b,u||k(P[S],r,N?"":S)):u||(P=Object.getOwnPropertyDescriptor(e,r)),!u&&!l){if((i=h[+d][r])&&7!=(i^s))throw Error("Decorating two elements with the same name ("+P[S].name+") is not supported yet");h[+d][r]=s<3?1:s}}for(var R=e,D=g.length-1;D>=0;D-=n?2:1){var _=y(g[D],"A decorator","be",!0),O=n?g[D-1]:void 0,T={},B={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");y(t,"An initializer","be",!0),a.push(t)}.bind(null,T)};if(v)i=_.call(O,R,B),T.v=1,y(i,"class decorators","return")&&(R=i);else if(B.static=d,B.private=l,i=B.access={has:l?p.bind():function(e){return r in e}},A||(i.get=l?N?function(e){return f(e),P.value}:x("get",0,f):function(e){return e[r]}),N||E||(i.set=l?x("set",0,f):function(e,t){e[r]=t}),R=_.call(O,$?{get:P.get,set:P.set}:P[S],B),T.v=1,$){if("object"==typeof R&&R)(i=y(R.get,"accessor.get"))&&(P.get=i),(i=y(R.set,"accessor.set"))&&(P.set=i),(i=y(R.init,"accessor.init"))&&j.unshift(i);else if(void 0!==R)throw new TypeError("accessor decorators must return an object with get, set, or init properties or undefined")}else y(R,(u?"field":"method")+" decorators","return")&&(u?j.unshift(R):P[S]=R)}return s<2&&c.push(w(j,d,1),w(a,d,0)),u||v||(l?$?c.splice(-1,0,x("get",d),x("set",d)):c.push(N?P[S]:y.call.bind(P[S])):m(e,r,P)),R}function E(e){return m(e,p,{configurable:!0,enumerable:!0,value:o})}return o=f(null==o?null:o),d=[],l=function(e){e&&d.push(w(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],m=!!i[3],f=16&l;b(t?e:e.prototype,i,f,m?"#"+p:$(p),u,u<2?[]:t?c=c||[]:a=a||[],d,!!t,m,r,t&&m?function(t){return v(t)===e}:s)}}},u(8,0),u(0,0),u(8,1),u(0,1),l(a),l(c),i=d,g||E(e),{e:i,get c(){var n=[];return g&&[E(e=b(e,[t],r,e.name,5,n)),w(n,1)]}}}(this,[],[[A,3,"isBunAvailable"],[A,3,"buildCommand"],[A,3,"rootDirPath"],[A,3,"dockerfile"],[A,3,"hasDockerfile"],[A,3,"hasSourceCode"],[A,3,"name"],[A,3,"dockerImageName"],[A,3,"env"],[A,3,"packageJson"],[A,3,"packageJsonPath"],[A,3,"hasPrisma"],[A,3,"dockerPackageJson"],[A,3,"binExists"]]).e}argv=void E(this);pathByName=new Map;constructor(t,n,r){this._dirPath=e.resolve(t),this.argv=n,this.loadEnv=r}get isBunAvailable(){try{return/(^|\n)bun\s/.test(a.readFileSync(e.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 a.existsSync(e.join(this.dirPath,"..","..","package.json"))?e.resolve(this.dirPath,"..",".."):this.dirPath}get dockerfile(){return a.readFileSync(this.findFile("Dockerfile"),"utf8")}get hasDockerfile(){try{return!!this.findFile("Dockerfile")}catch{return!1}}get hasSourceCode(){return a.existsSync(e.join(this.dirPath,"src"))}get name(){return this.packageJson.name||"unknown"}get dockerImageName(){return(this.packageJson.name||"unknown").replaceAll("@","").replaceAll("/","-")}get env(){return this.loadEnv?{...g(this.argv,this.dirPath),...process.env}:process.env}get packageJson(){return JSON.parse(a.readFileSync(this.packageJsonPath,"utf8"))}get packageJsonPath(){return e.join(this.dirPath,"package.json")}get hasPrisma(){return!(!this.packageJson.dependencies?.prisma&&!this.packageJson.devDependencies?.prisma)}get dockerPackageJson(){return e.dirname(this.findFile("Dockerfile"))===this.dirPath?this.packageJson:JSON.parse(a.readFileSync(e.join(e.dirname(this.findFile("Dockerfile")),"package.json"),"utf8"))}get binExists(){let t=!1,n=this.dirPath;for(;;){const r=e.join(n,"node_modules",".bin");if(a.existsSync(r)&&(this.env.PATH=`${r}:${this.env.PATH}`,t=!0),a.existsSync(e.join(n,".git")))break;const s=e.dirname(n);if(n===s)break;n=s}return t}findFile(t){let n=this.pathByName.get(t);if(n)return n;if(n=[t,e.join("..","..",t)].map((t=>e.resolve(this.dirPath,t))).find((e=>a.existsSync(e))),!n)throw new Error(`File not found: ${t}`);return this.pathByName.set(t,n),n}}function x(t,n=!0,r){if(r??=process.cwd(),a.existsSync(e.join(r,"package.json")))return new N(r,t,n)}async function P(t,n=!0,r){const s=function(t,n=!0,r){if(r??=process.cwd(),!a.existsSync(e.join(r,"package.json")))return;const s=new N(r,t,n);let o=s;if(!s.packageJson.workspaces&&e.dirname(r).endsWith("/packages")){const s=e.resolve(r,"..","..");a.existsSync(e.join(s,"package.json"))&&(o=new N(s,t,n))}return{root:o,self:s}}(t,n,r);if(s)return{...s,descendants:s.root===s.self?await j(t,s.root,n):[s.self]}}async function j(t,n,r){const s=[n],o=n.packageJson.workspaces;if(!Array.isArray(o))return s;const i=[],c=[];for(const t of o.map((t=>e.join(n.dirPath,t))))a.existsSync(t)?c.push(t):i.push(t);c.push(...await d(i,{dot:!0,onlyDirectories:!0}));for(const n of c)a.existsSync(e.join(n,"package.json"))&&s.push(new N(n,t,r));return s}const S=process.argv[0].endsWith("/bun")||process.env.npm_execpath?.endsWith("/bun"),R=S?"bun --bun run":"node",D=S?"bun":"yarn",_=S?"bun --bun run":"yarn",O={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(t){await async function(t,n){const s=await x(t,!0,n);if(!s)return console.error(c.red("No project found.")),!0;if(!a.existsSync(e.join(s.rootDirPath,".git")))return T(s,t),!0;const[o,d,l]=await async function(t,n){const s=e.resolve(t.dirPath,"node_modules",".cache","build"),o=e.resolve(s,"last-build");await a.promises.mkdir(s,{recursive:!0});const c=i("sha256"),d=r.execSync("git rev-parse HEAD",{cwd:t.dirPath}).toString().trim();c.update(d);const l=JSON.stringify(Object.entries(t.env).filter((([e])=>!B.has(e))).sort((([e],[t])=>e.localeCompare(t))));c.update(l),await async function(e,t,n){return new Promise((s=>{const o=r.spawnSync("git",["diff","--name-only"],{cwd:e.dirPath,env:e.env,stdio:"pipe",encoding:"utf8"}).stdout.trim().split("\n").map((t=>"test"===e.env.WB_ENV?t.replace(/packages\/scripts\/test-fixtures\/[^/]+\//,""):t)).filter((e=>(I.some((t=>e.includes(t)))||C.some((t=>e.endsWith(t))))&&!W.some((t=>e.includes(t)))));t.verbose&&console.info(`Changed files: ${o.join(", ")}`);const i=r.spawn("git",["diff","--",...o],{cwd:e.rootDirPath});i.stdout?.on("data",(e=>{n.update(e),t.verbose&&(console.info(e.toString()),console.info("Hash:",n.copy().digest("hex")))})),i.on("close",(()=>{s()}))}))}(t,n,c);const u=c.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}}((()=>a.promises.readFile(o,"utf8")));return[p===u,o,u]}(s,t);if(o)return console.info(c.green(`Skip to run '${t.command}' 💫`)),!1;if(!T(s,t))return;t.dryRun||await a.promises.writeFile(d,l,"utf8");return!0}(t)}};function T(e,t){if(t={...t,command:t.command??(S?"bun run build":"yarn build")},console.info(c.green(`Run '${t.command}'`)),!t.dryRun){const n=r.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 B=new Set(["CI","PWDEBUG","TMPDIR"]);const I=["src/","public/"],C=[".js",".cjs",".mjs",".jsx",".ts",".cts",".mts",".tsx",".json",".browserslistrc","package.json","yarn.lock"],W=["test/","tests/","__tests__/","test-fixtures/"];const z=new Set;async function V(e){try{await u(e)}catch{}}const J=new p,F={exitIfFailed:!0};async function Y(e,t,n,r=F){const[s,o]=U(e,t);if(L(s,t),n.verbose&&L(o,t,"Start (raw)",!0),n.dryRun)return G(s,0,r),0;const i=o.match(/http-get:\/\/127.0.0.1:(\d+)/)?.[1];o.includes("wait-on")&&i&&!o.includes("docker run")&&await async function(e){await V(e);const t=async()=>{z.has(e)||(z.add(e),await V(e))};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,t)}(Number(i));const a=await b(o,void 0,{cwd:t.dirPath,env:q(t.env,r),shell:!0,stdio:"inherit",timeout:r?.timeout,killOnExit:!0,verbose:n.verbose});return G(s,a.status,r),a.status??1}function M(e,t,n,r=F){return J.runAndWaitForReturnValue((async()=>{const[s,o]=U(e,t);if(L(s,t,"Start (parallel)",!0),n.dryRun)return L(s,t,"Started (log)"),n.verbose&&L(o,t,"Started (raw)",!0),G(s,0,r),0;const i=await b(o,void 0,{cwd:t.dirPath,env:q(t.env,r),shell:!0,stdio:"pipe",timeout:r?.timeout,mergeOutAndError:!0,killOnExit:!0,verbose:n.verbose});L(s,t,"Started (log)"),n.verbose&&L(o,t,"Started (raw)",!0);const a=i.stdout.trim();return a&&(process.stdout.write(a),process.stdout.write("\n")),G(s,i.status,r),i.status??1}))}function U(e,t){let n=e.replaceAll("\n","").replaceAll(/\s\s+/g," ").replaceAll("PRISMA ",t.packageJson.dependencies?.blitz?"YARN blitz prisma ":"YARN prisma ").replaceAll("BUN ",t.isBunAvailable?"bun --bun run ":"YARN ").replaceAll("YARN run ",t.isBunAvailable?"bun --bun run ":"yarn run ");return S&&(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(),[H(n.replaceAll("YARN ",`${_} `)),H(n.replaceAll("YARN ",!S&&t.binExists?"":`${_} `))]}function L(e,t,n="Start",r=!1){console.info("\n"+(r?c.gray:c.cyan)(c.bold(`${n}:`),e)+c.gray(` at ${t.dirPath}`))}function G(e,t,n){0===t?console.info(c.green(c.bold("Finished:"),e)):(console.info(c.red(c.bold(`Failed (exit code ${t}): `),e)),!1!==n.exitIfFailed&&process.exit(t??1))}function q(e,t){const n={...e};return t.ci&&(n.CI="1"),t.forceColor&&(n.FORCE_COLOR="3"),n}function H(e){return e.includes("next dev")||e.includes("pm2-runtime")?e.replaceAll("bun --bun","bun"):e}const X=new Set(["cjs","cts","js","json","jsonc","jsx","mjs","mts","ts","tsx"]),K=new Set(["cjs","cts","htm","html","js","json","jsonc","jsx","md","mjs","mts","scss","ts","tsx","vue","yaml","yml"]),Q=new Set([...K].filter((e=>!X.has(e)))),Z={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(t){S||(console.error(c.red("This command is only available on Bun.")),process.exit(1));const n=await P(t,!1);n||(console.error(c.red("No project found.")),process.exit(1));const r=t.files??[];let s,o,i;if(r.length>0){const t=[],n=[],a=[];for(const s of r){const r=e.resolve(String(s));if(r.endsWith("/test-fixtures")||r.includes("/test-fixtures/"))continue;const o=e.extname(r).slice(1);r.endsWith("/package.json")?a.push(r):X.has(o)?t.push(r):K.has(o)&&n.push(r)}s=t.map((e=>`"${e}"`)).join(" "),o=n.map((e=>`"${e}"`)).join(" "),i=a.map((e=>`"${e}"`)).join(" ")}else s="",o=`"**/{.*/,}*.{${[...Q].join(",")}" "!**/test-fixtures/**"`,i=n.descendants.map((e=>`"${e.packageJsonPath}"`)).join(" ");const a=t.fix&&t.format?"check --fix":t.fix?"lint --fix":"lint";let d;(s||0===r.length)&&(d=M(`bun --bun biome ${a} --colors=force --no-errors-on-unmatched --files-ignore-unknown=true ${s}`,n.self,t,{forceColor:!0})),t.format&&(o&&M(`bun --bun prettier --cache --color --no-error-on-unmatched-pattern --write ${o}`,n.self,t,{forceColor:!0}),i&&(await d,M(`bun --bun sort-package-json ${i}`,n.self,t,{forceColor:!0})))}};function*ee(e,t){for(const n of t)console.info(`Running "${e}" for ${n.name} ...`),yield n}const te={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(t){const n=await P(t);n||(console.error(c.red("No project found.")),process.exit(1));for(const r of ee("optimizeForDockerBuild",n.descendants)){const n=r.packageJson,s=["dependencies","devDependencies"];for(const e of s){const t=n[e]||{};for(const[e,n]of Object.entries(t))n?.startsWith("git@github.com:")&&(t[e]=`./${e}`)}if(ne(t,n),re(n),se(n),t.dryRun)continue;const o=t.outside?e.join(r.dirPath,"dist"):r.dirPath;await a.promises.mkdir(o,{recursive:!0}),await a.promises.writeFile(e.join(o,"package.json"),JSON.stringify(n),"utf8")}t.dryRun||t.outside||r.spawnSync("yarn",{stdio:"inherit"})}};function ne(e,t){if(!e.outside)return void delete t.devDependencies;const n=t.devDependencies||{},r=["artillery","concurrently","conventional-changelog-conventionalcommits","eslint","husky","imagemin","jest","kill-port","lint-staged","open-cli","playwright","prettier","pinst","sort-package-json","wait-on","semantic-release","vitest"];for(const t of Object.keys(n))(r.some((e=>t.includes(e)))||!e.outside&&t.includes("willbooster")&&t.includes("config"))&&delete n[t]}function re(e){const t=["check","deploy","format","lint","start","test"],n=["pinst ","husky "],r=e.scripts||{};for(const[e,s]of Object.entries(r))(t.some((t=>e.includes(t)))||n.some((e=>s.includes(e)||s.trim()===e.trim())))&&delete r[e]}function se(e){delete e.private,delete e.publishConfig,delete e.prettier}const oe=new class{deploy(e){return"PRISMA migrate deploy"}deployForce(e,t){const n=e.packageJson.dependencies?.blitz?"db":"prisma";return`rm -Rf ${n}/mount/prod.sqlite3*; PRISMA migrate reset --force && rm -Rf ${n}/mount/prod.sqlite3*\n && litestream restore -o ${n}/mount/prod.sqlite3 ${t} && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`}litestream(e){return`${R} -e '\nconst { PrismaClient } = require("@prisma/client");\nnew PrismaClient().$queryRaw\`PRAGMA journal_mode = WAL;\`\n .catch((error) => { console.log("Failed due to:", error); process.exit(1); });\n'`}migrate(e){return`PRISMA migrate deploy && PRISMA generate && ${this.seed(e)}`}migrateDev(e){return"PRISMA migrate dev"}reset(e){return`PRISMA migrate reset --force --skip-seed && ${this.seed(e)}`}restore(e,t,n){return`rm -Rf ${e.packageJson.dependencies?.blitz?"db":"prisma"}/restored.sqlite3; GOOGLE_APPLICATION_CREDENTIALS=gcp-sa-key.json litestream restore -o ${n} ${t}`}seed(e,t){return e.packageJson.dependencies?.blitz?"YARN blitz db seed"+(t?` -f ${t}`:""):t?"BUN build-ts run prisma/seeds.ts":e.packageJson.prisma?.seed?"YARN prisma db seed":'if [ -e "prisma/seeds.ts" ]; then BUN build-ts run prisma/seeds.ts; fi'}studio(t,n){let r="";if(n)try{new URL(n),r=`DATABASE_URL=${n} `}catch{const t=e.resolve(n);console.info(n,t),r=`DATABASE_URL=file://${t} `}return`${r}PRISMA studio`}},ie={},ae={command:"prisma",describe:"Run prisma commands",builder:e=>e.command(ce).command(le).command(ue).command(pe).command(me).command(fe).command(he).command(ge).command(we).command(ye).demandCommand(),handler(){}},ce={command:"deploy",describe:"Apply migration to DB without initializing it",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma deploy",t))await Y(oe.deploy(n),n,e)}},de={...ie,"backup-path":{description:"Whether to skip actual command execution",demandOption:!0,type:"string",alias:"b"}},le={command:"deploy-force <backup-path>",describe:"Force to apply migration to DB utilizing Litestream's backup without initializing it",builder:de,async handler(e){const t=await be(e);for(const n of ee("prisma deploy-force",t))await Y(oe.deployForce(n,e.backupPath),n,e)}},ue={command:"litestream",describe:"Setup DB for Litestream",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma litestream",t))await Y(oe.litestream(n),n,e)}},pe={command:"migrate",describe:"Apply migration to DB with initializing it",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma migrate",t))await Y(oe.migrate(n),n,e)}},me={command:"migrate-dev",describe:"Create a migration file",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma migrate-dev",t))await Y(oe.migrateDev(n),n,e)}},fe={command:"reset",describe:"Reset DB",builder:ie,async handler(e){const t=await be(e);for(const n of ee("prisma reset",t))await Y(oe.reset(n),n,e)}},he={command:"restore <backup-path>",describe:"Restore DB from Litestream's backup",builder:{...de,output:{description:'Output path of the restored database. Defaults to "<db|prisma>/restored.sqlite3".',type:"string"}},async handler(e){const t=await be(e);for(const n of ee("prisma restore",t)){const t=e.output||(n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3");await Y(oe.restore(n,e.backupPath,t),n,e)}}},ge={command:"seed",describe:"Populate DB with seed data",builder:{...ie,file:{alias:"f",description:"Path of the seed script.",type:"string"}},async handler(e){const t=await be(e);for(const n of ee("prisma seed",t))await Y(oe.seed(n,e.file),n,e)}},we={command:"studio [db-url-or-path]",describe:"Open Prisma Studio",builder:{...ie,"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 be(e);for(const n of ee("prisma studio",t)){const t=e.restored?n.packageJson.dependencies?.blitz?"db/restored.sqlite3":"prisma/restored.sqlite3":e.dbUrlOrPath?.toString();await Y(oe.studio(n,t),n,e)}}},ye={command:"$0 [args..]",describe:"Pass the command and arguments to prisma as is",builder:{args:{type:"array"}},async handler(e){const t=await be(e),n=`${e.args?.join(" ")??""}`.trimEnd();for(const r of ee(`prisma ${n}`,t))await Y(`PRISMA ${n}`,r,e)}};async function be(e){const t=await P(e);t||(console.error(c.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(c.red("No prisma project found.")),process.exit(1)),n}const ve={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=x(e);t||(console.error(c.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${c.yellow(`#${s} Retrying: ${n.join(" ")}`)}`),r=await Y(n.join(" "),t,e,{exitIfFailed:!1}),0===r)return;process.exit(r)}},ke=["express","fastify","elysia"],$e={command:"setup",describe:"Setup development environment. .env files are ignored.",builder:{},async handler(e){await async function(e,t){const n=await P(e,!1,t);n||(console.error(c.red("No project found.")),process.exit(1));for(const t of ee("setup",n.descendants)){const s=await f.readdir(t.dirPath,{withFileTypes:!0});if(t===n.root){if("darwin"===h.platform()){const n=["pstree"];t.hasDockerfile&&n.push("expect"),await M(`brew install ${n.join(" ")}`,t,e)}s.some((e=>e.isFile()&&e.name.includes("-version")))&&await Y("asdf install",t,e)}if(s.some((e=>e.isFile()&&"pyproject.toml"===e.name))){await M("poetry config virtualenvs.in-project true",t,e),await M("poetry config virtualenvs.prefer-active-python true",t,e);const[,n]=r.execSync("asdf current python").toString().trim().split(/\s+/);await M(`poetry env use ${n}`,t,e),await J.promiseAll(),await Y("poetry run pip install --upgrade pip",t,e),await Y("poetry install --ansi",t,e)}const o=t.packageJson.dependencies??{},i=t.packageJson.devDependencies||{},a=t.packageJson.scripts??{},c=[];let d=[];o.blitz||o.next||i["@remix-run/dev"]?(c.push("pm2"),d.push("concurrently","open-cli","vitest","wait-on")):ke.some((e=>o[e]))&&(c.push("pm2"),d.push("concurrently","vitest","wait-on")),S&&(d=d.filter((e=>"vitest"!==e))),c.length>0&&await Y(`${D} add ${c.join(" ")}`,t,e),d.length>0&&await Y(`${D} add -D ${d.join(" ")}`,t,e),a["gen-code"]&&await Y(`${_} gen-code`,t,e)}}(e)}};const Ee=new class{buildDevImage(t,n){const r=t.dockerPackageJson.scripts?.["docker/build/prepare"]?"yarn run docker/build/prepare && ":"";return`cd ${e.dirname(t.findFile("Dockerfile"))}\n && ${r}YARN wb optimizeForDockerBuild --outside\n && YARN wb retry -- docker build -t ${t.dockerImageName}\n --build-arg ARCH=$([ $(uname -m) = 'arm64' ] && echo arm64 || echo amd64)\n --build-arg WB_ENV=${t.env.WB_ENV}\n --build-arg WB_VERSION=${n} .`}stopAndStart(e,t=!1,n="",r=""){return`${this.stop(e)} && ${t?"unbuffer ":""}${this.start(e,n,r)}`}start(e,t="",n=""){return function(e,t){const n=async()=>{if(z.has(e))return;z.add(e),L(e,t);const{status:n}=o(e,{cwd:t.dirPath,shell:!0,stdio:"inherit"});G(e,n,{})};for(const e of["beforeExit","SIGINT","SIGTERM","SIGQUIT"])process.on(e,n)}(this.stop(e),e),`docker run --rm -it -p 8080: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 Ae{constructor(e=Number(process.env.PORT)||3e3){this.defaultPort=e}buildDocker(e,t="development"){return Ee.buildDevImage(e,t)}startDocker(e,t){return`${this.buildDocker(e)}\n && YARN concurrently --raw --kill-others-on-fail\n "${Ee.stopAndStart(e,!1,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}"\n "${this.waitAndOpenApp(e,t,8080)}"`}testE2E(e,t,{playwrightArgs:n="test tests/e2e",prismaDirectory:r,startCommand:s}){const o=e.env.WB_ENV,i=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"";return`WB_ENV=${o} NEXT_PUBLIC_WB_ENV=${o} APP_ENV=${o} PORT=8080 YARN concurrently --kill-others --raw --success first\n "rm -Rf ${r}/mount && ${s} && exit 1"\n "concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n && BUN playwright ${"test tests/e2e"===n&&t.target?n.replace("tests/e2e",t.target):n}${i}"`}testE2EDev(e,t,{playwrightArgs:n="test tests/e2e",startCommand:r}){const s=e.env.WB_ENV,o=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"";return`WB_ENV=${s} NEXT_PUBLIC_WB_ENV=${s} APP_ENV=${s} PORT=8080 YARN concurrently --kill-others --raw --success first\n "${r} && exit 1"\n "concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n && BUN playwright ${"test tests/e2e"===n&&t.target?n.replace("tests/e2e",t.target):n}${o}"`}testUnit(e,t){return`WB_ENV=${e.env.WB_ENV} YARN vitest run ${t.target||"tests/unit"} --color --passWithNoTests --allowOnly`}waitApp(e,t,n=this.defaultPort){return`wait-on -t 10000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 10000 -i 500 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 10000 -i 1000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 10000 -i 2000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 20000 -i 4000 http-get://127.0.0.1:${n} 2> /dev/null\n || wait-on -t 60000 -i 5000 http-get://127.0.0.1:${n}`}waitAndOpenApp(e,t,n=this.defaultPort){return`${this.waitApp(e,t,n)} || wait-on http-get://127.0.0.1:${n} && open-cli http://\${HOST:-localhost}:${n}`}}const Ne=new class extends Ae{constructor(){super()}start(e,t){return`${e.env.WB_ENV?`APP_ENV=${e.env.WB_ENV} `:""}YARN concurrently --raw --kill-others-on-fail\n "blitz dev ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t)}"`}startProduction(e,t,n){return`${e.env.WB_ENV?`APP_ENV=${e.env.WB_ENV} `:""}NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n "${oe.reset(e)} && ${e.buildCommand} && PORT=${n} pm2-runtime start ${e.findFile("ecosystem.config.cjs")} ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t,n)}"`}testE2E(e,t,{playwrightArgs:n,startCommand:r=`${oe.reset(e)} && ${e.buildCommand} && pm2-runtime start ${e.findFile("ecosystem.config.cjs")}`}){return super.testE2E(e,t,{playwrightArgs:n,prismaDirectory:"db",startCommand:r})}testE2EDev(e,t,{playwrightArgs:n,startCommand:r="blitz dev -p 8080"}){return super.testE2EDev(e,t,{playwrightArgs:n,startCommand:r})}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "blitz dev" "${this.waitApp(e,t)}"`}};const xe=new class extends Ae{constructor(){super()}start(e,t){return`YARN build-ts run src/index.ts ${t.watch?"--watch":""} -- ${t.normalizedArgsText??""}`}startDocker(e,t){return`${this.buildDocker(e)} && ${Ee.stopAndStart(e,!1,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProduction(e,t,n=8080){return`NODE_ENV=production ${e.buildCommand} && NODE_ENV=production PORT=\${PORT:-${n}} ${R} dist/index.js ${t.normalizedArgsText??""}`}testE2E(e,t,{startCommand:n=`${e.hasPrisma?"prisma migrate reset --force --skip-generate && ":""}(${this.startProduction(e,t)})`}){const r=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"";return`NODE_ENV=production WB_ENV=${e.env.WB_ENV} PORT=8080 YARN concurrently --kill-others --raw --success first\n "${n} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${t.target||"tests/e2e"} --color --passWithNoTests --allowOnly${r}"`}testE2EDev(e,t,{startCommand:n}){const r=e.packageJson.scripts?.["test/e2e-additional"]?" && YARN test/e2e-additional":"";return`NODE_ENV=production WB_ENV=${e.env.WB_ENV} PORT=8080 YARN concurrently --kill-others --raw --success first\n "${n||this.start(e,t)} && exit 1"\n "wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${t.target||"tests/e2e"} --color --passWithNoTests --allowOnly${r}"`}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "${this.start(e,t)}" "${this.waitApp(e,t)}"`}};const Pe=new class extends Ae{constructor(){super()}start(e,t){return`YARN concurrently --raw --kill-others-on-fail\n "next dev --turbo ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t)}"`}startProduction(e,t,n){return`NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n "${[...e.hasPrisma?[oe.reset(e)]:[],e.buildCommand,`PORT=${n} pm2-runtime start ${e.findFile("ecosystem.config.cjs")} ${t.normalizedArgsText??""}`].join(" && ")}"\n "${this.waitAndOpenApp(e,t,n)}"`}testE2E(e,t,n){return super.testE2E(e,t,{playwrightArgs:n.playwrightArgs,prismaDirectory:"db",startCommand:n.startCommand??[...e.hasPrisma?[oe.reset(e)]:[],e.buildCommand,`pm2-runtime start ${e.findFile("ecosystem.config.cjs")}`].join(" && ")})}testE2EDev(e,t,{startCommand:n="next dev --turbo -p 8080"}){return super.testE2EDev(e,t,{startCommand:n})}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "next dev --turbo" "${this.waitApp(e,t)}"`}};const je=new class extends Ae{constructor(){super()}start(e,t){return`YARN build-ts run src/index.ts ${t.watch?"--watch":""} -- ${t.normalizedArgsText??""}`}startDocker(e,t){return`${this.buildDocker(e)} && ${Ee.stopAndStart(e,!1,t.normalizedDockerOptionsText??"",t.normalizedArgsText??"")}`}startProduction(e,t){return`NODE_ENV=production ${e.buildCommand} && NODE_ENV=production ${R} dist/index.js ${t.normalizedArgsText??""}`}testE2E(){return"echo 'do nothing.'"}testE2EDev(){return"echo 'do nothing.'"}testStart(){return"echo 'do nothing.'"}};const Se=new class extends Ae{constructor(){super()}start(e,t){return`YARN concurrently --raw --kill-others-on-fail\n "remix dev ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t)}"`}startProduction(e,t,n){return`NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n "${oe.reset(e)} && ${e.buildCommand} && PORT=${n} pm2-runtime start ${e.findFile("ecosystem.config.cjs")} ${t.normalizedArgsText??""}"\n "${this.waitAndOpenApp(e,t,n)}"`}testE2E(e,t,{playwrightArgs:n,startCommand:r=`${oe.reset(e)} && ${e.buildCommand} && pm2-runtime start ${e.findFile("ecosystem.config.cjs")}`}){return super.testE2E(e,t,{playwrightArgs:n,prismaDirectory:"prisma",startCommand:r})}testE2EDev(e,t,{playwrightArgs:n,startCommand:r="remix dev"}){return super.testE2EDev(e,t,{playwrightArgs:n,startCommand:r})}testStart(e,t){return`YARN concurrently --kill-others --raw --success first "remix dev" "${this.waitApp(e,t)}"`}},Re={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",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 P(e);t||(console.error(c.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=Ne;else if(t.next)s=Pe;else if(r["@remix-run/dev"])s=Se;else if(ke.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=je}switch(console.info(`Running "start" for ${n.name} ...`),e.mode||"dev"){case"dev":case"development":{const r=De(t,"development");await Y(`${r}${s.start(n,e)}`,n,e);break}case"staging":{const r=De(t,"staging");await Y(`${r}${s.startProduction(n,e,8080)}`,n,e);break}case"docker":{const r=De(t,"staging");await Y(`${r}${s.startDocker(n,e)}`,n,e);break}case"docker-debug":{const r=De(t,"staging");e.normalizedArgsText="'/bin/bash'",await Y(`${r}${s.startDocker(n,e)}`,n,e);break}default:throw new Error(`Unknown start mode: ${e.mode}`)}}}};function De(e,t){process.env.WB_ENV||=t;let n=`WB_ENV=${process.env.WB_ENV} `;return e.next&&(process.env.NEXT_PUBLIC_WB_ENV=process.env.WB_ENV,n+=`NEXT_PUBLIC_WB_ENV=${process.env.WB_ENV} `),n}const _e={command:"test",describe:"Test project. If you pass no arguments, it will run all tests.",builder:{ci:{description:"Whether to run tests on CI",type:"boolean"},e2e:{description:"Whether to run e2e tests. You may pass mode as argument: none | headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace",type:"string"},start:{description:"Whether to run start tests",type:"boolean"},unit:{description:"Whether to run unit tests",type:"boolean"},"unit-timeout":{description:"Timeout for unit tests",type:"number"},target:{description:"Test target",type:"string",alias:"t"}},async handler(t){await async function(t){const n=await P(t);n||(console.error(c.red("No project found.")),process.exit(1));n.descendants.length>1&&(process.env.CI="1");process.env.FORCE_COLOR||="3",process.env.WB_ENV||="test";const r=void 0===t.e2e&&void 0===t.start&&void 0===t.unit;for(const s of n.descendants){const n=s.packageJson.dependencies||{},o=s.packageJson.devDependencies||{};let i;i=n.blitz?Ne:n.next?Pe:o["@remix-run/dev"]?Se:ke.some((e=>n[e]))&&!n["firebase-functions"]?xe:je,r&&(t={...t,e2e:a.existsSync(e.join(s.dirPath,"tests","e2e"))&&!t.target?.includes("/unit/")?"headless":"none",start:!0,unit:a.existsSync(e.join(s.dirPath,"tests","unit"))&&!t.target?.includes("/e2e/")}),console.info(`Running "test" for ${s.name} ...`);const c=[];if(!t.ci){switch(t.unit&&c.push(Y(i.testUnit(s,t),s,t,{timeout:t.unitTimeout})),t.start&&c.push(Y(i.testStart(s,t),s,t)),await Promise.all(c),t.e2e){case void 0:case"none":continue;case"":case"headless":await Y(i.testE2E(s,t,{}),s,t);continue;case"headless-dev":await Y(i.testE2EDev(s,t,{}),s,t);continue;case"docker":await Oe(s,t,i);continue;case"docker-debug":await Oe(s,t,i,`test ${t.target||"tests/e2e"} --debug`);continue}if(n.blitz||n.next||o["@remix-run/dev"])switch(t.e2e){case"headed":await Y(i.testE2E(s,t,{playwrightArgs:`test ${t.target||"tests/e2e"} --headed`}),s,t);continue;case"headed-dev":await Y(i.testE2EDev(s,t,{playwrightArgs:`test ${t.target||"tests/e2e"} --headed`}),s,t);continue;case"debug":await Y(i.testE2E(s,t,{playwrightArgs:`test ${t.target||"tests/e2e"} --debug`}),s,t);continue;case"generate":await Y(i.testE2E(s,t,{playwrightArgs:"codegen http://localhost:8080"}),s,t);continue;case"trace":await Y("BUN playwright show-trace",s,t);continue}throw new Error(`Unknown e2e mode: ${t.e2e}`)}if(await M(Ee.stopAll(),s,t),t.unit&&await M(i.testUnit(s,t).replaceAll(" --allowOnly",""),s,t,{timeout:t.unitTimeout}),t.start&&await M(i.testStart(s,t),s,t),await J.promiseAll(),"none"!==t.e2e){s.hasDockerfile&&await Y(`${i.buildDocker(s,"test")}`,s,t);const e=s.hasDockerfile?{startCommand:Ee.stopAndStart(s,!0)}:{};process.exitCode=await Y(i.testE2E(s,t,e).replaceAll(" --allowOnly",""),s,t,{exitIfFailed:!1}),await Y(Ee.stop(s),s,t)}}}(t)}};async function Oe(e,t,n,r){await Y(`${n.buildDocker(e,"test")}`,e,t),process.exitCode=await Y(`${n.testE2E(e,t,{playwrightArgs:r,startCommand:Ee.stopAndStart(e,!0)})}`,e,t,{exitIfFailed:!1}),await Y(Ee.stop(e),e,t)}const Te={command:"typecheck",describe:"Run type checking. .env files are ignored.",builder:{},async handler(e){const t=await P(e,!1);t||(console.error(c.red("No project found.")),process.exit(1));const n=t.descendants.map((n=>{const r=[];if(n.packageJson.workspaces?n.hasSourceCode&&(n.packageJson.dependencies?.typescript||n.packageJson.devDependencies?.typescript)&&r.push("BUN tsc --noEmit --Pretty"):((n.packageJson.dependencies?.typescript||n.packageJson.devDependencies?.typescript)&&r.push("BUN tsc --noEmit --Pretty"),n.packageJson.devDependencies?.pyright&&r.push("YARN pyright")),r.length>0)return M(r.join(" && "),n,e,{ci:t.descendants.length>1,forceColor:!0})})),r=await Promise.all(n);let s=0;for(const[e,n]of r.entries())if(n){(t.descendants[e].packageJson.dependencies||{}).blitz&&console.info(c.yellow('Please try "yarn gen-code" if you face unknown type errors.')),s=n}s&&process.exit(s)}},Be={...Te,command:"tc"},Ie={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"]}};await t(n(process.argv)).scriptName("wb").options(Ie).middleware((t=>{const n=t["working-dir"];if(n){const t=e.resolve(n);process.chdir(t)}!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(O).command(Z).command(te).command(ae).command(ve).command($e).command(Re).command(_e).command(Te).command(Be).demandCommand().strict().help().argv;for(const e of["SIGINT","SIGTERM","SIGQUIT"])process.on(e,(()=>process.exit()));
|
|
2
|
+
//# 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","../src/project.ts","../../../node_modules/at-decorators/dist/memoize.js","../../../node_modules/at-decorators/dist/hash.js","../src/utils/runtime.ts","../src/commands/buildIfNeeded.ts","../../shared-lib/src/error.ts","../src/utils/process.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/commands/prisma.ts","../src/commands/retry.ts","../src/commands/constants.ts","../src/commands/setup.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/start.ts","../src/scripts/builder.ts","../src/commands/test.ts","../src/commands/typecheck.ts","../src/sharedOptionsBuilder.ts","../src/index.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\n\nimport { config } from 'dotenv';\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. Note it does not assign them in `process.env`.\n * */\nexport function readEnvironmentVariables(\n  argv: EnvReaderOptions,\n  cwd: string,\n  cacheEnabled = true\n): Record<string, string> {\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.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);\n  }\n\n  let envVars: Record<string, string> = {};\n  const orgEnvVars = { ...process.env };\n  for (const envPath of envPaths) {\n    envVars = { ...readEnvFile(path.join(cwd, envPath), cacheEnabled), ...envVars };\n    let count = 0;\n    for (const [key, value] of Object.entries(envVars)) {\n      if (orgEnvVars[key] !== value) {\n        orgEnvVars[key] = value;\n        count++;\n      }\n    }\n    if (count > 0) {\n      console.info(`Read ${count} environment variables:`, envPath);\n    }\n  }\n\n  if (argv.checkEnv) {\n    const exampleKeys = Object.keys(readEnvFile(path.join(cwd, argv.checkEnv), cacheEnabled) || {});\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 envVars;\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  cacheEnabled = true\n): Record<string, string | undefined> {\n  const envVars = readEnvironmentVariables(argv, cwd, cacheEnabled);\n  Object.assign(process.env, envVars);\n  return envVars;\n}\n\nconst cachedEnvVars = new Map<string, Record<string, string>>();\n\nfunction readEnvFile(filePath: string, cacheEnabled = true): Record<string, string> {\n  const cached = cacheEnabled && cachedEnvVars.get(filePath);\n  if (cached) return cached;\n\n  const parsed = config({ path: path.resolve(filePath), processEnv: {} }).parsed ?? {};\n  if (cacheEnabled) {\n    cachedEnvVars.set(filePath, parsed);\n  }\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      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\nexport type SpawnAsyncReturns = Omit<SpawnSyncReturns<string>, 'output' | 'error'>;\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;\n  mergeOutAndError?: boolean;\n  killOnExit?: boolean;\n  verbose?: boolean;\n};\n\nexport async function spawnAsync(\n  command: string,\n  args?: ReadonlyArray<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      proc.stdout?.setEncoding?.('utf8');\n      proc.stderr?.setEncoding?.('utf8');\n\n      let stdout = '';\n      let stderr = '';\n      proc.stdout?.on('data', (data) => {\n        stdout += data;\n      });\n      proc.stderr?.on('data', (data) => {\n        if (options?.mergeOutAndError) {\n          stdout += data;\n        } else {\n          stderr += 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      reject(error);\n    }\n  });\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 { memoizeFactory } from 'at-decorators';\nimport { globby } from 'globby';\nimport type { PackageJson } from 'type-fest';\n\nconst memoize = memoizeFactory({ maxCachedThisSize: Number.MAX_SAFE_INTEGER, maxCachedArgsSize: 1 });\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  @memoize\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  @memoize\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  @memoize\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  @memoize\n  get dockerfile(): string {\n    return fs.readFileSync(this.findFile('Dockerfile'), 'utf8');\n  }\n\n  @memoize\n  get hasDockerfile(): boolean {\n    try {\n      return !!this.findFile('Dockerfile');\n    } catch {\n      return false;\n    }\n  }\n\n  @memoize\n  get hasSourceCode(): boolean {\n    return fs.existsSync(path.join(this.dirPath, 'src'));\n  }\n\n  @memoize\n  get name(): string {\n    return this.packageJson.name || 'unknown';\n  }\n\n  @memoize\n  get dockerImageName(): string {\n    const name = this.packageJson.name || 'unknown';\n    return name.replaceAll('@', '').replaceAll('/', '-');\n  }\n\n  @memoize\n  get env(): Record<string, string | undefined> {\n    return this.loadEnv ? { ...readEnvironmentVariables(this.argv, this.dirPath), ...process.env } : process.env;\n  }\n\n  @memoize\n  get packageJson(): PackageJson {\n    return JSON.parse(fs.readFileSync(this.packageJsonPath, 'utf8'));\n  }\n\n  @memoize\n  get packageJsonPath(): string {\n    return path.join(this.dirPath, 'package.json');\n  }\n\n  @memoize\n  get hasPrisma(): boolean {\n    return !!(this.packageJson.dependencies?.['prisma'] || this.packageJson.devDependencies?.['prisma']);\n  }\n\n  @memoize\n  get dockerPackageJson(): PackageJson {\n    return path.dirname(this.findFile('Dockerfile')) === this.dirPath\n      ? this.packageJson\n      : JSON.parse(fs.readFileSync(path.join(path.dirname(this.findFile('Dockerfile')), 'package.json'), 'utf8'));\n  }\n\n  @memoize\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","import{cyrb64HashWithLength as e}from\"./hash.js\";const t=s();function s({cacheDuration:t=Number.POSITIVE_INFINITY,caches:s,calcKey:n=(t=>e(JSON.stringify(t))),maxCachedArgsSize:i=100,maxCachedThisSize:c=10}={}){return function(e,o){if(\"getter\"===o?.kind){const n=new Map;return s?.push(n),function(){const s=Date.now();if(n.has(this)){const[e,i]=n.get(this);if(s-i<=t)return e}const i=e.call(this);if(n.size>=c){const e=n.keys().next().value;n.delete(e)}return n.set(this,[i,s]),i}}{const r=new Map;return s?.push(r),function(...s){const a=n(s);let h=r.get(this);const u=Date.now();if(h){if(h.has(a)){const[e,s]=h.get(a);if(u-s<=t)return e}}else{if(h=new Map,r.size>=c){const e=r.keys().next().value;r.delete(e)}r.set(this,h)}const f=o?e.call(this,...s):e(...s);if(h.size>=i){const e=h.keys().next().value;h.delete(e)}return h.set(a,[f,u]),f}}}}export{t as memoize,s as memoizeFactory};\n//# sourceMappingURL=memoize.js.map\n","function t(t,n=0){const[i,r]=function(t,n=0){let i=3735928559^n,r=1103547991^n;for(let n,a=0;a<t.length;a++)n=t.codePointAt(a),i=Math.imul(i^n,2654435761),r=Math.imul(r^n,1597334677);return i=Math.imul(i^i>>>16,2246822507),i^=Math.imul(r^r>>>13,3266489909),r=Math.imul(r^r>>>16,2246822507),r^=Math.imul(i^i>>>13,3266489909),[r>>>0,i>>>0]}(t,n);return t.length.toString(36)+i.toString(36).padStart(7,\"0\")+r.toString(36).padStart(7,\"0\")}export{t as cyrb64HashWithLength};\n//# sourceMappingURL=hash.js.map\n","export const isRunningOnBun = process.argv[0].endsWith('/bun') || 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 { 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\nfunction build(project: Project, argv: Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder>>>): boolean {\n  argv = { ...argv, command: argv.command ?? (isRunningOnBun ? 'bun run build' : 'yarn build') };\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\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 = await findSelfProject(argv, true, projectPathForTesting);\n  if (!project) {\n    console.error(chalk.red('No project found.'));\n    return true;\n  }\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\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      .sort(([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/'];\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', ['diff', '--name-only'], {\n      cwd: project.dirPath,\n      env: project.env,\n      stdio: 'pipe',\n      encoding: 'utf8',\n    });\n    const filePaths = ret.stdout\n      .trim()\n      .split('\\n')\n      .map((filePath) =>\n        project.env.WB_ENV === 'test' ? filePath.replace(/packages\\/scripts\\/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) => {\n      hash.update(data);\n      if (argv.verbose) {\n        console.info(data.toString());\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  sleepMilliseconds?: 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 */\nexport async function withRetry<T>(\n  func: (failedCount: number) => Promise<T>,\n  { beforeRetry, handleError, retryCount = 3, retryLogger, sleepMilliseconds = 0 }: 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 (sleepMilliseconds > 0) {\n        await sleep(sleepMilliseconds);\n      }\n      retryLogger?.(`Retry due to: ${error instanceof Error ? error.stack : error}`);\n      await beforeRetry?.(error);\n    }\n  }\n}\n","import { spawnSync } from 'node:child_process';\n\nimport killPortProcess from 'kill-port';\n\nimport type { Project } from '../project.js';\nimport { printFinishedAndExitIfNeeded, printStart } from '../scripts/run.js';\n\nconst killed = new Set<number | string>();\n\nexport async function killPortProcessImmediatelyAndOnExit(port: number): Promise<void> {\n  await killPortProcessHandlingErrors(port);\n  const killFunc = async (): Promise<void> => {\n    if (killed.has(port)) return;\n\n    killed.add(port);\n    await killPortProcessHandlingErrors(port);\n  };\n  for (const signal of ['beforeExit', 'SIGINT', 'SIGTERM', 'SIGQUIT']) {\n    process.on(signal, killFunc);\n  }\n}\n\nasync function killPortProcessHandlingErrors(port: number): Promise<void> {\n  try {\n    await killPortProcess(port);\n  } catch {\n    // do nothing\n  }\n}\n\nexport function spawnSyncOnExit(script: string, project: Project): void {\n  const killFunc = async (): Promise<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 { 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 { killPortProcessImmediatelyAndOnExit } from '../utils/process.js';\nimport { promisePool } from '../utils/promisePool.js';\nimport { isRunningOnBun, packageManagerWithRun } from '../utils/runtime.js';\n\ninterface Options {\n  ci?: boolean;\n  exitIfFailed?: boolean;\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 [printableScript, runnableScript] = normalizeScript(script, project);\n  printStart(printableScript, project);\n  if (argv.verbose) {\n    printStart(runnableScript, project, 'Start (raw)', true);\n  }\n  if (argv.dryRun) {\n    printFinishedAndExitIfNeeded(printableScript, 0, opts);\n    return 0;\n  }\n\n  const port = runnableScript.match(/http-get:\\/\\/127.0.0.1:(\\d+)/)?.[1];\n  if (runnableScript.includes('wait-on') && port && !runnableScript.includes('docker run')) {\n    await killPortProcessImmediatelyAndOnExit(Number(port));\n  }\n  const ret = await spawnAsync(runnableScript, 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  printFinishedAndExitIfNeeded(printableScript, 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 [printableScript, runnableScript] = normalizeScript(script, project);\n    printStart(printableScript, project, 'Start (parallel)', true);\n    if (argv.dryRun) {\n      printStart(printableScript, project, 'Started (log)');\n      if (argv.verbose) {\n        printStart(runnableScript, project, 'Started (raw)', true);\n      }\n      printFinishedAndExitIfNeeded(printableScript, 0, opts);\n      return 0;\n    }\n\n    const ret = await spawnAsync(runnableScript, 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    printStart(printableScript, project, 'Started (log)');\n    if (argv.verbose) {\n      printStart(runnableScript, 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(printableScript, 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): [string, string] {\n  let newScript = script\n    .replaceAll('\\n', '')\n    .replaceAll(/\\s\\s+/g, ' ')\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 ', project.isBunAvailable ? '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  return [\n    fixBunCommand(newScript.replaceAll('YARN ', `${packageManagerWithRun} `)),\n    fixBunCommand(\n      newScript.replaceAll('YARN ', !isRunningOnBun && project.binExists ? '' : `${packageManagerWithRun} `)\n    ),\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  return command.includes('next dev') || command.includes('pm2-runtime')\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 (filePath.endsWith('/test-fixtures') || filePath.includes('/test-fixtures/')) {\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 = argv.fix && argv.format ? 'check --fix' : argv.fix ? 'lint --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';\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('yarn', {\n        stdio: 'inherit',\n      });\n    }\n  },\n};\n\nfunction optimizeDevDependencies(argv: InferredOptionTypes<typeof builder>, packageJson: PackageJson): void {\n  if (!argv.outside) {\n    delete packageJson.devDependencies;\n    return;\n  }\n\n  const devDeps = packageJson.devDependencies || {};\n  const nameWordsToBeRemoved = [\n    'artillery',\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    'sort-package-json',\n    'wait-on',\n    'semantic-release',\n    'vitest',\n  ];\n  for (const name of Object.keys(devDeps)) {\n    if (\n      nameWordsToBeRemoved.some((word) => name.includes(word)) ||\n      (!argv.outside && name.includes('willbooster') && name.includes('config'))\n    ) {\n      delete devDeps[name];\n    }\n  }\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  for (const [name, content] of Object.entries(scripts)) {\n    if (\n      nameWordsOfUnnecessaryScripts.some((word) => name.includes(word)) ||\n      // Support \"husky\" since husky v9 requires `\"postinstall\": \"husky\"`\n      contentWordsOfUnnecessaryScripts.some((word) => content.includes(word) || content.trim() === word.trim())\n    ) {\n      delete scripts[name];\n    }\n  }\n}\n\nfunction optimizeRootProps(packageJson: PackageJson): void {\n  delete packageJson.private;\n  delete packageJson.publishConfig;\n  delete packageJson.prettier;\n}\n","import 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  deploy(_: Project): string {\n    return 'PRISMA migrate deploy';\n  }\n\n  deployForce(project: Project, backupPath: string): string {\n    const dirName = project.packageJson.dependencies?.['blitz'] ? 'db' : 'prisma';\n    // Don't skip \"migrate deploy\" because restored database may be older than the current schema.\n    return `rm -Rf ${dirName}/mount/prod.sqlite3*; PRISMA migrate reset --force && rm -Rf ${dirName}/mount/prod.sqlite3*\n      && litestream restore -o ${dirName}/mount/prod.sqlite3 ${backupPath} && ALLOW_TO_SKIP_SEED=0 PRISMA migrate deploy`;\n  }\n\n  litestream(_: Project): string {\n    return `${runtimeWithArgs} -e '\nconst { PrismaClient } = require(\"@prisma/client\");\nnew PrismaClient().$queryRaw\\`PRAGMA journal_mode = WAL;\\`\n  .catch((error) => { console.log(\"Failed due to:\", error); process.exit(1); });\n'`;\n  }\n\n  migrate(project: Project): string {\n    return `PRISMA migrate deploy && PRISMA generate && ${this.seed(project)}`;\n  }\n\n  migrateDev(_: Project): string {\n    return `PRISMA migrate dev`;\n  }\n\n  reset(project: Project): string {\n    // cf. https://www.prisma.io/docs/guides/database/seed-database#integrated-seeding-with-prisma-migrate\n    // Blitz does not trigger seed automatically, so we need to run it manually.\n    return `PRISMA migrate reset --force --skip-seed && ${this.seed(project)}`;\n    // I'm not sure why we need to remove all sqlite files, so I commented out the following line.\n    // return `true $(rm -Rf db/**/*.sqlite* 2> /dev/null) && true $(rm -Rf prisma/**/*.sqlite* 2> /dev/null) && PRISMA migrate reset --force --skip-seed && ${this.seed()}`;\n  }\n\n  restore(project: Project, backupPath: string, outputPath: string): string {\n    const dirName = project.packageJson.dependencies?.['blitz'] ? 'db' : 'prisma';\n    return `rm -Rf ${dirName}/restored.sqlite3; GOOGLE_APPLICATION_CREDENTIALS=gcp-sa-key.json litestream restore -o ${outputPath} ${backupPath}`;\n  }\n\n  seed(project: Project, scriptPath?: string): string {\n    if (project.packageJson.dependencies?.['blitz'])\n      return `YARN blitz db seed${scriptPath ? ` -f ${scriptPath}` : ''}`;\n    if (scriptPath) return 'BUN build-ts run prisma/seeds.ts';\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, dbUrlOrPath?: string): string {\n    let prefix = '';\n    if (dbUrlOrPath) {\n      try {\n        new URL(dbUrlOrPath);\n        prefix = `DATABASE_URL=${dbUrlOrPath} `;\n      } catch {\n        const absolutePath = path.resolve(dbUrlOrPath);\n        console.info(dbUrlOrPath, absolutePath);\n        prefix = `DATABASE_URL=file://${absolutePath} `;\n      }\n    }\n    return `${prefix}PRISMA studio`;\n  }\n}\n\nexport const prismaScripts = new PrismaScripts();\n","import 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';\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(deployCommand)\n      .command(deployForceCommand)\n      .command(litestreamCommand)\n      .command(migrateCommand)\n      .command(migrateDevCommand)\n      .command(resetCommand)\n      .command(restoreCommand)\n      .command(seedCommand)\n      .command(studioCommand)\n      .command(defaultCommand)\n      .demandCommand();\n  },\n  handler() {\n    // Do nothing\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    for (const project of prepareForRunningCommand('prisma deploy', allProjects)) {\n      await runWithSpawn(prismaScripts.deploy(project), project, argv);\n    }\n  },\n};\n\nconst deployForceBuilder = {\n  ...builder,\n  'backup-path': {\n    description: 'Whether to skip actual command execution',\n    demandOption: true,\n    type: 'string',\n    alias: 'b',\n  },\n} as const;\n\nconst deployForceCommand: CommandModule<unknown, InferredOptionTypes<typeof deployForceBuilder>> = {\n  command: 'deploy-force <backup-path>',\n  describe: \"Force to apply migration to DB utilizing Litestream's backup without initializing it\",\n  builder: deployForceBuilder,\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, argv.backupPath), project, argv);\n    }\n  },\n};\n\nconst litestreamCommand: CommandModule<unknown, InferredOptionTypes<typeof builder>> = {\n  command: '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 litestream', allProjects)) {\n      await runWithSpawn(prismaScripts.litestream(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    for (const project of prepareForRunningCommand('prisma migrate', allProjects)) {\n      await runWithSpawn(prismaScripts.migrate(project), 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    for (const project of prepareForRunningCommand('prisma migrate-dev', allProjects)) {\n      await runWithSpawn(prismaScripts.migrateDev(project), 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    for (const project of prepareForRunningCommand('prisma reset', allProjects)) {\n      await runWithSpawn(prismaScripts.reset(project), project, argv);\n    }\n  },\n};\n\nconst restoreBuilder = {\n  ...deployForceBuilder,\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 <backup-path>',\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 ||\n        (project.packageJson.dependencies?.['blitz'] ? 'db/restored.sqlite3' : 'prisma/restored.sqlite3');\n      await runWithSpawn(prismaScripts.restore(project, argv.backupPath, 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    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), 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    for (const project of prepareForRunningCommand(`prisma ${script}`, allProjects)) {\n      await runWithSpawn(`PRISMA ${script}`, project, argv);\n    }\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","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      });\n      if (lastStatus === 0) return;\n    }\n    process.exit(lastStatus);\n  },\n};\n","export const httpServerPackages = ['express', 'fastify', 'elysia'];\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 { isRunningOnBun, packageManagerWithRun, packageManager } from '../utils/runtime.js';\n\nimport { prepareForRunningCommand } from './commandUtils.js';\nimport { httpServerPackages } from './constants.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        if (project.hasDockerfile) {\n          packages.push('expect');\n        }\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);\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      await runWithSpawnInParallel('poetry config virtualenvs.prefer-active-python 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    const deps = project.packageJson.dependencies ?? {};\n    const devDeps = project.packageJson.devDependencies || {};\n    const scripts = project.packageJson.scripts ?? {};\n    const newDeps: string[] = [];\n    let newDevDeps: string[] = [];\n    if (deps['blitz'] || deps['next']) {\n      newDeps.push('pm2');\n      newDevDeps.push('concurrently', 'open-cli', 'vitest', 'wait-on');\n    } else if (devDeps['@remix-run/dev']) {\n      newDeps.push('pm2');\n      newDevDeps.push('concurrently', 'open-cli', 'vitest', 'wait-on');\n    } else if (httpServerPackages.some((p) => deps[p])) {\n      newDeps.push('pm2');\n      newDevDeps.push('concurrently', 'vitest', 'wait-on');\n    }\n    if (isRunningOnBun) {\n      newDevDeps = newDevDeps.filter((dep) => dep !== 'vitest');\n    }\n    if (newDeps.length > 0) {\n      await runWithSpawn(`${packageManager} add ${newDeps.join(' ')}`, project, argv);\n    }\n    if (newDevDeps.length > 0) {\n      await runWithSpawn(`${packageManager} add -D ${newDevDeps.join(' ')}`, project, argv);\n    }\n    if (scripts['gen-code']) {\n      await runWithSpawn(`${packageManagerWithRun} gen-code`, project, argv);\n    }\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  buildDevImage(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 amd64)\n        --build-arg WB_ENV=${project.env.WB_ENV}\n        --build-arg WB_VERSION=${version} .`;\n  }\n  stopAndStart(project: Project, unbuffer = false, additionalOptions = '', additionalArgs = ''): string {\n    return `${this.stop(project)} && ${unbuffer ? 'unbuffer ' : ''}${this.start(\n      project,\n      additionalOptions,\n      additionalArgs\n    )}`;\n  }\n  start(project: Project, additionalOptions = '', additionalArgs = ''): string {\n    spawnSyncOnExit(this.stop(project), project);\n    return `docker run --rm -it -p 8080: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 type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nexport interface TestE2EDevOptions {\n  // '--e2e generate' calls 'codegen http://localhost:8080'\n  playwrightArgs?: string;\n  startCommand?: string;\n}\n\nexport interface TestE2EOptions extends TestE2EDevOptions {\n  prismaDirectory?: 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  protected constructor(private readonly defaultPort = Number(process.env.PORT) || 3000) {}\n\n  buildDocker(project: Project, version = 'development'): string {\n    return dockerScripts.buildDevImage(project, version);\n  }\n\n  abstract start(project: Project, argv: ScriptArgv): string;\n\n  abstract startProduction(project: Project, argv: ScriptArgv, port: number): string;\n\n  startDocker(project: Project, argv: ScriptArgv): string {\n    return `${this.buildDocker(project)}\n      && YARN concurrently --raw --kill-others-on-fail\n        \"${dockerScripts.stopAndStart(\n          project,\n          false,\n          argv.normalizedDockerOptionsText ?? '',\n          argv.normalizedArgsText ?? ''\n        )}\"\n        \"${this.waitAndOpenApp(project, argv, 8080)}\"`;\n  }\n\n  testE2E(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs = 'test tests/e2e', prismaDirectory, startCommand }: TestE2EOptions\n  ): string {\n    // Basically, `playwright` (not `yarn playwright`) should work,\n    // but it doesn't work on a project depending on `artillery-engine-playwright`.\n    // So we use `yarn playwright` instead of `playwright` here.\n    const env = project.env.WB_ENV;\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    return `WB_ENV=${env} NEXT_PUBLIC_WB_ENV=${env} APP_ENV=${env} PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"rm -Rf ${prismaDirectory}/mount && ${startCommand} && exit 1\"\n      \"concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n        && BUN playwright ${playwrightArgs === 'test tests/e2e' && argv.target ? playwrightArgs.replace('tests/e2e', argv.target) : playwrightArgs}${suffix}\"`;\n  }\n\n  testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs = 'test tests/e2e', startCommand }: TestE2EDevOptions\n  ): string {\n    const env = project.env.WB_ENV;\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    return `WB_ENV=${env} NEXT_PUBLIC_WB_ENV=${env} APP_ENV=${env} PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"concurrently --kill-others-on-fail --raw 'wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080' 'BUN playwright install --with-deps'\n        && BUN playwright ${playwrightArgs === 'test tests/e2e' && argv.target ? playwrightArgs.replace('tests/e2e', argv.target) : playwrightArgs}${suffix}\"`;\n  }\n\n  abstract testStart(project: Project, argv: ScriptArgv): string;\n\n  testUnit(project: Project, argv: TestArgv): string {\n    // Since this command is referred from other commands, we have to use \"vitest run\" (non-interactive mode).\n    return `WB_ENV=${project.env.WB_ENV} YARN vitest run ${argv.target || 'tests/unit'} --color --passWithNoTests --allowOnly`;\n  }\n\n  protected waitApp(project: Project, argv: ScriptArgv, port = this.defaultPort): string {\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}`;\n  }\n\n  protected waitAndOpenApp(project: Project, argv: ScriptArgv, port = this.defaultPort): string {\n    return `${this.waitApp(\n      project,\n      argv,\n      port\n    )} || wait-on http-get://127.0.0.1:${port} && open-cli http://\\${HOST:-localhost}:${port}`;\n  }\n}\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    const appEnv = project.env.WB_ENV ? `APP_ENV=${project.env.WB_ENV} ` : '';\n    return `${appEnv}YARN concurrently --raw --kill-others-on-fail\n      \"blitz dev ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv)}\"`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port: number): string {\n    const appEnv = project.env.WB_ENV ? `APP_ENV=${project.env.WB_ENV} ` : '';\n    return `${appEnv}NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n      \"${prismaScripts.reset(project)} && ${project.buildCommand} && PORT=${port} pm2-runtime start ${project.findFile(\n        'ecosystem.config.cjs'\n      )} ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv, port)}\"`;\n  }\n\n  override testE2E(\n    project: Project,\n    argv: TestArgv,\n    {\n      playwrightArgs,\n      startCommand = `${prismaScripts.reset(project)} && ${\n        project.buildCommand\n      } && pm2-runtime start ${project.findFile('ecosystem.config.cjs')}`,\n    }: TestE2EOptions\n  ): string {\n    return super.testE2E(project, argv, {\n      playwrightArgs,\n      prismaDirectory: 'db',\n      startCommand,\n    });\n  }\n\n  override testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs, startCommand = 'blitz dev -p 8080' }: TestE2EDevOptions\n  ): string {\n    return super.testE2EDev(project, argv, { playwrightArgs, startCommand });\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"blitz dev\" \"${this.waitApp(project, argv)}\"`;\n  }\n}\n\nexport const blitzScripts = new BlitzScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport { runtimeWithArgs } from '../../utils/runtime.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { dockerScripts } from '../dockerScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run src/index.ts ${argv.watch ? '--watch' : ''} -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  override startDocker(project: Project, argv: ScriptArgv): string {\n    return `${this.buildDocker(project)} && ${dockerScripts.stopAndStart(\n      project,\n      false,\n      argv.normalizedDockerOptionsText ?? '',\n      argv.normalizedArgsText ?? ''\n    )}`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port = 8080): string {\n    return `NODE_ENV=production ${\n      project.buildCommand\n    } && NODE_ENV=production PORT=\\${PORT:-${port}} ${runtimeWithArgs} dist/index.js ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  override testE2E(\n    project: Project,\n    argv: TestArgv,\n    {\n      startCommand = `${project.hasPrisma ? 'prisma migrate reset --force --skip-generate && ' : ''}(${this.startProduction(\n        project,\n        argv\n      )})`,\n    }: TestE2EOptions\n  ): string {\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    return `NODE_ENV=production WB_ENV=${project.env.WB_ENV} PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"${startCommand} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${argv.target || 'tests/e2e'} --color --passWithNoTests --allowOnly${suffix}\"`;\n  }\n\n  override testE2EDev(project: Project, argv: TestArgv, { startCommand }: TestE2EDevOptions): string {\n    const suffix = project.packageJson.scripts?.['test/e2e-additional'] ? ' && YARN test/e2e-additional' : '';\n    return `NODE_ENV=production WB_ENV=${\n      project.env.WB_ENV\n    } PORT=8080 YARN concurrently --kill-others --raw --success first\n      \"${startCommand || this.start(project, argv)} && exit 1\"\n      \"wait-on -t 600000 -i 2000 http-get://127.0.0.1:8080 && vitest run ${argv.target || 'tests/e2e'} --color --passWithNoTests --allowOnly${suffix}\"`;\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"${this.start(project, argv)}\" \"${this.waitApp(\n      project,\n      argv\n    )}\"`;\n  }\n}\n\nexport const httpServerScripts = new HttpServerScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"next dev --turbo ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv)}\"`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port: number): string {\n    return `NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n      \"${[\n        ...(project.hasPrisma ? [prismaScripts.reset(project)] : []),\n        project.buildCommand,\n        `PORT=${port} pm2-runtime start ${project.findFile('ecosystem.config.cjs')} ${argv.normalizedArgsText ?? ''}`,\n      ].join(' && ')}\"\n      \"${this.waitAndOpenApp(project, argv, port)}\"`;\n  }\n\n  override testE2E(project: Project, argv: TestArgv, options: TestE2EOptions): string {\n    return super.testE2E(project, argv, {\n      playwrightArgs: options.playwrightArgs,\n      prismaDirectory: 'db',\n      startCommand:\n        options.startCommand ??\n        [\n          ...(project.hasPrisma ? [prismaScripts.reset(project)] : []),\n          project.buildCommand,\n          `pm2-runtime start ${project.findFile('ecosystem.config.cjs')}`,\n        ].join(' && '),\n    });\n  }\n\n  override testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { startCommand = 'next dev --turbo -p 8080' }: TestE2EDevOptions\n  ): string {\n    return super.testE2EDev(project, argv, { startCommand });\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"next dev --turbo\" \"${this.waitApp(project, argv)}\"`;\n  }\n}\n\nexport const nextScripts = new NextScripts();\n","import type { Project } from '../../project.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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN build-ts run src/index.ts ${argv.watch ? '--watch' : ''} -- ${argv.normalizedArgsText ?? ''}`;\n  }\n\n  override startDocker(project: Project, argv: ScriptArgv): string {\n    return `${this.buildDocker(project)} && ${dockerScripts.stopAndStart(\n      project,\n      false,\n      argv.normalizedDockerOptionsText ?? '',\n      argv.normalizedArgsText ?? ''\n    )}`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv): string {\n    return `NODE_ENV=production ${project.buildCommand} && NODE_ENV=production ${runtimeWithArgs} dist/index.js ${\n      argv.normalizedArgsText ?? ''\n    }`;\n  }\n\n  override testE2E(): string {\n    return `echo 'do nothing.'`;\n  }\n\n  override testE2EDev(): string {\n    return `echo 'do nothing.'`;\n  }\n\n  override testStart(): string {\n    return `echo 'do nothing.'`;\n  }\n}\n\nexport const plainAppScripts = new PlainAppScripts();\n","import type { TestArgv } from '../../commands/test.js';\nimport type { Project } from '../../project.js';\nimport type { ScriptArgv } from '../builder.js';\nimport { prismaScripts } from '../prismaScripts.js';\n\nimport type { TestE2EDevOptions, TestE2EOptions } from './baseScripts.js';\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();\n  }\n\n  override start(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --raw --kill-others-on-fail\n      \"remix dev ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv)}\"`;\n  }\n\n  override startProduction(project: Project, argv: ScriptArgv, port: number): string {\n    return `NODE_ENV=production YARN concurrently --raw --kill-others-on-fail\n      \"${prismaScripts.reset(project)} && ${project.buildCommand} && PORT=${port} pm2-runtime start ${project.findFile(\n        'ecosystem.config.cjs'\n      )} ${argv.normalizedArgsText ?? ''}\"\n      \"${this.waitAndOpenApp(project, argv, port)}\"`;\n  }\n\n  override testE2E(\n    project: Project,\n    argv: TestArgv,\n    {\n      playwrightArgs,\n      startCommand = `${prismaScripts.reset(project)} && ${\n        project.buildCommand\n      } && pm2-runtime start ${project.findFile('ecosystem.config.cjs')}`,\n    }: TestE2EOptions\n  ): string {\n    return super.testE2E(project, argv, { playwrightArgs, prismaDirectory: 'prisma', startCommand });\n  }\n\n  override testE2EDev(\n    project: Project,\n    argv: TestArgv,\n    { playwrightArgs, startCommand = 'remix dev' }: TestE2EDevOptions\n  ): string {\n    return super.testE2EDev(project, argv, { playwrightArgs, startCommand });\n  }\n\n  override testStart(project: Project, argv: ScriptArgv): string {\n    return `YARN concurrently --kill-others --raw --success first \"remix dev\" \"${this.waitApp(project, argv)}\"`;\n  }\n}\n\nexport const remixScripts = new RemixScripts();\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 './constants.js';\n\nconst builder = {\n  ...scriptOptionsBuilder,\n  mode: {\n    description: 'Start mode: dev[elopment] (default) | staging | docker | docker-debug',\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          const prefix = configureEnvironmentVariables(deps, 'development');\n          await runWithSpawn(`${prefix}${scripts.start(project, argv)}`, project, argv);\n          break;\n        }\n        case 'staging': {\n          const prefix = configureEnvironmentVariables(deps, 'staging');\n          await runWithSpawn(`${prefix}${scripts.startProduction(project, argv, 8080)}`, project, argv);\n          break;\n        }\n        case 'docker': {\n          const prefix = configureEnvironmentVariables(deps, 'staging');\n          await runWithSpawn(`${prefix}${scripts.startDocker(project, argv)}`, project, argv);\n          break;\n        }\n        case 'docker-debug': {\n          const prefix = configureEnvironmentVariables(deps, 'staging');\n          argv.normalizedArgsText = `'/bin/bash'`;\n          await runWithSpawn(`${prefix}${scripts.startDocker(project, argv)}`, project, argv);\n          break;\n        }\n        default: {\n          throw new Error(`Unknown start mode: ${argv.mode}`);\n        }\n      }\n    }\n  },\n};\n\nfunction configureEnvironmentVariables(deps: Partial<Record<string, string>>, wbEnv: string): string {\n  process.env.WB_ENV ||= wbEnv;\n  let prefix = `WB_ENV=${process.env.WB_ENV} `;\n  if (deps['next']) {\n    process.env.NEXT_PUBLIC_WB_ENV = process.env.WB_ENV;\n    prefix += `NEXT_PUBLIC_WB_ENV=${process.env.WB_ENV} `;\n  }\n  return prefix;\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};\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","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 { 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 './constants.js';\n\nconst builder = {\n  ci: {\n    description: 'Whether to run tests on CI',\n    type: 'boolean',\n  },\n  e2e: {\n    description:\n      'Whether to run e2e tests. You may pass mode as argument: none | headless (default) | headless-dev | headed | headed-dev | docker | docker-debug | debug | generate | trace',\n    type: 'string',\n  },\n  start: {\n    description: 'Whether to run start tests',\n    type: 'boolean',\n  },\n  unit: {\n    description: 'Whether to run unit tests',\n    type: 'boolean',\n  },\n  'unit-timeout': {\n    description: 'Timeout for unit tests',\n    type: 'number',\n  },\n  target: {\n    description: 'Test target',\n    type: 'string',\n    alias: 't',\n  },\n} as const;\n\nexport type TestArgv = Partial<ArgumentsCamelCase<InferredOptionTypes<typeof builder & typeof scriptOptionsBuilder>>>;\n\nexport const testCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  command: 'test',\n  describe: 'Test project. If you pass no arguments, it will run all tests.',\n  builder,\n  async handler(argv) {\n    await test(argv);\n  },\n};\n\nexport async function test(\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder & 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  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  const shouldRunAllTests = argv.e2e === undefined && argv.start === undefined && argv.unit === undefined;\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    if (shouldRunAllTests) {\n      argv = {\n        ...argv,\n        e2e:\n          fs.existsSync(path.join(project.dirPath, 'tests', 'e2e')) && !argv.target?.includes('/unit/')\n            ? 'headless'\n            : 'none',\n        start: true,\n        unit: fs.existsSync(path.join(project.dirPath, 'tests', 'unit')) && !argv.target?.includes('/e2e/'),\n      };\n    }\n\n    console.info(`Running \"test\" for ${project.name} ...`);\n\n    const promises: Promise<unknown>[] = [];\n    if (argv.ci) {\n      await runWithSpawnInParallel(dockerScripts.stopAll(), project, argv);\n      if (argv.unit) {\n        // CI mode disallows `only` to avoid including debug tests\n        await runWithSpawnInParallel(scripts.testUnit(project, argv).replaceAll(' --allowOnly', ''), project, argv, {\n          timeout: argv.unitTimeout,\n        });\n      }\n      if (argv.start) {\n        await runWithSpawnInParallel(scripts.testStart(project, argv), project, argv);\n      }\n      await promisePool.promiseAll();\n      if (argv.e2e !== 'none') {\n        if (project.hasDockerfile) {\n          await runWithSpawn(`${scripts.buildDocker(project, 'test')}`, project, argv);\n        }\n        const options = project.hasDockerfile\n          ? {\n              startCommand: dockerScripts.stopAndStart(project, true),\n            }\n          : {};\n        process.exitCode = await runWithSpawn(\n          // CI mode disallows `only` to avoid including debug tests\n          scripts.testE2E(project, argv, options).replaceAll(' --allowOnly', ''),\n          project,\n          argv,\n          {\n            exitIfFailed: false,\n          }\n        );\n        await runWithSpawn(dockerScripts.stop(project), project, argv);\n      }\n      continue;\n    }\n\n    if (argv.unit) {\n      promises.push(runWithSpawn(scripts.testUnit(project, argv), project, argv, { timeout: argv.unitTimeout }));\n    }\n    if (argv.start) {\n      promises.push(runWithSpawn(scripts.testStart(project, argv), project, argv));\n    }\n    await Promise.all(promises);\n    switch (argv.e2e) {\n      case undefined:\n      case 'none': {\n        continue;\n      }\n      case '':\n      case 'headless': {\n        await runWithSpawn(scripts.testE2E(project, argv, {}), project, argv);\n        continue;\n      }\n      case 'headless-dev': {\n        await runWithSpawn(scripts.testE2EDev(project, argv, {}), project, argv);\n        continue;\n      }\n      case 'docker': {\n        await testOnDocker(project, argv, scripts);\n        continue;\n      }\n      case 'docker-debug': {\n        await testOnDocker(project, argv, scripts, `test ${argv.target || 'tests/e2e'} --debug`);\n        continue;\n      }\n    }\n    if (deps['blitz'] || deps['next'] || devDeps['@remix-run/dev']) {\n      switch (argv.e2e) {\n        case 'headed': {\n          await runWithSpawn(\n            scripts.testE2E(project, argv, { playwrightArgs: `test ${argv.target || 'tests/e2e'} --headed` }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'headed-dev': {\n          await runWithSpawn(\n            scripts.testE2EDev(project, argv, { playwrightArgs: `test ${argv.target || 'tests/e2e'} --headed` }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'debug': {\n          await runWithSpawn(\n            scripts.testE2E(project, argv, { playwrightArgs: `test ${argv.target || 'tests/e2e'} --debug` }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'generate': {\n          await runWithSpawn(\n            scripts.testE2E(project, argv, { playwrightArgs: 'codegen http://localhost:8080' }),\n            project,\n            argv\n          );\n          continue;\n        }\n        case 'trace': {\n          await runWithSpawn(`BUN playwright show-trace`, project, argv);\n          continue;\n        }\n      }\n    }\n    throw new Error(`Unknown e2e mode: ${argv.e2e}`);\n  }\n}\n\nasync function testOnDocker(\n  project: Project,\n  argv: ArgumentsCamelCase<InferredOptionTypes<typeof builder>>,\n  scripts: BaseScripts,\n  playwrightArgs?: string\n): Promise<void> {\n  await runWithSpawn(`${scripts.buildDocker(project, 'test')}`, project, argv);\n  process.exitCode = await runWithSpawn(\n    `${scripts.testE2E(project, argv, {\n      playwrightArgs,\n      startCommand: dockerScripts.stopAndStart(project, true),\n    })}`,\n    project,\n    argv,\n    { exitIfFailed: false }\n  );\n  await runWithSpawn(dockerScripts.stop(project), project, argv);\n}\n","import 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    const promises = projects.descendants.map((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      if (commands.length > 0) {\n        return runWithSpawnInParallel(commands.join(' && '), project, argv, {\n          // Disable interactive mode\n          ci: projects.descendants.length > 1,\n          forceColor: true,\n        });\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) process.exit(finalExitCode);\n  },\n};\n\nexport const tcCommand: CommandModule<unknown, InferredOptionTypes<typeof builder & typeof sharedOptionsBuilder>> = {\n  ...typeCheckCommand,\n  command: 'tc',\n};\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 path from 'node:path';\n\nimport { removeNpmAndYarnEnvironmentVariables } from '@willbooster/shared-lib-node/src';\nimport yargs from 'yargs';\nimport { hideBin } from 'yargs/helpers';\n\nimport { buildIfNeededCommand } from './commands/buildIfNeeded.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 { 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(lintCommand)\n  .command(optimizeForDockerBuildCommand)\n  .command(prismaCommand)\n  .command(retryCommand)\n  .command(setupCommand)\n  .command(startCommand)\n  .command(testCommand)\n  .command(typeCheckCommand)\n  .command(tcCommand)\n  .demandCommand()\n  .strict()\n  .help().argv;\n\nfor (const signal of ['SIGINT', 'SIGTERM', 'SIGQUIT']) {\n  process.on(signal, () => process.exit());\n}\n"],"names":["readEnvironmentVariables","argv","cwd","cacheEnabled","envPaths","env","map","envPath","path","resolve","toString","cascade","cascadeEnv","cascadeNodeEnv","process","NODE_ENV","autoCascadeEnv","WB_ENV","undefined","length","push","join","includeRootEnv","rootPath","fs","existsSync","flatMap","relative","verbose","console","info","envVars","orgEnvVars","readEnvFile","count","key","value","Object","entries","checkEnv","missingKeys","keys","filter","Error","cachedEnvVars","Map","filePath","cached","get","parsed","config","processEnv","set","async","spawnAsync","command","args","options","Promise","reject","proc","spawn","stdout","setEncoding","stderr","on","data","mergeOutAndError","stopped","stopProcess","pid","treeKill","killOnExit","error","removeListener","removeAllListeners","code","signal","status","input","stdin","write","end","memoize","cacheDuration","t","Number","POSITIVE_INFINITY","caches","s","calcKey","n","i","r","a","codePointAt","Math","imul","padStart","e","JSON","stringify","maxCachedArgsSize","maxCachedThisSize","c","o","kind","Date","now","has","this","call","size","next","delete","h","u","f","memoizeFactory","MAX_SAFE_INTEGER","Project","_initProto","_applyDecs","pathByName","constructor","dirPath","loadEnv","_dirPath","isBunAvailable","test","readFileSync","rootDirPath","buildCommand","packageJson","scripts","build","includes","dockerfile","findFile","hasDockerfile","hasSourceCode","name","dockerImageName","replaceAll","parse","packageJsonPath","hasPrisma","dependencies","devDependencies","dockerPackageJson","dirname","binExists","binFound","currentPath","binPath","PATH","parentPath","fileName","p","find","findSelfProject","findDescendantProjects","rootAndSelfProjects","thisProject","rootProject","workspaces","endsWith","root","self","findRootAndSelfProjects","descendants","getAllDescendantProjects","projects","workspace","Array","isArray","globPattern","packageDirs","workspacePath","ws","globby","dot","onlyDirectories","subPackageDirPath","isRunningOnBun","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","update","environmentJson","ignoringEnvVarNames","sort","key1","key2","localeCompare","filteredFilePaths","spawnSync","stdio","encoding","split","replace","includePatterns","some","pattern","includeSuffix","suffix","excludePatterns","copy","digest","updateHashWithDiffResult","cachedContentHash","fn","ignoreEnoentAsync","readFile","canSkipBuild","green","dryRun","writeFile","buildIfNeeded","ret","shell","exitCode","Set","killed","killPortProcessHandlingErrors","port","killPortProcess","promisePool","PromisePool","defaultOptions","exitIfFailed","runWithSpawn","script","opts","printableScript","runnableScript","normalizeScript","printStart","printFinishedAndExitIfNeeded","match","killFunc","add","killPortProcessImmediatelyAndOnExit","configureEnv","timeout","runWithSpawnInParallel","runAndWaitForReturnValue","out","newScript","fixBunCommand","normalizedScript","prefix","weak","gray","cyan","bold","exit","newEnv","ci","forceColor","biomeExtensions","prettierExtensions","prettierOnlyExtensions","ext","lintCommand","fix","format","files","biomeArgsText","prettierArgsText","sortPackageJsonArgsText","filePathsToBeCheckedByBiome","filePathsToBeFormattedByPrettier","packageJsonFilePaths","file","String","extension","extname","slice","biomeCommand","biomePromise","prepareForRunningCommand","commandName","optimizeForDockerBuildCommand","outside","deps","startsWith","optimizeDevDependencies","optimizeScripts","optimizeRootProps","distDirPath","devDeps","nameWordsToBeRemoved","word","nameWordsOfUnnecessaryScripts","contentWordsOfUnnecessaryScripts","content","private","publishConfig","prettier","prismaScripts","deploy","_","deployForce","backupPath","dirName","litestream","migrate","seed","migrateDev","reset","restore","outputPath","scriptPath","prisma","studio","dbUrlOrPath","URL","absolutePath","builder","prismaCommand","yargs","deployCommand","deployForceCommand","litestreamCommand","migrateCommand","migrateDevCommand","resetCommand","restoreCommand","seedCommand","studioCommand","defaultCommand","demandCommand","allProjects","findPrismaProjects","deployForceBuilder","demandOption","output","restored","trimEnd","filtered","retryCommand","retry","default","cmdAndArgs","Boolean","lastStatus","yellow","httpServerPackages","setupCommand","dirents","readdir","withFileTypes","os","platform","packages","d","isFile","version","promiseAll","newDeps","newDevDeps","dep","setup","dockerScripts","buildDevImage","stopAndStart","unbuffer","additionalOptions","additionalArgs","stop","start","spawnSyncOnExit","stopAll","BaseScripts","defaultPort","PORT","buildDocker","startDocker","normalizedDockerOptionsText","normalizedArgsText","waitAndOpenApp","testE2E","playwrightArgs","prismaDirectory","startCommand","target","testE2EDev","testUnit","waitApp","blitzScripts","super","startProduction","testStart","httpServerScripts","watch","nextScripts","plainAppScripts","remixScripts","mode","arg","dockerOptions","normalizeArgs","configureEnvironmentVariables","wbEnv","NEXT_PUBLIC_WB_ENV","testCommand","e2e","unit","CI","FORCE_COLOR","shouldRunAllTests","unitTimeout","all","testOnDocker","typeCheckCommand","commands","typescript","pyright","exitCodes","finalExitCode","tcCommand","sharedOptionsBuilder","hideBin","scriptName","middleware","workingDir","chdir","BERRY_BIN_FOLDER","upperKey","toUpperCase","removeNpmAndYarnEnvironmentVariables","strict","help"],"mappings":"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","x_google_ignoreList":[3,4]}
|