binary-collections 2.0.13 → 2.0.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (286) hide show
  1. package/binaries/binary-executor.cjs +307 -238
  2. package/binaries/clean-nodemodule.cjs +307 -238
  3. package/binaries/clean-nodemodules.cjs +307 -238
  4. package/binaries/composer.cjs +323 -0
  5. package/binaries/composer.cmd +2 -0
  6. package/binaries/composer.phar +0 -0
  7. package/binaries/dev.cjs +307 -238
  8. package/binaries/empty.cjs +307 -238
  9. package/binaries/git-reduce-size.cjs +307 -238
  10. package/binaries/javakill.cjs +307 -238
  11. package/binaries/kill-process.cjs +307 -238
  12. package/binaries/nodekill.cjs +307 -238
  13. package/binaries/prod.cjs +307 -238
  14. package/binaries/py.cjs +307 -238
  15. package/binaries/rmfind.cjs +307 -238
  16. package/binaries/rmx.cjs +307 -238
  17. package/binaries/submodule-token.cjs +307 -238
  18. package/binaries/test-cjs.cjs +307 -238
  19. package/binaries/test-esm.cjs +307 -238
  20. package/binaries/yarn-clean.cjs +307 -238
  21. package/binaries/yc.cjs +307 -238
  22. package/binaries/ycw.cjs +307 -238
  23. package/docs-src/binary-collections.md +1 -1
  24. package/docs-src/clean-github-actions-caches.md +1 -1
  25. package/docs-src/copy-move-file.md +1 -4
  26. package/docs-src/del-ps.md +1 -1
  27. package/docs-src/find-node-modules.md +1 -1
  28. package/docs-src/generate-test-ci.md +56 -0
  29. package/docs-src/get-latest-workflow-status.md +100 -0
  30. package/docs-src/git-diff.md +1 -1
  31. package/docs-src/git-fix.md +1 -1
  32. package/docs-src/git-purge.md +1 -1
  33. package/docs-src/kill-night-crows.md +1 -1
  34. package/docs-src/node-cache-cleaner.md +2 -2
  35. package/docs-src/node-package-packer.md +1 -1
  36. package/docs-src/opencode-cli.md +127 -0
  37. package/docs-src/package-resolutions-updater.md +1 -1
  38. package/docs-src/rmpath.md +1 -1
  39. package/docs-src/run-by-checksum.md +1 -1
  40. package/docs-src/submodule-remove.md +1 -1
  41. package/docs-src/upload-backend.md +29 -0
  42. package/docs-src/vscode-cli.md +84 -0
  43. package/docs-src/workflow-badge.md +120 -0
  44. package/lib/binary-collections/config.cjs +14 -2
  45. package/lib/binary-collections/config.d.cts +10 -0
  46. package/lib/binary-collections/config.mjs +2 -2
  47. package/lib/binary-collections/findScript.cjs +43 -21
  48. package/lib/binary-collections/findScript.mjs +2 -2
  49. package/lib/binary-collections/listScript.cjs +43 -21
  50. package/lib/binary-collections/listScript.mjs +2 -2
  51. package/lib/binary-collections.cjs +43 -21
  52. package/lib/binary-collections.mjs +6 -6
  53. package/lib/chunk-2SJKVOTN.mjs +146 -0
  54. package/lib/{chunk-2MN4VPV2.mjs → chunk-3F6EIHYG.mjs} +2 -2
  55. package/lib/chunk-546KAIYT.mjs +113 -0
  56. package/lib/chunk-56BVU63B.mjs +86 -0
  57. package/lib/chunk-5WAOOOGZ.mjs +77 -0
  58. package/lib/chunk-72XTQ3CK.mjs +45 -0
  59. package/lib/chunk-7N52Z4IJ.mjs +39 -0
  60. package/lib/chunk-7Q6YEUQF.mjs +246 -0
  61. package/lib/{chunk-NQXUYO67.mjs → chunk-AJ3OIYYP.mjs} +43 -21
  62. package/lib/chunk-AQZ7LMFS.mjs +100 -0
  63. package/lib/chunk-BDCMTOZI.mjs +246 -0
  64. package/lib/chunk-BEUM4LH4.mjs +184 -0
  65. package/lib/{chunk-TBWXE7ST.mjs → chunk-BO4TZS4Q.mjs} +5 -2
  66. package/lib/chunk-CM3IC5YC.mjs +226 -0
  67. package/lib/{chunk-FLYSZFLW.mjs → chunk-D42YBRZW.mjs} +1 -1
  68. package/lib/chunk-FR3DMHJC.mjs +146 -0
  69. package/lib/chunk-I3O5ZRYU.mjs +77 -0
  70. package/lib/chunk-J4M5EL5P.mjs +108 -0
  71. package/lib/chunk-JK3MG2KF.mjs +236 -0
  72. package/lib/chunk-JMUFQSPE.mjs +184 -0
  73. package/lib/chunk-JVMLKHD2.mjs +62 -0
  74. package/lib/chunk-KAT2JNLZ.mjs +146 -0
  75. package/lib/{chunk-CD3HF3LK.mjs → chunk-KRCPFWIF.mjs} +6 -3
  76. package/lib/chunk-LACQTD5V.mjs +225 -0
  77. package/lib/chunk-MCCMMZSM.mjs +60 -0
  78. package/lib/chunk-OA2RKEY3.mjs +162 -0
  79. package/lib/{chunk-X2B3X7D4.mjs → chunk-PAZH45HS.mjs} +7 -1
  80. package/lib/chunk-QZMGBDSA.mjs +32 -0
  81. package/lib/chunk-RKPIBGKE.mjs +61 -0
  82. package/lib/chunk-SARIXFHP.mjs +44 -0
  83. package/lib/chunk-SJYP66BO.mjs +62 -0
  84. package/lib/chunk-SWUAEY4H.mjs +44 -0
  85. package/lib/chunk-TP3O2JGW.mjs +88 -0
  86. package/lib/chunk-UAIF5VIA.mjs +89 -0
  87. package/lib/chunk-UDZBVKXH.mjs +94 -0
  88. package/lib/chunk-UEOWRYAN.mjs +32 -0
  89. package/lib/chunk-UHPFLJXH.mjs +227 -0
  90. package/lib/chunk-UYNBNLV5.mjs +113 -0
  91. package/lib/chunk-WOC4FZ6F.mjs +164 -0
  92. package/lib/chunk-X7UVQ6ZC.mjs +183 -0
  93. package/lib/{chunk-RDN6HF5Z.mjs → chunk-XI67TI46.mjs} +1 -1
  94. package/lib/chunk-XW5NZAKI.mjs +82 -0
  95. package/lib/chunk-YLV4QATP.mjs +86 -0
  96. package/lib/chunk-YWSLMAQ7.mjs +65 -0
  97. package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
  98. package/lib/cross-env/index.mjs +3 -3
  99. package/lib/del-gradle.cjs +1 -1
  100. package/lib/del-gradle.mjs +22 -16
  101. package/lib/del-node-modules.cjs +1 -1
  102. package/lib/del-node-modules.mjs +148 -142
  103. package/lib/find-node-modules-cli.cjs +1 -1
  104. package/lib/find-node-modules-cli.mjs +10 -4
  105. package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +18 -6
  106. package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
  107. package/lib/{git-diff.cjs → git/git-diff.cjs} +16 -4
  108. package/lib/{git-diff.js → git/git-diff.js} +3 -3
  109. package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
  110. package/lib/{git-fix.cjs → git/git-fix.cjs} +134 -3
  111. package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
  112. package/lib/{git-purge.cjs → git/git-purge.cjs} +1 -1
  113. package/lib/{git-purge.mjs → git/git-purge.mjs} +4 -4
  114. package/lib/git/user-config.cjs +131 -1
  115. package/lib/git/user-config.mjs +3 -1
  116. package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +38 -10
  117. package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +7 -6
  118. package/lib/{clean-github-actions-caches.cjs → github-workflows/clean-github-actions-caches.cjs} +38 -10
  119. package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -4
  120. package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
  121. package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
  122. package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
  123. package/lib/github-workflows/get-latest-workflow-status-cli.cjs +541 -0
  124. package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
  125. package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
  126. package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
  127. package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
  128. package/lib/github-workflows/get-latest-workflow-status.mjs +8 -0
  129. package/lib/github-workflows/utils.cjs +271 -0
  130. package/lib/github-workflows/utils.d.cts +76 -0
  131. package/lib/github-workflows/utils.mjs +8 -0
  132. package/lib/github-workflows/workflow-badge-cli.cjs +722 -0
  133. package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
  134. package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
  135. package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
  136. package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
  137. package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
  138. package/lib/github-workflows/workflow-test-data.cjs +73 -0
  139. package/lib/github-workflows/workflow-test-data.d.cts +63 -0
  140. package/lib/github-workflows/workflow-test-data.mjs +6 -0
  141. package/lib/opencode/cli/auth-rotate.cjs +143 -0
  142. package/lib/opencode/cli/auth-rotate.d.ts +1 -0
  143. package/lib/opencode/cli/auth-rotate.js +70 -0
  144. package/lib/opencode/cli/auth-rotate.mjs +10 -0
  145. package/lib/opencode/cli/list-projects.cjs +184 -0
  146. package/lib/opencode/cli/list-projects.d.ts +1 -0
  147. package/lib/opencode/cli/list-projects.js +32 -0
  148. package/lib/opencode/cli/list-projects.mjs +11 -0
  149. package/lib/opencode/cli/list-sessions.cjs +215 -0
  150. package/lib/opencode/cli/list-sessions.d.ts +1 -0
  151. package/lib/opencode/cli/list-sessions.js +45 -0
  152. package/lib/opencode/cli/list-sessions.mjs +11 -0
  153. package/lib/opencode/database.cjs +349 -0
  154. package/lib/opencode/database.d.ts +91 -0
  155. package/lib/opencode/database.js +252 -0
  156. package/lib/opencode/database.mjs +28 -0
  157. package/lib/opencode/database.runner.cjs +145 -0
  158. package/lib/opencode/database.runner.d.ts +1 -0
  159. package/lib/opencode/database.runner.js +56 -0
  160. package/lib/opencode/database.runner.mjs +37 -0
  161. package/lib/opencode/opencode-zen.runner.cjs +48 -0
  162. package/lib/opencode/opencode-zen.runner.d.mts +1 -0
  163. package/lib/opencode/opencode-zen.runner.mjs +31 -0
  164. package/lib/opencode/sqlite.cjs +114 -0
  165. package/lib/opencode/sqlite.d.ts +18 -0
  166. package/lib/opencode/sqlite.js +82 -0
  167. package/lib/opencode/sqlite.mjs +10 -0
  168. package/lib/opencode/storage.cjs +124 -0
  169. package/lib/opencode/storage.d.ts +27 -0
  170. package/lib/opencode/storage.js +101 -0
  171. package/lib/opencode/storage.mjs +38 -0
  172. package/lib/opencode/storage.runner.cjs +50 -0
  173. package/lib/opencode/storage.runner.d.ts +1 -0
  174. package/lib/opencode/storage.runner.js +13 -0
  175. package/lib/opencode/storage.runner.mjs +29 -0
  176. package/lib/opencode/types.cjs +17 -0
  177. package/lib/opencode/types.d.ts +31 -0
  178. package/lib/opencode/types.js +2 -0
  179. package/lib/opencode/types.mjs +7 -0
  180. package/lib/opencode/utils/check-api.cjs +59 -0
  181. package/lib/opencode/utils/check-api.d.ts +12 -0
  182. package/lib/opencode/utils/check-api.js +46 -0
  183. package/lib/opencode/utils/check-api.mjs +8 -0
  184. package/lib/opencode-cli.cjs +473 -0
  185. package/lib/opencode-cli.d.ts +2 -0
  186. package/lib/opencode-cli.js +115 -0
  187. package/lib/opencode-cli.mjs +111 -0
  188. package/lib/package-resolutions-updater-cli.cjs +181 -154
  189. package/lib/package-resolutions-updater-cli.mjs +3 -2
  190. package/lib/package-resolutions-updater.cjs +181 -154
  191. package/lib/package-resolutions-updater.d.mts +12 -3
  192. package/lib/package-resolutions-updater.mjs +3 -2
  193. package/lib/print-directory-tree.cjs +131 -3
  194. package/lib/print-directory-tree.mjs +6 -3
  195. package/lib/rmpath-cli.cjs +131 -5
  196. package/lib/rmpath-cli.mjs +3 -1
  197. package/lib/rmpath.cjs +147 -11
  198. package/lib/rmpath.mjs +3 -1
  199. package/lib/run-by-checksum/hash.cjs +18 -2
  200. package/lib/run-by-checksum/hash.d.ts +4 -1
  201. package/lib/run-by-checksum/hash.js +38 -4
  202. package/lib/run-by-checksum/hash.mjs +1 -1
  203. package/lib/run-by-checksum/run.cjs +18 -2
  204. package/lib/run-by-checksum/run.mjs +2 -2
  205. package/lib/run-by-checksum-cli.cjs +18 -2
  206. package/lib/run-by-checksum-cli.mjs +2 -2
  207. package/lib/submodule-install.cjs +130 -4
  208. package/lib/submodule-install.mjs +5 -4
  209. package/lib/submodule-remove-cli.cjs +131 -5
  210. package/lib/submodule-remove-cli.mjs +3 -1
  211. package/lib/submodule-remove.cjs +146 -5
  212. package/lib/submodule-remove.mjs +3 -1
  213. package/lib/utils/findEnvFiles.cjs +3 -0
  214. package/lib/utils/findEnvFiles.d.cts +2 -2
  215. package/lib/utils/findEnvFiles.mjs +1 -1
  216. package/lib/vscode/project.cjs +0 -0
  217. package/lib/vscode/project.d.ts +0 -0
  218. package/lib/vscode/project.js +1 -0
  219. package/lib/vscode/project.mjs +7 -0
  220. package/lib/vscode/storage.cjs +138 -0
  221. package/lib/vscode/storage.d.ts +51 -0
  222. package/lib/vscode/storage.js +169 -0
  223. package/lib/vscode/storage.mjs +42 -0
  224. package/lib/vscode/storage.runner.cjs +125 -0
  225. package/lib/vscode/storage.runner.d.ts +1 -0
  226. package/lib/vscode/storage.runner.js +47 -0
  227. package/lib/vscode/storage.runner.mjs +60 -0
  228. package/lib/vscode-cli.cjs +155 -0
  229. package/lib/vscode-cli.d.ts +2 -0
  230. package/lib/vscode-cli.js +80 -0
  231. package/lib/vscode-cli.mjs +71 -0
  232. package/package.json +43 -21
  233. package/readme.md +41 -8
  234. package/releases/readme.md +1 -1
  235. package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
  236. package/vendor/clue/ndjson-react/README.md +365 -0
  237. package/vendor/composer/pcre/README.md +189 -0
  238. package/vendor/composer/semver/README.md +99 -0
  239. package/vendor/composer/xdebug-handler/README.md +305 -0
  240. package/vendor/ergebnis/agent-detector/README.md +107 -0
  241. package/vendor/evenement/evenement/README.md +64 -0
  242. package/vendor/fidry/cpu-core-counter/README.md +138 -0
  243. package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
  244. package/vendor/psr/container/README.md +13 -0
  245. package/vendor/psr/event-dispatcher/README.md +6 -0
  246. package/vendor/psr/log/README.md +58 -0
  247. package/vendor/react/cache/README.md +367 -0
  248. package/vendor/react/child-process/README.md +619 -0
  249. package/vendor/react/dns/README.md +453 -0
  250. package/vendor/react/event-loop/README.md +930 -0
  251. package/vendor/react/promise/README.md +722 -0
  252. package/vendor/react/socket/README.md +1564 -0
  253. package/vendor/react/stream/README.md +1249 -0
  254. package/vendor/sebastian/diff/README.md +151 -0
  255. package/vendor/symfony/console/README.md +30 -0
  256. package/vendor/symfony/deprecation-contracts/README.md +26 -0
  257. package/vendor/symfony/event-dispatcher/README.md +25 -0
  258. package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
  259. package/vendor/symfony/filesystem/README.md +23 -0
  260. package/vendor/symfony/finder/README.md +24 -0
  261. package/vendor/symfony/options-resolver/README.md +25 -0
  262. package/vendor/symfony/polyfill-ctype/README.md +12 -0
  263. package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
  264. package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
  265. package/vendor/symfony/polyfill-mbstring/README.md +13 -0
  266. package/vendor/symfony/polyfill-php80/README.md +25 -0
  267. package/vendor/symfony/polyfill-php81/README.md +18 -0
  268. package/vendor/symfony/polyfill-php84/README.md +23 -0
  269. package/vendor/symfony/polyfill-php85/README.md +20 -0
  270. package/vendor/symfony/process/README.md +23 -0
  271. package/vendor/symfony/service-contracts/README.md +9 -0
  272. package/vendor/symfony/stopwatch/README.md +52 -0
  273. package/vendor/symfony/string/README.md +24 -0
  274. package/lib/del-gradle.js +0 -16
  275. package/lib/del-node-modules.js +0 -211
  276. package/lib/find-node-modules-cli.js +0 -4
  277. /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
  278. /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
  279. /package/lib/{find-node-modules-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
  280. /package/lib/{git-diff-cli.d.ts → git/git-diff-cli.d.ts} +0 -0
  281. /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
  282. /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
  283. /package/lib/{git-fix.d.cts → git/git-fix.d.cts} +0 -0
  284. /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
  285. /package/lib/{del-node-modules.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
  286. /package/lib/{clean-github-actions-caches.d.cts → github-workflows/clean-github-actions-caches.d.cts} +0 -0
@@ -0,0 +1,184 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_config
4
+ } from "./chunk-SWUAEY4H.mjs";
5
+ import {
6
+ require_utils
7
+ } from "./chunk-6RK5UCTP.mjs";
8
+ import {
9
+ __commonJS,
10
+ __require,
11
+ init_esm_shims
12
+ } from "./chunk-QQ4A6DLD.mjs";
13
+
14
+ // src/github-workflows/clean-github-actions-caches.cjs
15
+ var require_clean_github_actions_caches = __commonJS({
16
+ "src/github-workflows/clean-github-actions-caches.cjs"(exports, module) {
17
+ init_esm_shims();
18
+ var axios = __require("axios");
19
+ var { getArgs } = require_utils();
20
+ var { GITHUB_ACCESS_TOKEN: ACCESS_TOKEN } = require_config();
21
+ if (!ACCESS_TOKEN) {
22
+ throw new Error(
23
+ "Access token is not provided. Please set ACCESS_TOKEN or GITHUB_TOKEN in your environment variables."
24
+ );
25
+ }
26
+ function printHelp() {
27
+ console.log(`
28
+ GitHub Actions Cache Cleaner
29
+
30
+ Description:
31
+ Removes outdated GitHub Actions caches for a repository, keeping only the newest
32
+ cache for each cache-key prefix. Authenticates via ACCESS_TOKEN or GITHUB_TOKEN
33
+ from your environment or .env file.
34
+
35
+ Usage:
36
+ clean-github-actions-caches [options]
37
+
38
+ Options:
39
+ -h, --help Show this help message
40
+ -r, --repo <repo> GitHub repository (owner/repo). If omitted, the tool will
41
+ attempt to infer the repository from the current working
42
+ directory's git remotes.
43
+ -p, --prefix-depth <n>
44
+ Number of leading cache key segments to use as the
45
+ grouping prefix when splitting on /[-_]/. Default: 3.
46
+
47
+ Environment Variables:
48
+ ACCESS_TOKEN GitHub access token (preferred)
49
+ GITHUB_TOKEN GitHub access token (fallback)
50
+
51
+ Behavior & Safety:
52
+ - Groups caches by a derived prefix from the cache key and keeps the most
53
+ recently created cache for each group.
54
+ - Deletes only caches older than the latest per prefix to reduce risk of
55
+ removing needed artifacts.
56
+
57
+ Examples:
58
+ # Run against a specific repo (owner/repo)
59
+ clean-github-actions-caches --repo octocat/hello-world
60
+
61
+ # Run via npx without installing
62
+ npx --legacy-peer-deps -y binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --repo owner/repo --prefix-depth 3
63
+
64
+ # Run via yarn dlx
65
+ yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --prefix-depth 3
66
+
67
+ Notes:
68
+ - Ensure ACCESS_TOKEN or GITHUB_TOKEN is set and has permissions to manage Actions caches.
69
+ - Intended for repository maintainers with appropriate permissions.
70
+ `);
71
+ }
72
+ var argv = getArgs({
73
+ alias: {
74
+ h: "help",
75
+ p: "prefix-depth",
76
+ r: "repo"
77
+ },
78
+ string: ["prefix-depth", "repo"],
79
+ boolean: ["help"]
80
+ });
81
+ if (argv.help) {
82
+ printHelp();
83
+ process.exit(0);
84
+ }
85
+ function deleteGitHubActionsCache(GH_REPO, cacheId) {
86
+ return new Promise((resolve, reject) => {
87
+ const url = `https://api.github.com/repos/${GH_REPO}/actions/caches/${cacheId}`;
88
+ const token = ACCESS_TOKEN;
89
+ if (!token) {
90
+ return reject(new Error("Access token is not provided"));
91
+ }
92
+ axios.delete(url, {
93
+ headers: {
94
+ Authorization: `token ${token}`,
95
+ Accept: "application/vnd.github.v3+json"
96
+ }
97
+ }).then((response) => {
98
+ console.log(`Cache (${cacheId}) deleted successfully`, response.data);
99
+ resolve(response.data);
100
+ }).catch((error) => {
101
+ var _a;
102
+ console.error("Error deleting cache:", ((_a = error.response) == null ? void 0 : _a.data) || error.message || "Unknown error");
103
+ reject(error);
104
+ });
105
+ });
106
+ }
107
+ function normalizePrefixDepth(prefixDepth) {
108
+ const parsed = Number(prefixDepth);
109
+ if (!Number.isFinite(parsed) || parsed < 1) {
110
+ return 3;
111
+ }
112
+ return Math.floor(parsed);
113
+ }
114
+ function isChecksumSegment(segment) {
115
+ return /^[a-f0-9]{32,}$/i.test(segment);
116
+ }
117
+ function getMeaningfulCacheKeyParts(key) {
118
+ return String(key).split(/[-_]/).filter(Boolean).filter((segment) => !isChecksumSegment(segment));
119
+ }
120
+ function getCachePrefix(key, prefixDepth = 3) {
121
+ const normalizedDepth = normalizePrefixDepth(prefixDepth);
122
+ const parts = String(key).split(/[-_]/).filter(Boolean);
123
+ const meaningfulParts = getMeaningfulCacheKeyParts(key);
124
+ if (meaningfulParts.length !== parts.length) {
125
+ if (meaningfulParts.length < normalizedDepth) {
126
+ return `${meaningfulParts.join("-")}-`;
127
+ }
128
+ return meaningfulParts.join("-");
129
+ }
130
+ if (parts.length <= normalizedDepth) {
131
+ return parts.join("-");
132
+ }
133
+ return parts.slice(0, normalizedDepth).join("-");
134
+ }
135
+ function groupCachesByPrefix(caches, prefixDepth = 3) {
136
+ return caches.reduce(
137
+ /**
138
+ * @param {Record<string, Record<string, any>[]>} acc
139
+ * @param {Record<string, any>} item
140
+ * @returns {Record<string, Record<string, any>[]>}
141
+ */
142
+ (acc, item) => {
143
+ const prefix = getCachePrefix(item.key, prefixDepth);
144
+ if (!acc[prefix]) {
145
+ acc[prefix] = [];
146
+ }
147
+ acc[prefix].push(item);
148
+ return acc;
149
+ },
150
+ {}
151
+ );
152
+ }
153
+ function get_caches(GH_REPO, prefixDepth = 3) {
154
+ const url = `https://api.github.com/repos/${GH_REPO}/actions/caches`;
155
+ return new Promise((resolve, reject) => {
156
+ axios.get(url, {
157
+ headers: {
158
+ Accept: "application/vnd.github.v3+json",
159
+ Authorization: `token ${ACCESS_TOKEN}`
160
+ }
161
+ }).then((response) => {
162
+ const data = response.data.actions_caches;
163
+ const grouped = groupCachesByPrefix(data, prefixDepth);
164
+ resolve(grouped);
165
+ }).catch((error) => {
166
+ reject(error);
167
+ });
168
+ });
169
+ }
170
+ module.exports = {
171
+ deleteGitHubActionsCache,
172
+ getCachePrefix,
173
+ getMeaningfulCacheKeyParts,
174
+ get_caches,
175
+ groupCachesByPrefix,
176
+ isChecksumSegment,
177
+ normalizePrefixDepth
178
+ };
179
+ }
180
+ });
181
+
182
+ export {
183
+ require_clean_github_actions_caches
184
+ };
@@ -0,0 +1,62 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_config
4
+ } from "./chunk-SARIXFHP.mjs";
5
+ import {
6
+ __commonJS,
7
+ __require,
8
+ init_esm_shims
9
+ } from "./chunk-QQ4A6DLD.mjs";
10
+
11
+ // src/submodule-remove.cjs
12
+ var require_submodule_remove = __commonJS({
13
+ "src/submodule-remove.cjs"(exports, module) {
14
+ init_esm_shims();
15
+ var { spawnAsync } = __require("cross-spawn");
16
+ var path = __require("upath");
17
+ var fs = __require("fs-extra");
18
+ var { loadDotenv } = require_config();
19
+ loadDotenv();
20
+ async function removeSubmodule(submodulePath) {
21
+ try {
22
+ await spawnAsync("git", ["submodule", "deinit", "-f", submodulePath], { stdio: "inherit" });
23
+ } catch (error) {
24
+ console.warn(`Warning: Could not deinitialize submodule "${submodulePath}". It may not exist.`);
25
+ console.warn(error.message);
26
+ }
27
+ try {
28
+ await spawnAsync("git", ["config", "--remove-section", `submodule.${submodulePath}`], { stdio: "inherit" });
29
+ } catch (error) {
30
+ console.warn(`Warning: Could not remove git config section for submodule "${submodulePath}". It may not exist.`);
31
+ console.warn(error.message);
32
+ }
33
+ const gitModulesPath = path.resolve(".git", "modules", submodulePath);
34
+ if (fs.existsSync(gitModulesPath)) {
35
+ fs.rmSync(gitModulesPath, { recursive: true, force: true });
36
+ console.log(`Removed .git/modules entry for submodule "${submodulePath}".`);
37
+ } else {
38
+ console.warn(`Warning: The path "${gitModulesPath}" does not exist. Skipping removal of .git/modules entry.`);
39
+ }
40
+ const gitmodulesPath = path.resolve(".gitmodules");
41
+ if (fs.existsSync(gitmodulesPath)) {
42
+ let gitmodulesContent = fs.readFileSync(gitmodulesPath, "utf-8");
43
+ const submoduleSectionRegex = new RegExp(
44
+ `\\[submodule "${submodulePath.replace(/[-/\\^$*+?.()|[\]{}]/g, "\\$&")}"]([\\s\\S]*?)(?=\\[|$)`,
45
+ "g"
46
+ );
47
+ gitmodulesContent = gitmodulesContent.replace(submoduleSectionRegex, "").trim();
48
+ fs.writeFileSync(gitmodulesPath, gitmodulesContent);
49
+ console.log(`Removed submodule "${submodulePath}" from .gitmodules.`);
50
+ } else {
51
+ console.warn(`Warning: The .gitmodules file does not exist. Skipping removal of submodule "${submodulePath}".`);
52
+ }
53
+ fs.rmSync(path.resolve(submodulePath), { recursive: true, force: true });
54
+ console.log(`Submodule "${submodulePath}" has been removed.`);
55
+ }
56
+ module.exports = removeSubmodule;
57
+ }
58
+ });
59
+
60
+ export {
61
+ require_submodule_remove
62
+ };
@@ -0,0 +1,146 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_config
4
+ } from "./chunk-SARIXFHP.mjs";
5
+ import {
6
+ __commonJS,
7
+ __require,
8
+ init_esm_shims
9
+ } from "./chunk-QQ4A6DLD.mjs";
10
+
11
+ // src/github-workflows/utils.cjs
12
+ var require_utils = __commonJS({
13
+ "src/github-workflows/utils.cjs"(exports, module) {
14
+ init_esm_shims();
15
+ var axios = __require("axios");
16
+ var { spawn } = __require("cross-spawn");
17
+ var { GITHUB_ACCESS_TOKEN: TOKEN } = require_config();
18
+ if (!TOKEN) {
19
+ console.error("Missing env var: ACCESS_TOKEN or GITHUB_TOKEN");
20
+ process.exit(1);
21
+ }
22
+ var BASE = "https://api.github.com";
23
+ var HEADERS = {
24
+ Authorization: `Bearer ${TOKEN}`,
25
+ Accept: "application/vnd.github+json",
26
+ "X-GitHub-Api-Version": "2022-11-28"
27
+ };
28
+ async function request(url) {
29
+ try {
30
+ const res = await axios.get(url, { headers: HEADERS });
31
+ return res.data;
32
+ } catch (err) {
33
+ if (err == null ? void 0 : err.response) {
34
+ const statusText = err.response.statusText || "Request failed";
35
+ const responseText = typeof err.response.data === "string" ? err.response.data : JSON.stringify(err.response.data);
36
+ throw new Error(`${err.response.status} ${statusText}
37
+ ${responseText}`);
38
+ }
39
+ throw err;
40
+ }
41
+ }
42
+ function runGit(args) {
43
+ return new Promise((resolve, reject) => {
44
+ var _a, _b;
45
+ const child = spawn("git", args, {
46
+ cwd: process.cwd(),
47
+ stdio: ["ignore", "pipe", "pipe"]
48
+ });
49
+ let stdout = "";
50
+ let stderr = "";
51
+ (_a = child.stdout) == null ? void 0 : _a.on("data", (chunk) => {
52
+ stdout += chunk.toString();
53
+ });
54
+ (_b = child.stderr) == null ? void 0 : _b.on("data", (chunk) => {
55
+ stderr += chunk.toString();
56
+ });
57
+ child.on("error", reject);
58
+ child.on("close", (code) => {
59
+ if (code === 0) return resolve(stdout.trim());
60
+ reject(new Error(stderr.trim() || `git ${args.join(" ")} exited with code ${code}`));
61
+ });
62
+ });
63
+ }
64
+ function parseOwnerFromUrl(remoteUrl) {
65
+ const normalized = remoteUrl.trim().replace(/\.git$/i, "");
66
+ const match = normalized.match(/github\.com[:/](?<owner>[^/]+)\/(?<repo>[^/]+)$/i);
67
+ return (match == null ? void 0 : match.groups) || null;
68
+ }
69
+ function getOwnerFromRemoteUrl(remoteUrl) {
70
+ const parsed = parseOwnerFromUrl(remoteUrl);
71
+ return (parsed == null ? void 0 : parsed.owner) || null;
72
+ }
73
+ function getRepoFromRemoteUrl(remoteUrl) {
74
+ const parsed = parseOwnerFromUrl(remoteUrl);
75
+ return (parsed == null ? void 0 : parsed.repo) || null;
76
+ }
77
+ async function getCurrentOwner() {
78
+ const commands = [
79
+ ["config", "--local", "--get", "remote.origin.url"],
80
+ ["remote", "get-url", "origin"]
81
+ ];
82
+ for (const args of commands) {
83
+ try {
84
+ const remoteUrl = await runGit(args);
85
+ const owner = getOwnerFromRemoteUrl(remoteUrl);
86
+ if (owner) return owner;
87
+ } catch {
88
+ }
89
+ }
90
+ throw new Error("Unable to determine repository owner from git remote.origin.url");
91
+ }
92
+ async function getCurrentRepo() {
93
+ const commands = [
94
+ ["config", "--local", "--get", "remote.origin.url"],
95
+ ["remote", "get-url", "origin"]
96
+ ];
97
+ for (const args of commands) {
98
+ try {
99
+ const remoteUrl = await runGit(args);
100
+ const repo = getRepoFromRemoteUrl(remoteUrl);
101
+ if (repo) return repo;
102
+ } catch {
103
+ }
104
+ }
105
+ throw new Error("Unable to determine repository name from git remote.origin.url");
106
+ }
107
+ async function getOwnerRepo() {
108
+ const owner = await getCurrentOwner();
109
+ const repo = await getCurrentRepo();
110
+ return { owner, repo };
111
+ }
112
+ async function getLatestRun(owner, repo, workflowId) {
113
+ var _a;
114
+ let url;
115
+ if (workflowId) {
116
+ url = `${BASE}/repos/${owner}/${repo}/actions/workflows/${encodeURIComponent(workflowId)}/runs?per_page=1`;
117
+ } else {
118
+ url = `${BASE}/repos/${owner}/${repo}/actions/runs?per_page=1`;
119
+ }
120
+ const data = await request(url);
121
+ return (_a = data.workflow_runs) == null ? void 0 : _a[0];
122
+ }
123
+ async function getJobs(owner, repo, runId) {
124
+ const data = await request(`${BASE}/repos/${owner}/${repo}/actions/runs/${runId}/jobs`);
125
+ return data.jobs || [];
126
+ }
127
+ module.exports = {
128
+ BASE,
129
+ HEADERS,
130
+ request,
131
+ runGit,
132
+ parseOwnerFromUrl,
133
+ getOwnerFromRemoteUrl,
134
+ getRepoFromRemoteUrl,
135
+ getCurrentOwner,
136
+ getCurrentRepo,
137
+ getOwnerRepo,
138
+ getLatestRun,
139
+ getJobs
140
+ };
141
+ }
142
+ });
143
+
144
+ export {
145
+ require_utils
146
+ };
@@ -1,4 +1,7 @@
1
1
  import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ require_config
