wbfy 1.70.0 → 1.71.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.cjs +34 -34
- package/dist/index.min.cjs.map +3 -3
- package/package.json +1 -1
package/dist/index.min.cjs
CHANGED
@@ -1,8 +1,8 @@
|
|
1
|
-
"use strict";var Lt=Object.create;var Ce=Object.defineProperty;var Ut=Object.getOwnPropertyDescriptor;var Gt=Object.getOwnPropertyNames;var zt=Object.getPrototypeOf,Ht=Object.prototype.hasOwnProperty;var Mt=(e,t,
|
2
|
-
${o}`),a.stdout.toString().trim()}function Re(e,t,
|
3
|
-
`)){let s=n.trim();if(s&&s.split(/\s+/)[0]!=="nodejs"){t.push(s);continue}let[,
|
1
|
+
"use strict";var Lt=Object.create;var Ce=Object.defineProperty;var Ut=Object.getOwnPropertyDescriptor;var Gt=Object.getOwnPropertyNames;var zt=Object.getPrototypeOf,Ht=Object.prototype.hasOwnProperty;var Mt=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Gt(t))!Ht.call(e,s)&&s!==i&&Ce(e,s,{get:()=>t[s],enumerable:!(n=Ut(t,s))||n.enumerable});return e};var c=(e,t,i)=>(i=e!=null?Lt(zt(e)):{},Mt(t||!e||!e.__esModule?Ce(i,"default",{value:e,enumerable:!0}):i,e));var Nt=c(require("node:path")),Wt=c(require("glob")),It=c(require("yargs"));var G=c(require("node:fs")),q=c(require("node:path"));var ae=class{isVerbose;constructor(){this.isVerbose=!1}},E=new ae;var le=class{async function(t,i){E.isVerbose&&console.info(`--------- ${t} start ---------`),await i(),E.isVerbose&&console.info(`---------- ${t} end ----------`)}},m=new le;var $e=require("minimal-promise-pool"),p=new $e.PromisePool;var ce=c(require("node:child_process"));function v(e,t,i,n=0){do{let[s,r,a]=Re(e,t,i);if(console.log(`$ ${s} ${r.join(" ")} at ${a.cwd}`),ce.default.spawnSync(s,r,a).status===0)break}while(--n>=0)}function U(e,t,i){let[n,s,r]=Re(e,t,i);r.stdio="pipe";let a=ce.default.spawnSync(n,s,r),o=a.stderr.toString().trim();return o&&console.error(`${n} [${s.map(l=>`"${l}"`)}] caused the following error:
|
2
|
+
${o}`),a.stdout.toString().trim()}function Re(e,t,i){let n={...process.env};return n.PATH&&n.BERRY_BIN_FOLDER&&(n.PATH=n.PATH.replace(`${n.BERRY_BIN_FOLDER}:`,"")),n.ASDF_DIR&&(t=["-l","-c",`. ${n.ASDF_DIR}/asdf.sh && ${e} ${t.join(" ")}`],e="bash"),[e,t,{cwd:i,env:n,shell:!1,stdio:"inherit"}]}async function Te(e){return m.function("generateVersionConfigs",async()=>{await Yt(e)})}async function Yt(e){if(!e.versionsText)return;let t=[];for(let n of e.versionsText.trim().split(`
|
3
|
+
`)){let s=n.trim();if(s&&s.split(/\s+/)[0]!=="nodejs"){t.push(s);continue}let[,r]=s.split(/\s+/);await p.run(()=>G.default.promises.writeFile(q.default.resolve(e.dirPath,".node-version"),r))}if(e.containingPoetryLock&&(K("poetry 1.2.2",0,t),G.default.existsSync(q.default.resolve(e.dirPath,".python-version"))||K("python 3.9.15",0,t)),e.depending.firebase&&K("java adoptopenjdk-17.0.5+8",0,t),e.containingPackageJson){let n=U("npm",["show","yarn","version"],e.dirPath);K(`yarn ${n}`,t.length,t)}let i=q.default.resolve(e.dirPath,".tool-versions");await(t.length>0?p.run(()=>G.default.promises.writeFile(i,t.join(`
|
4
4
|
`)+`
|
5
|
-
`)):p.run(()=>G.default.promises.rm(
|
5
|
+
`)):p.run(()=>G.default.promises.rm(i,{force:!0}))),await p.promiseAll(),v("asdf",["plugin","update","--all"],e.dirPath),v("asdf",["install"],e.dirPath)}function K(e,t,i){let[n]=e.split(" "),s=i.findIndex(r=>r.split(/\s+/)[0]===n);s>=0?i[s]=e:i.splice(t,0,e)}var Ee=c(require("node:path"));var k={codeWith2IndentSize:["cjs","mjs","js","jsx","cts","mts","ts","tsx","json","json5","cpp","dart","htm","html","pu","puml","rb","vue","yaml","yml"].sort(),codeWith4IndentSize:["go","gradle","py"].sort(),codeWith8IndentSize:["sh"].sort(),markdownLike:["md"].sort(),eslint:["cjs","mjs","js","cts","mts","ts","tsx","jsx"].sort(),prettier:["cjs","mjs","js","jsx","cts","mts","ts","tsx","json","json5","css","htm","html","md","scss","vue","yaml","yml"].sort()};var pe=c(require("node:fs/promises")),y={async readFileIgnoringError(e){try{return await pe.default.readFile(e,"utf8")}catch{}},async generateFile(e,t){await pe.default.writeFile(e,t),console.log(`Generated ${e}`)}};var Kt=`root = true
|
6
6
|
|
7
7
|
[*]
|
8
8
|
charset = utf-8
|
@@ -28,19 +28,19 @@ trim_trailing_whitespace = false
|
|
28
28
|
|
29
29
|
[{Makefile,*.mk}]
|
30
30
|
indent_style = tab
|
31
|
-
`;async function
|
31
|
+
`;async function je(e){return m.function("generateEditorconfig",async()=>{let t=Ee.default.resolve(e.dirPath,".editorconfig");await p.run(()=>y.generateFile(t,Kt))})}function V(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var de=c(require("node:path"));var me=c(require("node:fs")),z="# Project-specific settings",Oe=/# Project-specific settings[^\n]*\n/gm,We="# Generated by wbfy",qt="# Generated by ",De=`${z} (head)
|
32
32
|
|
33
33
|
|
34
34
|
${We}
|
35
35
|
`,Be=`
|
36
36
|
${z} (tail)
|
37
|
-
`,b={separator:We,separatorPrefix:qt,defaultHeadUserContent:De,defaultTailUserContent:Be,async readGitignoreWithoutSeparators(e){try{let t=await me.default.promises.readFile(e,"utf8"),
|
37
|
+
`,b={separator:We,separatorPrefix:qt,defaultHeadUserContent:De,defaultTailUserContent:Be,async readGitignoreWithoutSeparators(e){try{let t=await me.default.promises.readFile(e,"utf8"),i=Ne(t);return i>0&&(t=t.slice(0,i-1)),t.replace(Oe,"").replace(/# Generated by [^\n]*\n/gm,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
|
38
38
|
|
39
39
|
`).trim()+`
|
40
40
|
`}catch{}},getHeadUserContent(e){let t=e.indexOf(this.separatorPrefix);return t>=0?e.slice(0,e.indexOf(`
|
41
41
|
`,t)+1).replace(Oe,`${z} (head)
|
42
42
|
`):De},getTailUserContent(e){let t=Ne(e);return t>0?e.slice(t-1):Be},async isBerryZeroInstallEnabled(e){try{return(await me.default.promises.readFile(e,"utf8")).includes(`
|
43
|
-
!.yarn/cache`)}catch{return!1}}};function Ne(e){let t=e.indexOf(z),
|
43
|
+
!.yarn/cache`)}catch{return!1}}};function Ne(e){let t=e.indexOf(z),i=e.lastIndexOf(z);return i>t?i:-1}var Ie=`
|
44
44
|
3rd-party/
|
45
45
|
@types/
|
46
46
|
__generated__/
|
@@ -53,7 +53,7 @@ test-fixtures/
|
|
53
53
|
*.min.*js
|
54
54
|
.yarn/
|
55
55
|
.pnp.js
|
56
|
-
`;async function Je(e){return m.function("generateEslintignore",async()=>{let t=
|
56
|
+
`;async function Je(e){return m.function("generateEslintignore",async()=>{let t=de.default.resolve(e.dirPath,".eslintignore"),i=await y.readFileIgnoringError(t)??"",n=b.getHeadUserContent(i)+Ie,s=b.getTailUserContent(i),r=de.default.resolve(e.dirPath,".gitignore"),a=await b.readGitignoreWithoutSeparators(r)||"",o=n+Ie+a+s;await p.run(()=>y.generateFile(t,o))})}var Ue=c(require("node:fs")),Ge=c(require("node:path")),ze=c(require("deepmerge"));var Ae=c(require("deepmerge"));function N(e,t){return t}function X(e,t,i){let n=[...e];for(let[s,r]of t.entries())n[s]===void 0?n[s]=i.cloneUnlessOtherwiseSpecified(r,i):i.isMergeableObject(r)?n[s]=(0,Ae.default)(e[s],r,i):e.includes(r)||n.push(r);return n}async function He(e,t){return m.function("generateEslintrc",async()=>{if(t.depending.blitz==="2")return;let i=[];e.eslintBase&&i.push(e.eslintBase),e!==t&&i.push("../../.eslintrc.json");let n={root:!0,extends:i},s=Ge.default.resolve(e.dirPath,".eslintrc.json");try{let a=await Ue.default.promises.readFile(s,"utf8"),o=JSON.parse(a);o.extends&&(o.extends=o.extends.filter(d=>!d.startsWith("@willbooster/")&&d!=="../../.eslintrc.json")),i.length===0&&(o.extends=[]);let l=n.extends;n.extends=o.extends,o.extends=l,n=ze.default.all([n,o,n],{arrayMerge:X}),e.depending.blitz==="0"?Le(n,"blitz"):e.depending.blitz==="2"&&Le(n,"@blitzjs/next/eslint")}catch{}let r=JSON.stringify(n);await p.run(()=>y.generateFile(s,r))})}function Le(e,t){e.extends=[t,...e.extends.filter(i=>i!==t)]}var Me=c(require("node:path"));var Vt=`* text=auto
|
57
57
|
|
58
58
|
*.vcproj text eol=crlf
|
59
59
|
|
@@ -66,7 +66,7 @@ temp/
|
|
66
66
|
Icon[\r]
|
67
67
|
*.sqlite3
|
68
68
|
*.sqlite3-journal
|
69
|
-
`;async function qe(e,t){return m.function("generateGitignore",async()=>{let
|
69
|
+
`;async function qe(e,t){return m.function("generateGitignore",async()=>{let i=W.default.resolve(e.dirPath,".gitignore"),n=await y.readFileIgnoringError(i)??"",s=b.getHeadUserContent(n)+Zt,r=b.getTailUserContent(n),a=[...Xt];e.containingGemfile&&a.push("ruby"),e.containingGoMod&&(a.push("go"),s+=`${W.default.basename(e.dirPath)}
|
70
70
|
`),e.containingPackageJson&&a.push("node"),e.containingPomXml&&(a.push("maven"),s+=`.idea/google-java-format.xml
|
71
71
|
`),e.containingPubspecYaml&&(a.push("flutter","AndroidStudio","ruby"),s+=`.flutter-plugins-dependencies
|
72
72
|
android/key.properties
|
@@ -78,10 +78,10 @@ packaged.yaml
|
|
78
78
|
android/app/src/main/assets/
|
79
79
|
`),t.depending.storybook&&a.push("storybookjs"),t.depending.blitz&&(a.push("nextjs"),s+=`.blitz/
|
80
80
|
.blitz**
|
81
|
-
`);let o="";for(let
|
82
|
-
`),o+=
|
83
|
-
`}await b.isBerryZeroInstallEnabled(
|
84
|
-
android/$1`));let l=s+o+
|
81
|
+
`);let o="";for(let d of a){let f=await ei(d)??"";if(!f){let h=`https://www.toptal.com/developers/gitignore/api/${d}`,w=await(await fetch(h)).text();if(w.includes("Attention Required!")){console.error(`Failed to fetch ${h}`);return}f=w.trim(),await p.run(()=>Qt(d,f)),E.isVerbose&&console.info(`Fetched ${h}`)}o&&(o+=`
|
82
|
+
`),o+=f+`
|
83
|
+
`}await b.isBerryZeroInstallEnabled(i)||(o=o.replace("!.yarn/cache","# !.yarn/cache").replace("# .pnp.*",".pnp.*")),(e.containingPomXml||e.containingPubspecYaml)&&(o=o.replace(/^# .idea\/artifacts$/gm,".idea/artifacts").replace(/^# .idea\/compiler.xml$/gm,".idea/compiler.xml").replace(/^# .idea\/jarRepositories.xml$/gm,".idea/jarRepositories.xml").replace(/^# .idea\/modules.xml$/gm,".idea/modules.xml").replace(/^# .idea\/*.iml$/gm,".idea/*.iml").replace(/^# .idea\/modules$/gm,".idea/modules").replace(/^# *.iml$/gm,"*.iml").replace(/^# *.ipr$/gm,"*.ipr"),e.containingPubspecYaml&&(o=o.replace(/^.idea\/modules.xml$/gm,"# .idea/modules.xml"))),o=o.replace(/^.idea\/?$/gm,"# .idea"),(t.depending.reactNative||e.depending.reactNative||e.containingPubspecYaml)&&(o=o.replace(/^(.idea\/.+)$/gm,`$1
|
84
|
+
android/$1`));let l=s+o+r;await p.run(()=>y.generateFile(i,l))})}var Z=W.default.join(Ke.default.homedir(),".cache","wbfy","gitignore");async function Qt(e,t){await H.default.promises.mkdir(Z,{recursive:!0}),await H.default.promises.writeFile(W.default.join(Z,e),t)}async function ei(e){try{let t=await H.default.promises.stat(W.default.join(Z,e));return Date.now()-t.mtimeMs>6*60*60*1e3?void 0:await H.default.promises.readFile(W.default.join(Z,e),"utf8")}catch{}}var $=c(require("node:fs")),I=c(require("node:path"));var ue="npm test",Q={preCommit:"node node_modules/.bin/lint-staged",prePush:"yarn typecheck",prePushForLab:`
|
85
85
|
if [ $(git branch --show-current) = "main" ] && [ $(git config user.email) != "exkazuu@gmail.com" ]; then
|
86
86
|
echo "************************************************"
|
87
87
|
echo "*** Don't push main branch directly. Use PR! ***"
|
@@ -96,14 +96,14 @@ run_if_changed() {
|
|
96
96
|
if echo "$changed_files" | grep --quiet -E "$1"; then
|
97
97
|
eval "$2"
|
98
98
|
fi
|
99
|
-
}`.trim()};async function Ve(e){return m.function("generateHuskyrc",async()=>{await
|
99
|
+
}`.trim()};async function Ve(e){return m.function("generateHuskyrc",async()=>{await ti(e)})}async function ti(e){var d,f;let t=I.default.resolve(e.dirPath,"package.json"),i=await $.default.promises.readFile(t,"utf8"),n=JSON.parse(i);n.scripts||={},delete n.scripts.postinstall,delete n.scripts.postpublish,delete n.scripts.prepare,delete n.scripts.prepublishOnly,delete n.scripts.prepack,delete n.scripts.postpack;let s=I.default.resolve(e.dirPath,".husky");await Promise.all([$.default.promises.writeFile(t,JSON.stringify(n,void 0,2)),$.default.promises.rm(s,{force:!0,recursive:!0})]),v("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let r=I.default.resolve(s,"pre-commit"),a=await $.default.promises.readFile(r,"utf8");if(await p.run(()=>$.default.promises.rm(I.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await p.run(()=>$.default.promises.writeFile(r,a.replace(ue,Q.preCommit))),e.containingTypeScript||e.containingTypeScriptInPackages){let h=(d=e.repository)!=null&&d.startsWith("github:WillBoosterLab/")?Q.prePushForLab:Q.prePush;e.containingSubPackageJsons||(h=h.replace("yarn typecheck","node node_modules/.bin/tsc --noEmit --Pretty")),await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"pre-push"),a.replace(ue,h),{mode:493}))}let o=[];e.versionsText&&o.push('run_if_changed "\\..+-version" "asdf plugin update --all"'),(f=e.versionsText)!=null&&f.includes("python ")&&o.push('run_if_changed "\\..+-version" "asdf install python"'),e.versionsText&&o.push('run_if_changed "\\..+-version" "asdf install"'),o.push('run_if_changed "package\\.json" "yarn"'),e.containingPoetryLock&&o.push('run_if_changed "poetry\\.lock" "poetry install"'),(e.depending.blitz||e.depending.prisma)&&o.push("yarn gen-code");let l=a.replace(ue,`${Q.postMerge}
|
100
100
|
|
101
101
|
${o.join(`
|
102
|
-
`)}`);await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"post-merge"),l,{mode:493}))}var
|
102
|
+
`)}`);await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"post-merge"),l,{mode:493}))}var fe=c(require("node:fs")),ge=c(require("node:path"));var ii=`<?xml version="1.0" encoding="UTF-8"?>
|
103
103
|
<project version="4">
|
104
104
|
<component name="ProjectTasksOptions">
|
105
105
|
<TaskOptions isEnabled="true">
|
106
|
-
<option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
106
|
+
<option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
107
107
|
<option name="checkSyntaxErrors" value="false" />
|
108
108
|
<option name="description" />
|
109
109
|
<option name="exitCodeBehavior" value="ERROR" />
|
@@ -123,7 +123,7 @@ ${o.join(`
|
|
123
123
|
<envs />
|
124
124
|
</TaskOptions>
|
125
125
|
<TaskOptions isEnabled="true">
|
126
|
-
<option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
126
|
+
<option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
127
127
|
<option name="checkSyntaxErrors" value="false" />
|
128
128
|
<option name="description" />
|
129
129
|
<option name="exitCodeBehavior" value="ERROR" />
|
@@ -143,7 +143,7 @@ ${o.join(`
|
|
143
143
|
<envs />
|
144
144
|
</TaskOptions>
|
145
145
|
<TaskOptions isEnabled="true">
|
146
|
-
<option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
146
|
+
<option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
147
147
|
<option name="checkSyntaxErrors" value="false" />
|
148
148
|
<option name="description" />
|
149
149
|
<option name="exitCodeBehavior" value="ERROR" />
|
@@ -163,7 +163,7 @@ ${o.join(`
|
|
163
163
|
<envs />
|
164
164
|
</TaskOptions>
|
165
165
|
<TaskOptions isEnabled="true">
|
166
|
-
<option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
166
|
+
<option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
167
167
|
<option name="checkSyntaxErrors" value="false" />
|
168
168
|
<option name="description" />
|
169
169
|
<option name="exitCodeBehavior" value="ERROR" />
|
@@ -183,7 +183,7 @@ ${o.join(`
|
|
183
183
|
<envs />
|
184
184
|
</TaskOptions>
|
185
185
|
<TaskOptions isEnabled="true">
|
186
|
-
<option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
186
|
+
<option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
187
187
|
<option name="checkSyntaxErrors" value="false" />
|
188
188
|
<option name="description" />
|
189
189
|
<option name="exitCodeBehavior" value="ERROR" />
|
@@ -203,7 +203,7 @@ ${o.join(`
|
|
203
203
|
<envs />
|
204
204
|
</TaskOptions>
|
205
205
|
<TaskOptions isEnabled="true">
|
206
|
-
<option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
206
|
+
<option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
|
207
207
|
<option name="checkSyntaxErrors" value="false" />
|
208
208
|
<option name="description" />
|
209
209
|
<option name="exitCodeBehavior" value="ERROR" />
|
@@ -224,15 +224,15 @@ ${o.join(`
|
|
224
224
|
</TaskOptions>
|
225
225
|
</component>
|
226
226
|
</project>
|
227
|
-
`;async function Xe(e){return m.function("generateIdeaSettings",async()=>{let t=ge.default.resolve(e.dirPath,".idea");if(
|
228
|
-
'${Qe(e)}': [${JSON.stringify(`eslint --fix${ee.getLintFixSuffix(e)}`)}, 'prettier --cache --write'],`;t.push(
|
227
|
+
`;async function Xe(e){return m.function("generateIdeaSettings",async()=>{let t=ge.default.resolve(e.dirPath,".idea");if(fe.default.existsSync(t)){let i=ge.default.resolve(t,"watcherTasks.xml");await(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?p.run(()=>y.generateFile(i,ii)):p.run(()=>fe.default.promises.rm(i,{force:!0})))}})}var ye=c(require("node:fs")),ie=c(require("node:path"));var ee={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var Ze={node:["src","__tests__","scripts"].sort(),blitz:["__tests__","scripts","app","db","integrations","mailers","pages","test"].sort()};function te(e){return e.depending.blitz?Ze.blitz:Ze.node}async function he(e){return m.function("generateLintstagedrc",async()=>{await ri(e)})}async function ri(e){let t=[];if(e.containingJavaScript||e.containingTypeScript){let r=`
|
228
|
+
'${Qe(e)}': [${JSON.stringify(`node node_modules/.bin/eslint --fix${ee.getLintFixSuffix(e)}`)}, 'node node_modules/.bin/prettier --cache --write'],`;t.push(r)}let i=e.root?" && !file.includes('/packages/')":"";t.push(`
|
229
229
|
'./**/*.{${k.prettier.join(",")}}': files => {
|
230
|
-
${e.containingJavaScript||e.containingTypeScript?
|
231
|
-
const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${
|
230
|
+
${e.containingJavaScript||e.containingTypeScript?ni(e):""}
|
231
|
+
const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${i});
|
232
232
|
if (filteredFiles.length === 0) return [];
|
233
|
-
const commands = [\`prettier --cache --write \${filteredFiles.join(' ')}\`];
|
233
|
+
const commands = [\`node node_modules/.bin/prettier --cache --write \${filteredFiles.join(' ')}\`];
|
234
234
|
if (filteredFiles.some(file => file.endsWith('package.json'))) {
|
235
|
-
commands.push('
|
235
|
+
commands.push('node node_modules/.bin/sort-package-json');
|
236
236
|
}
|
237
237
|
return commands;
|
238
238
|
},`),e.containingPubspecYaml&&t.push(`
|
@@ -250,7 +250,7 @@ ${o.join(`
|
|
250
250
|
|
251
251
|
module.exports = {${t.join("")}
|
252
252
|
};
|
253
|
-
`,s=
|
253
|
+
`,s=ie.default.resolve(e.dirPath,".lintstagedrc.cjs");await p.run(()=>ye.default.promises.rm(ie.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await p.run(()=>ye.default.promises.rm(ie.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await p.run(()=>y.generateFile(s,n))}function Qe(e){return`./{${te(e).join(",")}}/**/*.{${k.eslint.join(",")}}`}function ni(e){return`files = micromatch.not(files, '${Qe(e)}');`}var O=c(require("node:fs")),A=c(require("node:path")),ve=c(require("deepmerge"));var et=require("@octokit/core"),tt=process.env.GH_BOT_PAT||process.env.PUBLIC_GH_BOT_PAT||process.env.GH_TOKEN||process.env.GITHUB_TOKEN,re=!!tt,C=new et.Octokit({auth:tt}),we=class{getOrgAndName(t){var a;let i=t.split(":").at(-1),n=i==null?void 0:i.split("/"),s=(n==null?void 0:n.at(-2))??"",r=((a=n==null?void 0:n.at(-1))==null?void 0:a.replace(/.git$/,""))??"";return[s,r]}},j=new we;var Pe=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys","eslint-plugin-unicorn"],it=[...Pe,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],rt=["eslint-plugin-react","eslint-plugin-react-hooks"],nt={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...Pe],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...Pe,...rt],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...it],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...it,...rt],"../../.eslintrc.json":[]};async function ot(e,t,i){return m.function("generatePackageJson",async()=>{await oi(e,t,i)})}async function oi(e,t,i){var f,h;let n=A.default.resolve(e.dirPath,"package.json"),s=await O.default.promises.readFile(n,"utf8"),r=JSON.parse(s);r.scripts=r.scripts||{},r.dependencies=r.dependencies||{},r.devDependencies=r.devDependencies||{},r.peerDependencies=r.peerDependencies||{},await si(r),r.name!=="@willbooster/prettier-config"&&(r.prettier="@willbooster/prettier-config");for(let g of Object.keys(r.scripts))r.scripts[g].includes("git clone")||(r.scripts[g]=r.scripts[g].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));r.scripts=(0,ve.default)(r.scripts,ai(e)),r.scripts.prettify+=await li(e.dirPath);let a=[],o=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],l=[];e.root&&(o.push("husky","@willbooster/renovate-config"),(e.publicRepo||e.referred)&&(o.push("pinst"),r.scripts.prepack="pinst --disable",r.scripts.postpack="pinst --enable"),e.depending.semanticRelease&&(o.push("conventional-changelog-conventionalcommits"),!r.devDependencies["semantic-release"]&&!r.devDependencies["multi-semantic-release"]&&!r.devDependencies["@qiwi/multi-semantic-release"]&&o.push("semantic-release"),r.version="0.0.0-semantically-released"),e.containingSubPackageJsons?r.workspaces=["packages/*"]:delete r.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(o.push("eslint","micromatch"),e.containingTypeScriptInPackages&&o.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&o.push("typescript"),e.eslintBase&&o.push(...nt[e.eslintBase]),e.willBoosterConfigs&&(a=a.filter(g=>!g.includes("@willbooster/")),o=o.filter(g=>!g.includes("@willbooster/"))),r.name||(r.name=A.default.basename(e.dirPath)),e.containingSubPackageJsons&&(r.private=!0),r.license||(r.license="UNLICENSED"),!r.private&&r.license!=="UNLICENSED"&&t.publicRepo&&(r.publishConfig??={},r.publishConfig.access??="public");let[d]=j.getOrgAndName(e.repository??"");if((d==="WillBooster"||d==="WillBoosterLab")&&(r.author="WillBooster Inc."),!e.containingTypeScript&&!e.containingTypeScriptInPackages&&delete r.scripts.typecheck,e.depending.semanticRelease&&e.release.npm&&(r.resolutions||={},r.resolutions["npm/chalk"]="^4.1.2"),!e.containingSubPackageJsons){if(!e.containingJavaScript&&!e.containingTypeScript?(delete r.scripts.lint,delete r.scripts["lint-fix"],r.scripts.cleanup=r.scripts.cleanup.replace(" && yarn lint-fix","")):r.scripts["lint-fix"]+=ee.getLintFixSuffix(e),e.containingPubspecYaml){r.scripts.lint="flutter analyze",r.scripts["lint-fix"]="yarn lint";let g=["lib","test","test_driver"].filter(w=>O.default.existsSync(A.default.resolve(e.dirPath,w)));g.length>0&&(r.scripts["format-code"]=`flutter format $(find ${g.join(" ")} -name generated -prune -o -name '*.freezed.dart' -prune -o -name '*.g.dart' -prune -o -name '*.dart' -print)`,r.scripts.format+=" && yarn format-code")}if(e.containingPoetryLock){r.scripts.postinstall==="poetry install"&&delete r.scripts.postinstall;let g=await O.default.promises.readdir(e.dirPath,{withFileTypes:!0}),F=(await Promise.all(g.map(async x=>{if(!x.isDirectory())return"";let Jt=A.default.resolve(e.dirPath,x.name);return(await O.default.promises.readdir(Jt)).some(At=>At.endsWith(".py"))?x.name:""}))).filter(Boolean);F.length>0&&(r.scripts["format-code"]=`poetry run isort --profile black ${F.join(" ")} && poetry run black ${F.join(" ")}`,r.scripts.lint=`poetry run flake8 ${F.join(" ")}`,r.scripts["lint-fix"]="yarn lint",r.scripts.format+=" && yarn format-code",l.push("black","isort","flake8"))}e.repository&&(r.repository=e.repository)}e.depending.blitz?(e.depending.blitz==="0"&&(o=o.filter(g=>!g.includes("@typescript-eslint/")),o=o.filter(g=>g!=="eslint-plugin-react"&&g!=="eslint-import-resolver-typescript"&&g!=="eslint-plugin-import"&&g!=="eslint-plugin-react-hooks")),(f=r.scripts["gen-code"])!=null&&f.startsWith("blitz codegen")||(r.scripts["gen-code"]="blitz codegen")):e.depending.prisma&&!((h=r.scripts["gen-code"])!=null&&h.startsWith("prisma generate"))&&(r.scripts["gen-code"]="prisma generate"),Object.keys(r.dependencies).length===0&&delete r.dependencies,Object.keys(r.devDependencies).length===0&&delete r.devDependencies,Object.keys(r.peerDependencies).length===0&&delete r.peerDependencies,await O.default.promises.writeFile(n,JSON.stringify(r)),i||(a=a.filter(g=>{var w;return!((w=r.devDependencies)!=null&&w[g])}),a.length>0&&v("yarn",["add",...new Set(a)],e.dirPath),o=o.filter(g=>{var w;return!((w=r.dependencies)!=null&&w[g])}),o.length>0&&v("yarn",["add","-D",...new Set(o)],e.dirPath),l.length>0&&v("poetry",["add",...new Set(l)],e.dirPath))}async function si(e){e.author==="WillBooster LLC"&&(e.author="WillBooster Inc."),delete e.scripts["sort-package-json"],delete e.scripts["sort-all-package-json"],delete e.scripts["typecheck:codegen"],delete e.dependencies.tslib,delete e.devDependencies["@willbooster/eslint-config"],delete e.devDependencies["@willbooster/eslint-config-react"],delete e.devDependencies["@willbooster/tsconfig"],delete e.devDependencies["eslint-import-resolver-node"],delete e.devDependencies["eslint-plugin-prettier"],delete e.devDependencies.lerna,delete e.devDependencies.pinst,delete e.scripts["flutter-format"],delete e.scripts["format-flutter"],delete e.scripts["python-format"],delete e.scripts["format-python"],delete e.scripts.prettier;for(let t of Object.values(nt))for(let i of t)delete e.devDependencies[i];await p.run(()=>O.default.promises.rm("lerna.json",{force:!0}))}function ai(e){let t={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{${te(e)}}/**/*.{${k.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --cache --color --write "**/{.*/,}*.{${k.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"};return e.containingSubPackageJsons&&(t=(0,ve.default)({...t},{format:"sort-package-json && yarn prettify && yarn workspaces foreach --parallel --verbose run format",lint:"yarn workspaces foreach --parallel --verbose run lint","lint-fix":"yarn workspaces foreach --parallel --verbose run lint-fix",prettify:`prettier --cache --color --write "**/{.*/,}*.{${k.prettier.join(",")}}" "!**/packages/**" "!**/test-fixtures/**"`,test:"yarn workspaces foreach --verbose run test",typecheck:"yarn workspaces foreach --parallel --verbose run typecheck"})),e.depending.blitz&&(t.typecheck=`${t.typecheck} || yarn run typecheck/warn`,t["typecheck/warn"]=`echo 'Please try "yarn gen-code" if you face unknown type errors.' && exit 1`,t["typecheck:gen-code"]="yarn gen-code && tsc --noEmit --Pretty"),t}async function li(e){let t=A.default.resolve(e,".prettierignore"),i=await O.default.promises.readFile(t,"utf8"),n=i.indexOf(b.separatorPrefix);return n<0?"":i.slice(0,n).split(`
|
254
254
|
`).map(a=>{let o=a.trim();return o.endsWith("/")?o.slice(0,-1):o}).filter(a=>a&&!a.startsWith("#")&&!a.includes("/")).map(a=>` "!**/${a}/**"`).join("")}var ke=c(require("node:path"));var st=`
|
255
255
|
3rd-party/
|
256
256
|
android/
|
@@ -261,13 +261,13 @@ test-fixtures/
|
|
261
261
|
*.min.js
|
262
262
|
.yarn/
|
263
263
|
.pnp.js
|
264
|
-
`;async function at(e){return m.function("generatePrettierignore",async()=>{let t=ke.default.resolve(e.dirPath,".prettierignore"),
|
264
|
+
`;async function at(e){return m.function("generatePrettierignore",async()=>{let t=ke.default.resolve(e.dirPath,".prettierignore"),i=await y.readFileIgnoringError(t)??"",n=b.getHeadUserContent(i)+st,s=b.getTailUserContent(i),r=ke.default.resolve(e.dirPath,".gitignore"),a=await b.readGitignoreWithoutSeparators(r)||"",o="";e.containingPubspecYaml&&(o=`
|
265
265
|
android/app/
|
266
266
|
ios/Runner/Assets.xcassets/
|
267
267
|
pubspec.yaml
|
268
|
-
`);let l=n+st+o+a+s;await p.run(()=>y.generateFile(t,l))})}var ne=c(require("node:fs")),be=c(require("node:path"));async function ct(e){return m.function("generateReadme",async()=>{var
|
269
|
-
`){
|
270
|
-
${t.slice(a+1)}`;break}return
|
271
|
-
${
|
272
|
-
`),t}var pt=c(require("node:fs")),mt=c(require("node:path")),xe=c(require("deepmerge"));async function ft(e){return m.function("generateReleaserc",async()=>{let t=mt.default.resolve(e.dirPath,".releaserc.json");try{let r=JSON.parse(await pt.default.promises.readFile(t,"utf8")),n=(r==null?void 0:r.plugins)||[];for(let i=0;i<n.length;i++){let a=Array.isArray(n[i])?n[i][0]:n[i],o=Array.isArray(n[i])&&n[i][1]||{};a==="@semantic-release/commit-analyzer"?n[i]=["@semantic-release/commit-analyzer",xe.default.all([o,{preset:"conventionalcommits"}],{arrayMerge:N})]:a==="@semantic-release/github"&&(n[i]=["@semantic-release/github",xe.default.all([o,{successComment:!1,labels:["r: semantic-release"],releasedLabels:["released :bookmark:"]}],{arrayMerge:N})])}let s=JSON.stringify(r);await p.run(()=>y.generateFile(t,s))}catch{}})}var oe=c(require("node:fs")),se=c(require("node:path")),ut=c(require("deepmerge")),dt=c(require("lodash.clonedeep"));var pr={extends:["@willbooster"]};async function gt(e){return m.function("generateRenovateJson",async()=>{let t=(0,dt.default)(pr),r=se.default.resolve(e.dirPath,".renovaterc.json");try{let s=await oe.default.promises.readFile(r,"utf8"),i=JSON.parse(s);t=ut.default.all([t,i,t],{arrayMerge:N})}catch{}await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,".dependabot"),{force:!0})),await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let n=JSON.stringify(t);await p.run(()=>y.generateFile(r,n))})}var yt=c(require("node:fs")),ht=c(require("node:path")),wt=c(require("deepmerge")),Pt=c(require("lodash.clonedeep"));function M(e){let t=Object.entries(e).sort(([r],[n])=>r.localeCompare(n));for(let[r,n]of t)delete e[r],e[r]=n;return e}var mr={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["./node_modules/@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","packages/*/scripts/**/*"]},fr={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["../../node_modules/@types","../../@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*"]};async function vt(e,t){return m.function("generateTsconfig",async()=>{var i,a;if(t.depending.blitz)return;let r=(0,Pt.default)(e.root?mr:fr);!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete r.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(r.include=r.include.filter(o=>!o.startsWith("packages/*/")));let n=ht.default.resolve(e.dirPath,"tsconfig.json");try{let o=await yt.default.promises.readFile(n,"utf8"),l=JSON.parse(o);l.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete l.extends,(i=r==null?void 0:r.compilerOptions)==null||delete i.target,(a=r==null?void 0:r.compilerOptions)==null||delete a.module,l.jsx&&delete r.jsx,r=wt.default.all([r,l,r],{arrayMerge:N}),r.include=r.include.filter(f=>!f.includes("@types"))}catch{}M(r.compilerOptions);let s=JSON.stringify(r);await p.run(()=>y.generateFile(n,s))})}var T=c(require("node:fs")),R=c(require("node:path")),xt=c(require("deepmerge")),_e=c(require("js-yaml")),_t=c(require("lodash.clonedeep"));var ur={test:{name:"Test",on:{pull_request:null,push:{branches:["main","wbfy","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},release:{name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},wbfy:{name:"Willboosterify",on:{workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}},"wbfy-merge":{name:"Merge wbfy",on:{workflow_dispatch:null},jobs:{"wbfy-merge":{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy-merge.yml@main"}}},"semantic-pr":{name:"Lint PR title",on:{pull_request_target:{types:["opened","edited","synchronize"]}},jobs:{"semantic-pr":{uses:"WillBooster/reusable-workflows/.github/workflows/semantic-pr.yml@main"}}},"notify-ready":{name:"Notify ready",on:{issues:{types:["labeled"]}},jobs:{"notify-ready":{uses:"WillBooster/reusable-workflows/.github/workflows/notify-ready.yml@main",secrets:{DISCORD_WEBHOOK_URL:"${{ secrets.DISCORD_WEBHOOK_URL_FOR_READY }}"}}}},"close-comment":{name:"Add close comment",on:{pull_request:{types:["opened"]}},jobs:{"close-comment":{uses:"WillBooster/reusable-workflows/.github/workflows/close-comment.yml@main"}}},"add-issue-to-project":{name:"Add issue to github project",on:{issues:{types:["labeled"]}},jobs:{"add-to-project":{uses:"WillBooster/reusable-workflows/.github/workflows/add-issue-to-project.yml@main",secrets:{GH_PROJECT_URL:"${{ secrets.GH_PROJECT_URL }}",GH_BOT_PAT:"${{ secrets.GH_BOT_PAT }}"}}}}};async function St(e){return m.function("generateWorkflow",async()=>{var i;let t=R.default.resolve(e.dirPath,".github","workflows");await T.default.promises.mkdir(t,{recursive:!0});let r=R.default.resolve(e.dirPath,".github","semantic.yml");await p.run(()=>T.default.promises.rm(r,{force:!0,recursive:!0}));let s=(await T.default.promises.readdir(t,{withFileTypes:!0})).filter(a=>a.isFile()&&a.name.endsWith(".yml")).map(a=>a.name);e.depending.semanticRelease&&s.push("release.yml"),(e.publicRepo||(i=e.repository)!=null&&i.startsWith("github:WillBoosterLab/"))&&s.push("notify-ready.yml"),s.push("test.yml","wbfy.yml","wbfy-merge.yml","semantic-pr.yml","close-comment.yml","add-issue-to-project.yml");for(let a of s){let o=R.default.basename(a,".yml");await p.run(()=>dr(e,t,o))}})}async function dr(e,t,r){var i,a;let n=(0,_t.default)(ur[r]||{}),s=R.default.join(t,`${r}.yml`);try{let o=await T.default.promises.readFile(s,"utf8"),l=_e.default.load(o);n=xt.default.all([n,l,n],{arrayMerge:X})}catch{}for(let o of Object.values(n.jobs)){if(!((a=(i=o.uses)==null?void 0:i.includes)!=null&&a.call(i,"/reusable-workflows/")))return;gr(e,o,r)}switch(r){case"release":{if(n.on.schedule)delete n.on.push;else if(e.release.branches.length>0)n.on.push.branches=e.release.branches;else{await T.default.promises.rm(R.default.join(t,"release.yml"),{force:!0});return}break}case"wbfy":{kt(n,20,24);break}case"wbfy-merge":{kt(n,0,4);break}}if(await bt(n,s),r==="release")await T.default.promises.rm(R.default.join(t,"semantic-release.yml"),{force:!0});else if(r==="sync"){if(await T.default.promises.rm(R.default.join(t,"sync-init.yml"),{force:!0}),!n.jobs.sync)return;n.jobs["sync-force"]=n.jobs.sync;let o=n.jobs.sync.with.sync_params_without_dest;if(!o)return;n.jobs.sync.with.sync_params_without_dest=`--force ${o}`,n.name="Force to Sync",n.on={workflow_dispatch:null},delete n.jobs.sync,await bt(n,R.default.join(t,"sync-force.yml"))}}function gr(e,t,r){var n,s,i;if(t.with||={},t.secrets||={},(e.release.github&&r==="test"||r==="release"||r==="wbfy"||r==="wbfy-merge")&&(t.secrets.GH_TOKEN=e.publicRepo?"${{ secrets.PUBLIC_GH_BOT_PAT }}":"${{ secrets.GH_BOT_PAT }}"),e.release.npm&&(r==="release"||r==="test")&&(t.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}"),t.secrets.FIREBASE_TOKEN&&(t.secrets.GCP_SA_KEY_JSON_FOR_FIREBASE="${{ secrets.GCP_SA_KEY_JSON_FOR_FIREBASE }}",delete t.secrets.FIREBASE_TOKEN),(t.secrets.DISCORD_WEBHOOK_URL&&(r==="release"||r.startsWith("deploy"))||t.with.server_url&&r.startsWith("deploy"))&&(t.secrets.DISCORD_WEBHOOK_URL="${{ secrets.DISCORD_WEBHOOK_URL_FOR_RELEASE }}"),r==="sync"){let a=(n=t.with)==null?void 0:n.sync_params_without_dest;a&&(t.with.sync_params_without_dest=a.replace("sync ",""))}if((s=e.repository)!=null&&s.startsWith("github:WillBooster/")?t.uses=t.uses.replace("WillBoosterLab/","WillBooster/"):(i=e.repository)!=null&&i.startsWith("github:WillBoosterLab/")&&(t.uses=t.uses.replace("WillBooster/","WillBoosterLab/")),delete t.with.non_self_hosted,delete t.with.notify_discord,delete t.with.require_fly,delete t.with.require_gcloud,t.with.dot_env_path===".env"&&delete t.with.dot_env_path,e.containingDockerfile&&r.startsWith("deploy")&&(t.with.cpu_arch="X64"),r==="release"||r==="test"||r==="wbfy"||r==="wbfy-merge"||r.startsWith("deploy")?e.publicRepo&&(t.with.github_hosted_runner=!0):delete t.with.github_hosted_runner,Object.keys(t.with).length>0?M(t.with):delete t.with,Object.keys(t.secrets).length>0){let a=M(t.secrets);delete t.secrets,t.secrets=a}else delete t.secrets}function kt(e,t,r){var l,f;let[n,s]=(((f=(l=e.on.schedule)==null?void 0:l[0])==null?void 0:f.cron)??"").split(" ").map(Number);if(n!==0&&Number.isInteger(s)){let d=(s+9)%24,h=t<r?t<=d&&d<r:t<=d||d<r;if(h)return;console.log("setSchedule:",e,n,s,h,d,t,r)}else console.log("setSchedule:",e,n,s);let i=1+Math.floor(Math.random()*59),a=t+Math.floor(Math.random()*(r-t)),o=`${i} ${(a-9+24)%24} * * *`;e.on.schedule=[{cron:o}]}async function bt(e,t){let r=_e.default.dump(e,{lineWidth:-1,noCompatMode:!0,styles:{"!!null":"empty"}});await T.default.promises.writeFile(t,r)}var J=c(require("node:fs")),L=c(require("node:path")),Se=c(require("js-yaml"));async function $t(e){return m.function("generateYarnrcYml",async()=>{let t=U("yarn",["--version"],e.dirPath),r=yr("@yarnpkg/cli",e.dirPath);Ct(t)<=Ct(r)&&t!==r&&v("yarn",["set","version",r],e.dirPath,1);let n=L.default.join(e.dirPath,".yarn","releases");await J.default.promises.mkdir(n,{recursive:!0});for(let f of await J.default.promises.readdir(n))f.startsWith("yarn-")&&!f.startsWith(`yarn-${r}.`)&&(await p.run(()=>J.default.promises.rm(L.default.join(n,f))),console.log("Removed",L.default.join(n,f)));let s=L.default.resolve(e.dirPath,".yarnrc");await p.run(()=>J.default.promises.rm(s,{force:!0}));let i=L.default.resolve(e.dirPath,".yarnrc.yml"),a=Se.default.load(await J.default.promises.readFile(i,"utf8"));a.defaultSemverRangePrefix="",e.requiringNodeModules&&(a.nodeLinker="node-modules",a.nmMode="hardlinks-global",a.enableGlobalCache=!0),await J.default.promises.writeFile(i,Se.default.dump(a,{lineWidth:-1}));let o=(a.plugins||[]).map(f=>f.spec),l=e.containingTypeScript||e.containingTypeScriptInPackages;Ft(e,o,l,"@yarnpkg/plugin-typescript"),l&&!e.requiringNodeModules&&v("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),Ft(e,o,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),v("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)})}function yr(e,t){let r=U("npm",["show",e,"versions","--json"],t),n=JSON.parse(r);return n[n.length-1]}function Ft(e,t,r,n){r!==t.includes(n)&&v("yarn",["plugin",r?"import":"remove",n],e.dirPath)}function Ct(e){let[t]=e.split(".");return Number(t)}async function Rt(e){return m.function("setupLabels",async()=>{if(!ie)return;let[t,r]=E.getOrgAndName(e.repository??"");if(!(!t||!r)&&!(t!=="WillBooster"&&t!=="WillBoosterLab"))try{await u(t,r,"d1: x-easy :hedgehog:","EDE9FE"),await u(t,r,"d2: easy :rabbit2:","DDD6FE"),await u(t,r,"d3: medium :ox:","C4B5FD"),await u(t,r,"d4: hard :squid:","A78BFA"),await u(t,r,"d5: x-hard :whale2:","8B5CF6"),await u(t,r,"p1: critical :fire::fire::fire:","EF4444"),await u(t,r,"p2: urgent :fire::fire:","F87171"),await u(t,r,"p3: important :fire:","FCA5A5"),await u(t,r,"p4: nice to have :droplet:","FECACA"),await u(t,r,"r: blitz","5300bc"),await u(t,r,"r: firebase","ffca28"),await u(t,r,"r: prisma","0c344b"),await u(t,r,"r: react","61dafb"),await u(t,r,"r: svelte","ff3e00"),await u(t,r,"r: semantic-release","494949"),await u(t,r,"ready :rocket:","22C55E"),await u(t,r,"review requested :mag:","FBCA04"),await u(t,r,"released :bookmark:","6366F1"),await u(t,r,"s: 0.5h :clock1230:","F3F4F6"),await u(t,r,"s: 1h :clock1:","E5E7EB"),await u(t,r,"s: 2h :clock2:","D1D5DB"),await u(t,r,"s: 3h :clock3:","9CA3AF"),await u(t,r,"s: 5h :clock5:","6B7280"),await u(t,r,"s: 8h :clock8:","4B5563"),await u(t,r,"s: 13h :clock1:","374151"),await u(t,r,"t: build :hammer:","BFDBFE"),await u(t,r,"t: chore :broom:","BFDBFE"),await u(t,r,"t: ci :construction_worker:","BFDBFE"),await u(t,r,"t: docs :memo:","BFDBFE"),await u(t,r,"t: feat :sparkles:","BFDBFE"),await u(t,r,"t: fix :bug:","BFDBFE"),await u(t,r,"t: perf :zap:","BFDBFE"),await u(t,r,"t: refactor :recycle:","BFDBFE"),await u(t,r,"t: style :lipstick:","BFDBFE"),await u(t,r,"t: test :test_tube:","BFDBFE"),await u(t,r,"project","24292F"),await _(t,r,"bug"),await _(t,r,"documentation"),await _(t,r,"duplicate"),await _(t,r,"enhancement"),await _(t,r,"good first issue"),await _(t,r,"help wanted"),await _(t,r,"invalid"),await _(t,r,"question"),await _(t,r,"wontfix"),await _(t,r,"ready"),await _(t,r,"review requested"),await _(t,r,"released"),await _(t,r,"semantic-release")}catch(n){console.warn("Skip setupLabels due to:",(n==null?void 0:n.stack)??n)}})}async function u(e,t,r,n){try{await C.request("POST /repos/{owner}/{repo}/labels",{owner:e,repo:t,name:r,color:n})}catch{await C.request("PATCH /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:r,color:n})}}async function _(e,t,r){try{await C.request("DELETE /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:r})}catch{}}var Tt=c(require("dotenv")),D=c(require("libsodium-wrappers"));var hr=["READY_DISCORD_WEBHOOK_URL"];async function jt(e){return m.function("setupSecrets",async()=>{if(!ie)return;let[t,r]=E.getOrgAndName(e.repository??"");if(!t||!r||t!=="WillBoosterLab")return;let n=Tt.default.config().parsed||{};if(Object.keys(n).length!==0)try{for(let o of hr)try{await C.request("DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:r,secret_name:o})}catch{}let s=await C.request("GET /repos/{owner}/{repo}/actions/secrets/public-key",{owner:t,repo:r}),{key:i,key_id:a}=s.data;await D.default.ready;for(let[o,l]of Object.entries(n)){if(e.publicRepo&&o==="GH_BOT_PAT"||!e.publicRepo&&o==="PUBLIC_GH_BOT_PAT")continue;let f=D.default.from_base64(i,D.default.base64_variants.ORIGINAL),d=D.default.from_string(l),h=D.default.crypto_box_seal(d,f),g=D.default.to_base64(h,D.default.base64_variants.ORIGINAL);await C.request("PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:r,secret_name:o,encrypted_value:g,key_id:a})}}catch(s){console.warn("Skip setupSecrets due to:",(s==null?void 0:s.stack)??s)}})}async function Et(e){}var S=c(require("node:fs")),Y=c(require("node:fs/promises")),P=c(require("node:path")),B=c(require("glob")),Dt=c(require("js-yaml")),Bt=require("simple-git");async function Fe(e){var r;let t=P.default.resolve(e,"package.json");try{let n=S.default.existsSync(t),s={},i={},a={};if(n){let F=S.default.readFileSync(t,"utf8");a=JSON.parse(F),s=a.dependencies??{},i=a.devDependencies??{}}let o=!0;try{let F=P.default.resolve(e,".yarnrc.yml"),x=Dt.default.load(await Y.default.readFile(F,"utf8"));o=!x.nodeLinker||x.nodeLinker==="node-modules"}catch{}let l=[],f=[];try{let F=P.default.resolve(e,".releaserc.json"),x=JSON.parse(await Y.default.readFile(F,"utf8"));l=(x==null?void 0:x.branches)||[],f=((r=x==null?void 0:x.plugins)==null?void 0:r.flat())||[]}catch{}let d=P.default.basename(P.default.resolve(e,".."))!=="packages"||!S.default.existsSync(P.default.resolve(e,"..","..","package.json")),h;d&&(h=await Pr(e,a));let g;try{g=await Y.default.readFile(P.default.resolve(e,".tool-versions"),"utf8")}catch{try{g="nodejs "+(await Y.default.readFile(P.default.resolve(e,".node-version"),"utf8")).trim()}catch{}}let w={dirPath:e,root:d,publicRepo:(h==null?void 0:h.private)===!1,referred:!!a.files,repository:h!=null&&h.full_name?`github:${h==null?void 0:h.full_name}`:void 0,willBoosterConfigs:t.includes(`${P.default.sep}willbooster-configs`),containingSubPackageJsons:B.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:S.default.existsSync(P.default.resolve(e,"Dockerfile"))||S.default.existsSync(P.default.resolve(e,"docker-compose.yml")),containingGemfile:S.default.existsSync(P.default.resolve(e,"Gemfile")),containingGoMod:S.default.existsSync(P.default.resolve(e,"go.mod")),containingPackageJson:S.default.existsSync(P.default.resolve(e,"package.json")),containingPoetryLock:S.default.existsSync(P.default.resolve(e,"poetry.lock")),containingPomXml:S.default.existsSync(P.default.resolve(e,"pom.xml")),containingPubspecYaml:S.default.existsSync(P.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:S.default.existsSync(P.default.resolve(e,"template.yaml")),containingJavaScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsx:B.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsxInPackages:B.default.sync("packages/**/@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,depending:{blitz:(s.blitz||i.blitz||"").replace("^","")[0],firebase:!!i["firebase-tools"],prisma:!!i.prisma,reactNative:!!s["react-native"],semanticRelease:!!(i["semantic-release"]||l.length>0||f.length>0),storybook:!!i["@storybook/react"]},release:{branches:l,github:f.includes("@semantic-release/github"),npm:f.includes("@semantic-release/npm")},requiringNodeModules:o,versionsText:g};if(w.eslintBase=wr(w),w.containingGemfile||w.containingGoMod||w.containingPackageJson||w.containingPoetryLock||w.containingPomXml||w.containingPubspecYaml||w.containingTemplateYaml)return w}catch{}}function wr(e){if(e.containingTypeScript)return e.containingJsxOrTsx?"@willbooster/eslint-config-ts-react":"@willbooster/eslint-config-ts";if(e.containingJsxOrTsx)return"@willbooster/eslint-config-js-react";if(e.containingJavaScript)return"@willbooster/eslint-config-js"}async function Pr(e,t){var o,l,f;let s=(await(0,Bt.simpleGit)(e).getRemotes(!0)).find(d=>d.name==="origin"),i=((o=s==null?void 0:s.refs)==null?void 0:o.fetch)??((l=s==null?void 0:s.refs)==null?void 0:l.push);if(typeof i=="string"){let d=await Ot(i);if(d)return d}let a=((f=t.repository)==null?void 0:f.url)??t.repository;if(typeof a=="string"){let d=await Ot(a);if(d&&d.message!=="Not Found")return d}}async function Ot(e){let[t,r]=E.getOrgAndName(e);if(!t||!r)return;let n={full_name:`${t}/${r}`};try{let s=await C.request("GET /repos/{owner}/{repo}",{owner:t,repo:r});Object.assign(n,s.data)}catch{}return n}async function vr(){let e=await(0,It.default)(process.argv.slice(2)).command("wbfy <paths...>","Generate/update project files for WillBooster").demandCommand(1).alias("d","skipDeps").boolean("skipDeps").default("skipDeps",!1).describe("skipDeps","Skip dependency installation").alias("v","verbose").boolean("verbose").default("verbose",!1).argv;j.isVerbose=e.verbose;for(let t of e._){if(typeof t=="number")continue;let r=await Fe(t);if(!r){console.error(`there is no valid package.json in ${t}`);continue}let n=r.containingSubPackageJsons?Wt.default.sync("packages/*",{cwd:t}).map(l=>Nt.default.resolve(t,l)):[],i=(await Promise.all(n.map(l=>Fe(l)))).filter(l=>!!l),a=[r,...i];if(j.isVerbose)for(let l of a)console.info(l);await Te(r),await $t(r),await Promise.all([Ee(r),Ye(r),Ve(r),Xe(r),he(r),ct(r),gt(r),ft(r),St(r),Rt(r),jt(r),Et(r)]),await p.promiseAll();let o=[];for(let l of a)await qe(l,r),await p.promiseAll(),!(!l.root&&!l.containingPackageJson)&&(await at(l),await ot(l,r,e.skipDeps),o.push(he(l)),(l.containingTypeScript||l.containingTypeScriptInPackages)&&o.push(vt(l,r)),(l.containingJavaScript||l.containingJavaScriptInPackages||l.containingTypeScript||l.containingTypeScriptInPackages)&&(r.willBoosterConfigs||o.push(He(l,r)),o.push(Je(l))));await Promise.all(o),await p.promiseAll(),v("yarn",["cleanup"],t),v("yarn",["install"],t)}}vr().then();
|
268
|
+
`);let l=n+st+o+a+s;await p.run(()=>y.generateFile(t,l))})}var ne=c(require("node:fs")),be=c(require("node:path"));async function ct(e){return m.function("generateReadme",async()=>{var r,a;let t=be.default.resolve(e.dirPath,"README.md"),i=await ne.default.promises.readFile(t,"utf8");i=lt(e,i,ci,".releaserc.json");let n=(a=e.repository)==null?void 0:a.slice(((r=e.repository)==null?void 0:r.indexOf(":"))+1),s=ne.default.readdirSync(`${e.dirPath}/.github/workflows`);for(let o of s){if(!o.startsWith("test")&&!o.startsWith("deploy"))continue;let l=o;l=l.charAt(0).toUpperCase()+l.slice(1,l.indexOf(".")),l=l.replace("-"," ");let d=`[](https://github.com/${n}/actions/workflows/${o})`;i=lt(e,i,d,`.github/workflows/${o}`)}await p.run(()=>y.generateFile(t,i))})}var ci="[](https://github.com/semantic-release/semantic-release)";function lt(e,t,i,n){if(!ne.default.existsSync(be.default.resolve(e.dirPath,n)))return t;let s=t.indexOf(i);s>=0&&(t=t.slice(0,s)+t.slice(s+i.length));let r=!1;for(let a=0;a<t.length;a++)if(t[a]===`
|
269
|
+
`){r=!0,t=`${t.slice(0,a+1)}${i}
|
270
|
+
${t.slice(a+1)}`;break}return r||(t=`${t}
|
271
|
+
${i}
|
272
|
+
`),t}var pt=c(require("node:fs")),mt=c(require("node:path")),xe=c(require("deepmerge"));async function dt(e){return m.function("generateReleaserc",async()=>{let t=mt.default.resolve(e.dirPath,".releaserc.json");try{let i=JSON.parse(await pt.default.promises.readFile(t,"utf8")),n=(i==null?void 0:i.plugins)||[];for(let r=0;r<n.length;r++){let a=Array.isArray(n[r])?n[r][0]:n[r],o=Array.isArray(n[r])&&n[r][1]||{};a==="@semantic-release/commit-analyzer"?n[r]=["@semantic-release/commit-analyzer",xe.default.all([o,{preset:"conventionalcommits"}],{arrayMerge:N})]:a==="@semantic-release/github"&&(n[r]=["@semantic-release/github",xe.default.all([o,{successComment:!1,labels:["r: semantic-release"],releasedLabels:["released :bookmark:"]}],{arrayMerge:N})])}let s=JSON.stringify(i);await p.run(()=>y.generateFile(t,s))}catch{}})}var oe=c(require("node:fs")),se=c(require("node:path")),ut=c(require("deepmerge")),ft=c(require("lodash.clonedeep"));var pi={extends:["@willbooster"]};async function gt(e){return m.function("generateRenovateJson",async()=>{let t=(0,ft.default)(pi),i=se.default.resolve(e.dirPath,".renovaterc.json");try{let s=await oe.default.promises.readFile(i,"utf8"),r=JSON.parse(s);t=ut.default.all([t,r,t],{arrayMerge:N})}catch{}await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,".dependabot"),{force:!0})),await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let n=JSON.stringify(t);await p.run(()=>y.generateFile(i,n))})}var yt=c(require("node:fs")),ht=c(require("node:path")),wt=c(require("deepmerge")),Pt=c(require("lodash.clonedeep"));function M(e){let t=Object.entries(e).sort(([i],[n])=>i.localeCompare(n));for(let[i,n]of t)delete e[i],e[i]=n;return e}var mi={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["./node_modules/@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","packages/*/scripts/**/*"]},di={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["../../node_modules/@types","../../@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*"]};async function vt(e,t){return m.function("generateTsconfig",async()=>{var r,a;if(t.depending.blitz)return;let i=(0,Pt.default)(e.root?mi:di);!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete i.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(i.include=i.include.filter(o=>!o.startsWith("packages/*/")));let n=ht.default.resolve(e.dirPath,"tsconfig.json");try{let o=await yt.default.promises.readFile(n,"utf8"),l=JSON.parse(o);l.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete l.extends,(r=i==null?void 0:i.compilerOptions)==null||delete r.target,(a=i==null?void 0:i.compilerOptions)==null||delete a.module,l.jsx&&delete i.jsx,i=wt.default.all([i,l,i],{arrayMerge:N}),i.include=i.include.filter(d=>!d.includes("@types"))}catch{}M(i.compilerOptions);let s=JSON.stringify(i);await p.run(()=>y.generateFile(n,s))})}var T=c(require("node:fs")),R=c(require("node:path")),xt=c(require("deepmerge")),_e=c(require("js-yaml")),_t=c(require("lodash.clonedeep"));var ui={test:{name:"Test",on:{pull_request:null,push:{branches:["main","wbfy","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},release:{name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},wbfy:{name:"Willboosterify",on:{workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}},"wbfy-merge":{name:"Merge wbfy",on:{workflow_dispatch:null},jobs:{"wbfy-merge":{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy-merge.yml@main"}}},"semantic-pr":{name:"Lint PR title",on:{pull_request_target:{types:["opened","edited","synchronize"]}},jobs:{"semantic-pr":{uses:"WillBooster/reusable-workflows/.github/workflows/semantic-pr.yml@main"}}},"notify-ready":{name:"Notify ready",on:{issues:{types:["labeled"]}},jobs:{"notify-ready":{uses:"WillBooster/reusable-workflows/.github/workflows/notify-ready.yml@main",secrets:{DISCORD_WEBHOOK_URL:"${{ secrets.DISCORD_WEBHOOK_URL_FOR_READY }}"}}}},"close-comment":{name:"Add close comment",on:{pull_request:{types:["opened"]}},jobs:{"close-comment":{uses:"WillBooster/reusable-workflows/.github/workflows/close-comment.yml@main"}}},"add-issue-to-project":{name:"Add issue to github project",on:{issues:{types:["labeled"]}},jobs:{"add-to-project":{uses:"WillBooster/reusable-workflows/.github/workflows/add-issue-to-project.yml@main",secrets:{GH_PROJECT_URL:"${{ secrets.GH_PROJECT_URL }}",GH_BOT_PAT:"${{ secrets.GH_BOT_PAT }}"}}}}};async function St(e){return m.function("generateWorkflow",async()=>{var r;let t=R.default.resolve(e.dirPath,".github","workflows");await T.default.promises.mkdir(t,{recursive:!0});let i=R.default.resolve(e.dirPath,".github","semantic.yml");await p.run(()=>T.default.promises.rm(i,{force:!0,recursive:!0}));let s=(await T.default.promises.readdir(t,{withFileTypes:!0})).filter(a=>a.isFile()&&a.name.endsWith(".yml")).map(a=>a.name);e.depending.semanticRelease&&s.push("release.yml"),(e.publicRepo||(r=e.repository)!=null&&r.startsWith("github:WillBoosterLab/"))&&s.push("notify-ready.yml"),s.push("test.yml","wbfy.yml","wbfy-merge.yml","semantic-pr.yml","close-comment.yml","add-issue-to-project.yml");for(let a of s){let o=R.default.basename(a,".yml");await p.run(()=>fi(e,t,o))}})}async function fi(e,t,i){var r,a;let n=(0,_t.default)(ui[i]||{}),s=R.default.join(t,`${i}.yml`);try{let o=await T.default.promises.readFile(s,"utf8"),l=_e.default.load(o);n=xt.default.all([n,l,n],{arrayMerge:X})}catch{}for(let o of Object.values(n.jobs)){if(!((a=(r=o.uses)==null?void 0:r.includes)!=null&&a.call(r,"/reusable-workflows/")))return;gi(e,o,i)}switch(i){case"release":{if(n.on.schedule)delete n.on.push;else if(e.release.branches.length>0)n.on.push.branches=e.release.branches;else{await T.default.promises.rm(R.default.join(t,"release.yml"),{force:!0});return}break}case"wbfy":{kt(n,20,24);break}case"wbfy-merge":{kt(n,0,4);break}}if(await bt(n,s),i==="release")await T.default.promises.rm(R.default.join(t,"semantic-release.yml"),{force:!0});else if(i==="sync"){if(await T.default.promises.rm(R.default.join(t,"sync-init.yml"),{force:!0}),!n.jobs.sync)return;n.jobs["sync-force"]=n.jobs.sync;let o=n.jobs.sync.with.sync_params_without_dest;if(!o)return;n.jobs.sync.with.sync_params_without_dest=`--force ${o}`,n.name="Force to Sync",n.on={workflow_dispatch:null},delete n.jobs.sync,await bt(n,R.default.join(t,"sync-force.yml"))}}function gi(e,t,i){var n,s,r;if(t.with||={},t.secrets||={},(e.release.github&&i==="test"||i==="release"||i==="wbfy"||i==="wbfy-merge")&&(t.secrets.GH_TOKEN=e.publicRepo?"${{ secrets.PUBLIC_GH_BOT_PAT }}":"${{ secrets.GH_BOT_PAT }}"),e.release.npm&&(i==="release"||i==="test")&&(t.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}"),t.secrets.FIREBASE_TOKEN&&(t.secrets.GCP_SA_KEY_JSON_FOR_FIREBASE="${{ secrets.GCP_SA_KEY_JSON_FOR_FIREBASE }}",delete t.secrets.FIREBASE_TOKEN),(t.secrets.DISCORD_WEBHOOK_URL&&(i==="release"||i.startsWith("deploy"))||t.with.server_url&&i.startsWith("deploy"))&&(t.secrets.DISCORD_WEBHOOK_URL="${{ secrets.DISCORD_WEBHOOK_URL_FOR_RELEASE }}"),i==="sync"){let a=(n=t.with)==null?void 0:n.sync_params_without_dest;a&&(t.with.sync_params_without_dest=a.replace("sync ",""))}if((s=e.repository)!=null&&s.startsWith("github:WillBooster/")?t.uses=t.uses.replace("WillBoosterLab/","WillBooster/"):(r=e.repository)!=null&&r.startsWith("github:WillBoosterLab/")&&(t.uses=t.uses.replace("WillBooster/","WillBoosterLab/")),delete t.with.non_self_hosted,delete t.with.notify_discord,delete t.with.require_fly,delete t.with.require_gcloud,t.with.dot_env_path===".env"&&delete t.with.dot_env_path,e.containingDockerfile&&i.startsWith("deploy")&&(t.with.cpu_arch="X64"),i==="release"||i==="test"||i==="wbfy"||i==="wbfy-merge"||i.startsWith("deploy")?e.publicRepo&&(t.with.github_hosted_runner=!0):delete t.with.github_hosted_runner,Object.keys(t.with).length>0?M(t.with):delete t.with,Object.keys(t.secrets).length>0){let a=M(t.secrets);delete t.secrets,t.secrets=a}else delete t.secrets}function kt(e,t,i){var l,d;let[n,s]=(((d=(l=e.on.schedule)==null?void 0:l[0])==null?void 0:d.cron)??"").split(" ").map(Number);if(n!==0&&Number.isInteger(s)){let f=(s+9)%24,h=t<i?t<=f&&f<i:t<=f||f<i;if(h)return;console.log("setSchedule:",e,n,s,h,f,t,i)}else console.log("setSchedule:",e,n,s);let r=1+Math.floor(Math.random()*59),a=t+Math.floor(Math.random()*(i-t)),o=`${r} ${(a-9+24)%24} * * *`;e.on.schedule=[{cron:o}]}async function bt(e,t){let i=_e.default.dump(e,{lineWidth:-1,noCompatMode:!0,styles:{"!!null":"empty"}});await T.default.promises.writeFile(t,i)}var J=c(require("node:fs")),L=c(require("node:path")),Se=c(require("js-yaml"));async function $t(e){return m.function("generateYarnrcYml",async()=>{let t=U("yarn",["--version"],e.dirPath),i=yi("@yarnpkg/cli",e.dirPath);Ct(t)<=Ct(i)&&t!==i&&v("yarn",["set","version",i],e.dirPath,1);let n=L.default.join(e.dirPath,".yarn","releases");await J.default.promises.mkdir(n,{recursive:!0});for(let d of await J.default.promises.readdir(n))d.startsWith("yarn-")&&!d.startsWith(`yarn-${i}.`)&&(await p.run(()=>J.default.promises.rm(L.default.join(n,d))),console.log("Removed",L.default.join(n,d)));let s=L.default.resolve(e.dirPath,".yarnrc");await p.run(()=>J.default.promises.rm(s,{force:!0}));let r=L.default.resolve(e.dirPath,".yarnrc.yml"),a=Se.default.load(await J.default.promises.readFile(r,"utf8"));a.defaultSemverRangePrefix="",e.requiringNodeModules&&(a.nodeLinker="node-modules",a.nmMode="hardlinks-global",a.enableGlobalCache=!0),await J.default.promises.writeFile(r,Se.default.dump(a,{lineWidth:-1}));let o=(a.plugins||[]).map(d=>d.spec),l=e.containingTypeScript||e.containingTypeScriptInPackages;Ft(e,o,l,"@yarnpkg/plugin-typescript"),l&&!e.requiringNodeModules&&v("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),Ft(e,o,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),v("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)})}function yi(e,t){let i=U("npm",["show",e,"versions","--json"],t),n=JSON.parse(i);return n[n.length-1]}function Ft(e,t,i,n){i!==t.includes(n)&&v("yarn",["plugin",i?"import":"remove",n],e.dirPath)}function Ct(e){let[t]=e.split(".");return Number(t)}async function Rt(e){return m.function("setupLabels",async()=>{if(!re)return;let[t,i]=j.getOrgAndName(e.repository??"");if(!(!t||!i)&&!(t!=="WillBooster"&&t!=="WillBoosterLab"))try{await u(t,i,"d1: x-easy :hedgehog:","EDE9FE"),await u(t,i,"d2: easy :rabbit2:","DDD6FE"),await u(t,i,"d3: medium :ox:","C4B5FD"),await u(t,i,"d4: hard :squid:","A78BFA"),await u(t,i,"d5: x-hard :whale2:","8B5CF6"),await u(t,i,"p1: critical :fire::fire::fire:","EF4444"),await u(t,i,"p2: urgent :fire::fire:","F87171"),await u(t,i,"p3: important :fire:","FCA5A5"),await u(t,i,"p4: nice to have :droplet:","FECACA"),await u(t,i,"r: blitz","5300bc"),await u(t,i,"r: firebase","ffca28"),await u(t,i,"r: prisma","0c344b"),await u(t,i,"r: react","61dafb"),await u(t,i,"r: svelte","ff3e00"),await u(t,i,"r: semantic-release","494949"),await u(t,i,"ready :rocket:","22C55E"),await u(t,i,"review requested :mag:","FBCA04"),await u(t,i,"released :bookmark:","6366F1"),await u(t,i,"s: 0.5h :clock1230:","F3F4F6"),await u(t,i,"s: 1h :clock1:","E5E7EB"),await u(t,i,"s: 2h :clock2:","D1D5DB"),await u(t,i,"s: 3h :clock3:","9CA3AF"),await u(t,i,"s: 5h :clock5:","6B7280"),await u(t,i,"s: 8h :clock8:","4B5563"),await u(t,i,"s: 13h :clock1:","374151"),await u(t,i,"t: build :hammer:","BFDBFE"),await u(t,i,"t: chore :broom:","BFDBFE"),await u(t,i,"t: ci :construction_worker:","BFDBFE"),await u(t,i,"t: docs :memo:","BFDBFE"),await u(t,i,"t: feat :sparkles:","BFDBFE"),await u(t,i,"t: fix :bug:","BFDBFE"),await u(t,i,"t: perf :zap:","BFDBFE"),await u(t,i,"t: refactor :recycle:","BFDBFE"),await u(t,i,"t: style :lipstick:","BFDBFE"),await u(t,i,"t: test :test_tube:","BFDBFE"),await u(t,i,"project","24292F"),await _(t,i,"bug"),await _(t,i,"documentation"),await _(t,i,"duplicate"),await _(t,i,"enhancement"),await _(t,i,"good first issue"),await _(t,i,"help wanted"),await _(t,i,"invalid"),await _(t,i,"question"),await _(t,i,"wontfix"),await _(t,i,"ready"),await _(t,i,"review requested"),await _(t,i,"released"),await _(t,i,"semantic-release")}catch(n){console.warn("Skip setupLabels due to:",(n==null?void 0:n.stack)??n)}})}async function u(e,t,i,n){try{await C.request("POST /repos/{owner}/{repo}/labels",{owner:e,repo:t,name:i,color:n})}catch{await C.request("PATCH /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:i,color:n})}}async function _(e,t,i){try{await C.request("DELETE /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:i})}catch{}}var Tt=c(require("dotenv")),D=c(require("libsodium-wrappers"));var hi=["READY_DISCORD_WEBHOOK_URL"];async function Et(e){return m.function("setupSecrets",async()=>{if(!re)return;let[t,i]=j.getOrgAndName(e.repository??"");if(!t||!i||t!=="WillBoosterLab")return;let n=Tt.default.config().parsed||{};if(Object.keys(n).length!==0)try{for(let o of hi)try{await C.request("DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:i,secret_name:o})}catch{}let s=await C.request("GET /repos/{owner}/{repo}/actions/secrets/public-key",{owner:t,repo:i}),{key:r,key_id:a}=s.data;await D.default.ready;for(let[o,l]of Object.entries(n)){if(e.publicRepo&&o==="GH_BOT_PAT"||!e.publicRepo&&o==="PUBLIC_GH_BOT_PAT")continue;let d=D.default.from_base64(r,D.default.base64_variants.ORIGINAL),f=D.default.from_string(l),h=D.default.crypto_box_seal(f,d),g=D.default.to_base64(h,D.default.base64_variants.ORIGINAL);await C.request("PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:i,secret_name:o,encrypted_value:g,key_id:a})}}catch(s){console.warn("Skip setupSecrets due to:",(s==null?void 0:s.stack)??s)}})}async function jt(e){}var S=c(require("node:fs")),Y=c(require("node:fs/promises")),P=c(require("node:path")),B=c(require("glob")),Dt=c(require("js-yaml")),Bt=require("simple-git");async function Fe(e){var i;let t=P.default.resolve(e,"package.json");try{let n=S.default.existsSync(t),s={},r={},a={};if(n){let F=S.default.readFileSync(t,"utf8");a=JSON.parse(F),s=a.dependencies??{},r=a.devDependencies??{}}let o=!0;try{let F=P.default.resolve(e,".yarnrc.yml"),x=Dt.default.load(await Y.default.readFile(F,"utf8"));o=!x.nodeLinker||x.nodeLinker==="node-modules"}catch{}let l=[],d=[];try{let F=P.default.resolve(e,".releaserc.json"),x=JSON.parse(await Y.default.readFile(F,"utf8"));l=(x==null?void 0:x.branches)||[],d=((i=x==null?void 0:x.plugins)==null?void 0:i.flat())||[]}catch{}let f=P.default.basename(P.default.resolve(e,".."))!=="packages"||!S.default.existsSync(P.default.resolve(e,"..","..","package.json")),h;f&&(h=await Pi(e,a));let g;try{g=await Y.default.readFile(P.default.resolve(e,".tool-versions"),"utf8")}catch{try{g="nodejs "+(await Y.default.readFile(P.default.resolve(e,".node-version"),"utf8")).trim()}catch{}}let w={dirPath:e,root:f,publicRepo:(h==null?void 0:h.private)===!1,referred:!!a.files,repository:h!=null&&h.full_name?`github:${h==null?void 0:h.full_name}`:void 0,willBoosterConfigs:t.includes(`${P.default.sep}willbooster-configs`),containingSubPackageJsons:B.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:S.default.existsSync(P.default.resolve(e,"Dockerfile"))||S.default.existsSync(P.default.resolve(e,"docker-compose.yml")),containingGemfile:S.default.existsSync(P.default.resolve(e,"Gemfile")),containingGoMod:S.default.existsSync(P.default.resolve(e,"go.mod")),containingPackageJson:S.default.existsSync(P.default.resolve(e,"package.json")),containingPoetryLock:S.default.existsSync(P.default.resolve(e,"poetry.lock")),containingPomXml:S.default.existsSync(P.default.resolve(e,"pom.xml")),containingPubspecYaml:S.default.existsSync(P.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:S.default.existsSync(P.default.resolve(e,"template.yaml")),containingJavaScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsx:B.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsxInPackages:B.default.sync("packages/**/@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,depending:{blitz:(s.blitz||r.blitz||"").replace("^","")[0],firebase:!!r["firebase-tools"],prisma:!!r.prisma,reactNative:!!s["react-native"],semanticRelease:!!(r["semantic-release"]||l.length>0||d.length>0),storybook:!!r["@storybook/react"]},release:{branches:l,github:d.includes("@semantic-release/github"),npm:d.includes("@semantic-release/npm")},requiringNodeModules:o,versionsText:g};if(w.eslintBase=wi(w),w.containingGemfile||w.containingGoMod||w.containingPackageJson||w.containingPoetryLock||w.containingPomXml||w.containingPubspecYaml||w.containingTemplateYaml)return w}catch{}}function wi(e){if(e.containingTypeScript)return e.containingJsxOrTsx?"@willbooster/eslint-config-ts-react":"@willbooster/eslint-config-ts";if(e.containingJsxOrTsx)return"@willbooster/eslint-config-js-react";if(e.containingJavaScript)return"@willbooster/eslint-config-js"}async function Pi(e,t){var o,l,d;let s=(await(0,Bt.simpleGit)(e).getRemotes(!0)).find(f=>f.name==="origin"),r=((o=s==null?void 0:s.refs)==null?void 0:o.fetch)??((l=s==null?void 0:s.refs)==null?void 0:l.push);if(typeof r=="string"){let f=await Ot(r);if(f)return f}let a=((d=t.repository)==null?void 0:d.url)??t.repository;if(typeof a=="string"){let f=await Ot(a);if(f&&f.message!=="Not Found")return f}}async function Ot(e){let[t,i]=j.getOrgAndName(e);if(!t||!i)return;let n={full_name:`${t}/${i}`};try{let s=await C.request("GET /repos/{owner}/{repo}",{owner:t,repo:i});Object.assign(n,s.data)}catch{}return n}async function vi(){let e=await(0,It.default)(process.argv.slice(2)).command("wbfy <paths...>","Generate/update project files for WillBooster").demandCommand(1).alias("d","skipDeps").boolean("skipDeps").default("skipDeps",!1).describe("skipDeps","Skip dependency installation").alias("v","verbose").boolean("verbose").default("verbose",!1).argv;E.isVerbose=e.verbose;for(let t of e._){if(typeof t=="number")continue;let i=await Fe(t);if(!i){console.error(`there is no valid package.json in ${t}`);continue}let n=i.containingSubPackageJsons?Wt.default.sync("packages/*",{cwd:t}).map(l=>Nt.default.resolve(t,l)):[],r=(await Promise.all(n.map(l=>Fe(l)))).filter(l=>!!l),a=[i,...r];if(E.isVerbose)for(let l of a)console.info(l);await Te(i),await $t(i),await Promise.all([je(i),Ye(i),Ve(i),Xe(i),he(i),ct(i),gt(i),dt(i),St(i),Rt(i),Et(i),jt(i)]),await p.promiseAll();let o=[];for(let l of a)await qe(l,i),await p.promiseAll(),!(!l.root&&!l.containingPackageJson)&&(await at(l),await ot(l,i,e.skipDeps),o.push(he(l)),(l.containingTypeScript||l.containingTypeScriptInPackages)&&o.push(vt(l,i)),(l.containingJavaScript||l.containingJavaScriptInPackages||l.containingTypeScript||l.containingTypeScriptInPackages)&&(i.willBoosterConfigs||o.push(He(l,i)),o.push(Je(l))));await Promise.all(o),await p.promiseAll(),v("yarn",["cleanup"],t),v("yarn",["install"],t)}}vi().then();
|
273
273
|
//# sourceMappingURL=index.min.cjs.map
|