4
+ } from "./chunk-PAZH45HS.mjs";
2
5
  import {
3
6
  require_findEnvFiles
4
7
  } from "./chunk-H44UWUFY.mjs";
@@ -11,19 +14,19 @@ import {
11
14
  init_esm_shims
12
15
  } from "./chunk-QQ4A6DLD.mjs";
13
16
 
14
- // src/clean-github-actions-caches.cjs
17
+ // src/github-workflows/clean-github-actions-caches.cjs
15
18
  var require_clean_github_actions_caches = __commonJS({
16
- "src/clean-github-actions-caches.cjs"(exports, module) {
19
+ "src/github-workflows/clean-github-actions-caches.cjs"(exports, module) {
17
20
  init_esm_shims();
18
21
  var axios = __require("axios");
19
22
  var { getArgs } = require_utils();
23
+ var { GITHUB_ACCESS_TOKEN: ACCESS_TOKEN } = require_config();
20
24
  var { findEnvWithToken } = require_findEnvFiles();
21
25
  __require("dotenv").config({
22
26
  path: findEnvWithToken(),
23
27
  quiet: true,
24
28
  overwrite: true
25
29
  });
26
- var ACCESS_TOKEN = process.env.ACCESS_TOKEN || process.env.GITHUB_TOKEN;
27
30
  if (!ACCESS_TOKEN) {
28
31
  throw new Error(
29
32
  "Access token is not provided. Please set ACCESS_TOKEN or GITHUB_TOKEN in your environment variables."
@@ -0,0 +1,225 @@
1
+ import { createRequire } from 'module'; const require = createRequire(import.meta.url);
2
+ import {
3
+ SQLite
4
+ } from "./chunk-56BVU63B.mjs";
5
+ import {
6
+ DATABASE_PATH
7
+ } from "./chunk-XW5NZAKI.mjs";
8
+ import {
9
+ init_esm_shims
10
+ } from "./chunk-QQ4A6DLD.mjs";
11
+
12
+ // src/opencode/database.ts
13
+ init_esm_shims();
14
+ import fs from "fs-extra";
15
+ import { execSync } from "child_process";
16
+ async function checkDatabase() {
17
+ if (!fs.existsSync(DATABASE_PATH)) {
18
+ console.error("No OpenCode database found. Run opencode (v1.2.0+) at least once to create the database.");
19
+ return false;
20
+ }
21
+ try {
22
+ const db = new SQLite(DATABASE_PATH);
23
+ try {
24
+ const rows = db.all("SELECT name FROM sqlite_master WHERE type='table' AND name='session'");
25
+ if (rows.length === 0) {
26
+ console.error(
27
+ "OpenCode database exists but is missing expected tables. Try running opencode to complete the migration."
28
+ );
29
+ return false;
30
+ }
31
+ return true;
32
+ } finally {
33
+ db.close();
34
+ }
35
+ } catch (error) {
36
+ if (error instanceof Error) {
37
+ console.error(`Could not open OpenCode database: ${error.message}`);
38
+ } else {
39
+ console.error("Could not open OpenCode database.");
40
+ }
41
+ return false;
42
+ }
43
+ }
44
+ function toProject(row) {
45
+ let sandboxes = [];
46
+ try {
47
+ sandboxes = JSON.parse(row.sandboxes);
48
+ } catch {
49
+ }
50
+ return {
51
+ id: row.id,
52
+ worktree: row.worktree,
53
+ vcs: row.vcs,
54
+ name: row.name,
55
+ sandboxes,
56
+ time: {
57
+ created: row.time_created,
58
+ updated: row.time_updated
59
+ }
60
+ };
61
+ }
62
+ function toSession(row) {
63
+ const session = {
64
+ id: row.id,
65
+ slug: row.slug,
66
+ version: row.version,
67
+ projectID: row.project_id,
68
+ directory: row.directory,
69
+ parentID: row.parent_id ?? void 0,
70
+ title: row.title,
71
+ time: {
72
+ created: row.time_created,
73
+ updated: row.time_updated,
74
+ compacting: row.time_compacting ?? void 0,
75
+ archived: row.time_archived ?? void 0
76
+ }
77
+ };
78
+ if (row.summary_files != null) {
79
+ session.summary = {
80
+ additions: row.summary_additions ?? 0,
81
+ deletions: row.summary_deletions ?? 0,
82
+ files: row.summary_files
83
+ };
84
+ }
85
+ if (row.share_url) {
86
+ session.share = { url: row.share_url };
87
+ }
88
+ return session;
89
+ }
90
+ function toMessage(id, sessionID, dataJson) {
91
+ const data = JSON.parse(dataJson);
92
+ return {
93
+ id,
94
+ sessionID,
95
+ role: data.role,
96
+ time: data.time,
97
+ parentID: data.parentID,
98
+ modelID: data.modelID,
99
+ providerID: data.providerID,
100
+ agent: data.agent,
101
+ mode: data.mode,
102
+ cost: data.cost,
103
+ tokens: data.tokens,
104
+ finish: data.finish
105
+ };
106
+ }
107
+ function toPart(id, messageID, sessionID, dataJson) {
108
+ const data = JSON.parse(dataJson);
109
+ return {
110
+ id,
111
+ messageID,
112
+ sessionID,
113
+ type: data.type,
114
+ text: data.text,
115
+ tool: data.tool,
116
+ state: data.state
117
+ };
118
+ }
119
+ async function loadProjects() {
120
+ const rows = query("SELECT id, worktree, vcs, name, time_created, time_updated, sandboxes FROM project");
121
+ return rows.map(toProject);
122
+ }
123
+ async function loadSessions() {
124
+ const rows = query(
125
+ `SELECT id, project_id, parent_id, slug, directory, title, version,
126
+ share_url, summary_additions, summary_deletions, summary_files,
127
+ time_created, time_updated, time_compacting, time_archived
128
+ FROM session
129
+ WHERE parent_id IS NULL
130
+ ORDER BY time_updated DESC`
131
+ );
132
+ return rows.map(toSession);
133
+ }
134
+ async function loadMessages(sessionID) {
135
+ const rows = query(
136
+ `SELECT id, session_id, data FROM message WHERE session_id = '${escapeSql(sessionID)}' ORDER BY id ASC`
137
+ );
138
+ return rows.map((row) => toMessage(row.id, row.session_id, row.data));
139
+ }
140
+ async function loadParts(messageID) {
141
+ const rows = query(
142
+ `SELECT id, message_id, session_id, data FROM part WHERE message_id = '${escapeSql(messageID)}' ORDER BY id ASC`
143
+ );
144
+ return rows.map((row) => toPart(row.id, row.message_id, row.session_id, row.data));
145
+ }
146
+ async function loadTranscript(sessionID) {
147
+ const sid = escapeSql(sessionID);
148
+ const rows = query(
149
+ `SELECT m.id AS message_id, m.data AS message_data,
150
+ p.id AS part_id, p.message_id AS part_message_id,
151
+ p.session_id AS part_session_id, p.data AS part_data
152
+ FROM message m
153
+ LEFT JOIN part p ON p.message_id = m.id
154
+ WHERE m.session_id = '${sid}'
155
+ ORDER BY m.id ASC, p.id ASC`
156
+ );
157
+ const entriesMap = /* @__PURE__ */ new Map();
158
+ for (const row of rows) {
159
+ let entry = entriesMap.get(row.message_id);
160
+ if (!entry) {
161
+ entry = {
162
+ message: toMessage(row.message_id, sessionID, row.message_data),
163
+ parts: []
164
+ };
165
+ entriesMap.set(row.message_id, entry);
166
+ }
167
+ if (row.part_id && row.part_data && row.part_message_id && row.part_session_id) {
168
+ const part = toPart(row.part_id, row.part_message_id, row.part_session_id, row.part_data);
169
+ if (part.type === "text" && part.text || part.type === "tool") {
170
+ entry.parts.push(part);
171
+ }
172
+ }
173
+ }
174
+ return Array.from(entriesMap.values()).filter((entry) => entry.parts.length > 0);
175
+ }
176
+ function runSql(query2) {
177
+ const dbPath = DATABASE_PATH;
178
+ execSync(`sqlite3 "${dbPath}"`, {
179
+ input: query2,
180
+ timeout: 1e4
181
+ });
182
+ }
183
+ async function deleteSession(session) {
184
+ const sid = escapeSql(session.id);
185
+ runSql(
186
+ `WITH RECURSIVE descendants(id) AS (SELECT id FROM session WHERE id = '${sid}' UNION ALL SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id) DELETE FROM session WHERE id IN (SELECT id FROM descendants);`
187
+ );
188
+ }
189
+ async function deleteSessionById(id) {
190
+ const sid = escapeSql(id);
191
+ runSql(
192
+ `WITH RECURSIVE descendants(id) AS (SELECT id FROM session WHERE id = '${sid}' UNION ALL SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id) DELETE FROM session WHERE id IN (SELECT id FROM descendants);`
193
+ );
194
+ }
195
+ async function deleteAllSessions() {
196
+ runSql(`DELETE FROM part; DELETE FROM message; DELETE FROM session;`);
197
+ }
198
+ async function deleteAllProjectSessions(projectID) {
199
+ const pid = escapeSql(projectID);
200
+ runSql(`DELETE FROM session WHERE project_id = '${pid}'; DELETE FROM project WHERE id = '${pid}';`);
201
+ }
202
+ function query(sql) {
203
+ const db = new SQLite(DATABASE_PATH);
204
+ try {
205
+ return db.all(sql);
206
+ } finally {
207
+ db.close();
208
+ }
209
+ }
210
+ function escapeSql(value) {
211
+ return value.replace(/'/g, "''");
212
+ }
213
+
214
+ export {
215
+ checkDatabase,
216
+ loadProjects,
217
+ loadSessions,
218
+ loadMessages,
219
+ loadParts,
220
+ loadTranscript,
221
+ deleteSession,
222
+ deleteSessionById,
223
+ deleteAllSessions,
224
+ deleteAllProjectSessions
225
+ };