binary-collections 2.0.12 → 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.
- package/binaries/binary-executor.cjs +307 -162
- package/binaries/clean-nodemodule.cjs +307 -162
- package/binaries/clean-nodemodules.cjs +307 -162
- package/binaries/composer.cjs +323 -0
- package/binaries/composer.cmd +2 -0
- package/binaries/composer.phar +0 -0
- package/binaries/dev.cjs +307 -162
- package/binaries/empty.cjs +307 -162
- package/binaries/git-reduce-size.cjs +307 -162
- package/binaries/javakill.cjs +307 -162
- package/binaries/kill-process.cjs +307 -162
- package/binaries/nodekill.cjs +307 -162
- package/binaries/prod.cjs +307 -162
- package/binaries/py.cjs +307 -162
- package/binaries/rmfind.cjs +307 -162
- package/binaries/rmx.cjs +307 -162
- package/binaries/submodule-token.cjs +307 -162
- package/binaries/test-cjs.cjs +307 -162
- package/binaries/test-esm.cjs +307 -162
- package/binaries/yarn-clean.cjs +307 -162
- package/binaries/yc +22 -1
- package/binaries/yc.cjs +307 -162
- package/binaries/ycw +256 -0
- package/binaries/ycw.cjs +323 -0
- package/docs-src/binary-collections.md +34 -0
- package/docs-src/changelog.md +26 -0
- package/docs-src/clean-github-actions-caches.md +115 -0
- package/docs-src/copy-move-file.md +56 -0
- package/docs-src/del-gradle.md +17 -0
- package/docs-src/del-ps.md +28 -0
- package/docs-src/downloader.md +62 -0
- package/docs-src/env-helpers.md +29 -0
- package/docs-src/find-node-modules.md +17 -0
- package/docs-src/free-chatgpt.md +26 -0
- package/docs-src/generate-test-ci.md +56 -0
- package/docs-src/get-latest-workflow-status.md +100 -0
- package/docs-src/git-diff.md +33 -0
- package/docs-src/git-fix.md +34 -0
- package/docs-src/git-purge.md +17 -0
- package/docs-src/git-reduce-size.md +17 -0
- package/docs-src/git-undo.md +21 -0
- package/docs-src/kill-night-crows.md +26 -0
- package/docs-src/node-cache-cleaner.md +182 -0
- package/docs-src/node-executor.md +50 -0
- package/docs-src/node-package-packer.md +48 -0
- package/docs-src/npm-run-series.md +43 -0
- package/docs-src/opencode-cli.md +127 -0
- package/docs-src/package-resolutions-updater.md +22 -0
- package/docs-src/php-cs-fixer-staged.md +19 -0
- package/docs-src/print-directory-tree.md +35 -0
- package/docs-src/print-tarball-tree.md +55 -0
- package/docs-src/py.md +19 -0
- package/docs-src/remove-module.md +32 -0
- package/docs-src/rmfind-rmx.md +21 -0
- package/docs-src/rmpath.md +38 -0
- package/docs-src/run-by-checksum.md +87 -0
- package/docs-src/submodule-install.md +31 -0
- package/docs-src/submodule-remove.md +22 -0
- package/docs-src/submodule-token.md +17 -0
- package/docs-src/test-runners.md +21 -0
- package/docs-src/upload-backend.md +29 -0
- package/docs-src/vscode-cli.md +84 -0
- package/docs-src/workflow-badge.md +120 -0
- package/docs-src/yarn-install.md +31 -0
- package/docs-src/yarn-reinstall.md +27 -0
- package/lib/binary-collections/config.cjs +15 -3
- package/lib/binary-collections/config.d.cts +10 -0
- package/lib/binary-collections/config.mjs +2 -2
- package/lib/binary-collections/findScript.cjs +75 -28
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +75 -28
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +85 -43
- package/lib/binary-collections.mjs +8 -8
- package/lib/changelog.cjs +7 -12
- package/lib/changelog.mjs +2 -2
- package/lib/chunk-2SJKVOTN.mjs +146 -0
- package/lib/{chunk-SPTECFE5.mjs → chunk-3F6EIHYG.mjs} +87 -21
- package/lib/chunk-546KAIYT.mjs +113 -0
- package/lib/chunk-56BVU63B.mjs +86 -0
- package/lib/chunk-5WAOOOGZ.mjs +77 -0
- package/lib/{chunk-V2IBPCEV.mjs → chunk-6C7KTYGZ.mjs} +3 -1
- package/lib/{chunk-5RTXZVCW.mjs → chunk-6RK5UCTP.mjs} +5 -10
- package/lib/chunk-72XTQ3CK.mjs +45 -0
- package/lib/chunk-7N52Z4IJ.mjs +39 -0
- package/lib/chunk-7Q6YEUQF.mjs +246 -0
- package/lib/{chunk-ZOWVMII3.mjs → chunk-AJ3OIYYP.mjs} +75 -28
- package/lib/chunk-AQZ7LMFS.mjs +100 -0
- package/lib/chunk-BDCMTOZI.mjs +246 -0
- package/lib/chunk-BEUM4LH4.mjs +184 -0
- package/lib/{chunk-66KDU4TX.mjs → chunk-BO4TZS4Q.mjs} +39 -61
- package/lib/chunk-CM3IC5YC.mjs +226 -0
- package/lib/{chunk-6PU7BAHB.mjs → chunk-D42YBRZW.mjs} +1 -1
- package/lib/chunk-FR3DMHJC.mjs +146 -0
- package/lib/chunk-I3O5ZRYU.mjs +77 -0
- package/lib/chunk-J4M5EL5P.mjs +108 -0
- package/lib/chunk-JK3MG2KF.mjs +236 -0
- package/lib/chunk-JMUFQSPE.mjs +184 -0
- package/lib/chunk-JVMLKHD2.mjs +62 -0
- package/lib/chunk-KAT2JNLZ.mjs +146 -0
- package/lib/chunk-KLKAIFKI.mjs +40 -0
- package/lib/{chunk-FB2WKVJD.mjs → chunk-KRCPFWIF.mjs} +72 -37
- package/lib/chunk-LACQTD5V.mjs +225 -0
- package/lib/chunk-LVSPEFU2.mjs +86 -0
- package/lib/chunk-MCCMMZSM.mjs +60 -0
- package/lib/{chunk-2LSRSEXF.mjs → chunk-MGPYPKIE.mjs} +2 -2
- package/lib/chunk-OA2RKEY3.mjs +162 -0
- package/lib/{chunk-C6D2TTYU.mjs → chunk-OBXLTXFJ.mjs} +4 -2
- package/lib/{chunk-G5UUEWUO.mjs → chunk-PAZH45HS.mjs} +8 -2
- package/lib/chunk-QD4T255Z.mjs +40 -0
- package/lib/{chunk-XPJGCDOD.mjs → chunk-QII2EKCS.mjs} +14 -2
- package/lib/chunk-QZMGBDSA.mjs +32 -0
- package/lib/chunk-RDGDLSPD.mjs +76 -0
- package/lib/chunk-RJKTSUAX.mjs +123 -0
- package/lib/chunk-RKPIBGKE.mjs +61 -0
- package/lib/chunk-SARIXFHP.mjs +44 -0
- package/lib/chunk-SJYP66BO.mjs +62 -0
- package/lib/chunk-SWUAEY4H.mjs +44 -0
- package/lib/chunk-TP3O2JGW.mjs +88 -0
- package/lib/chunk-UAIF5VIA.mjs +89 -0
- package/lib/chunk-UDZBVKXH.mjs +94 -0
- package/lib/chunk-UEOWRYAN.mjs +32 -0
- package/lib/chunk-UHPFLJXH.mjs +227 -0
- package/lib/{chunk-M3YIYRHT.mjs → chunk-UY5VUEA3.mjs} +1 -1
- package/lib/chunk-UYNBNLV5.mjs +113 -0
- package/lib/chunk-WOC4FZ6F.mjs +164 -0
- package/lib/chunk-WSHVPGNM.mjs +44 -0
- package/lib/chunk-X7UVQ6ZC.mjs +183 -0
- package/lib/{chunk-NCZPTKDV.mjs → chunk-XI67TI46.mjs} +1 -1
- package/lib/chunk-XW5NZAKI.mjs +82 -0
- package/lib/chunk-YLV4QATP.mjs +86 -0
- package/lib/chunk-YWSLMAQ7.mjs +65 -0
- package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
- package/lib/cross-env/command.cjs +2 -2
- package/lib/cross-env/command.js +2 -2
- package/lib/cross-env/command.mjs +2 -2
- package/lib/cross-env/index.cjs +2 -2
- package/lib/cross-env/index.mjs +5 -5
- package/lib/cross-env/variable.mjs +2 -2
- package/lib/del-gradle.cjs +7 -12
- package/lib/del-gradle.mjs +23 -17
- package/lib/del-node-modules.cjs +186 -4
- package/lib/del-node-modules.mjs +151 -142
- package/lib/{del-ps.cjs → del-ps-cli.cjs} +36 -41
- package/lib/del-ps-cli.mjs +44 -0
- package/lib/del-yarn-caches.cjs +6 -11
- package/lib/del-yarn-caches.mjs +1 -1
- package/lib/downloader-cli.cjs +256 -0
- package/lib/downloader-cli.mjs +90 -0
- package/lib/file/copy-cli.cjs +183 -2
- package/lib/file/copy-cli.mjs +6 -2
- package/lib/file/move-cli.cjs +183 -2
- package/lib/file/move-cli.mjs +6 -2
- package/lib/find-node-modules-cli.cjs +2 -2
- package/lib/find-node-modules-cli.mjs +11 -5
- package/lib/find-node-modules.cjs +1 -1
- package/lib/find-node-modules.mjs +1 -1
- package/lib/free-chatgpt.cjs +6 -11
- package/lib/free-chatgpt.mjs +1 -1
- package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +109 -36
- package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
- package/lib/{git-diff.cjs → git/git-diff.cjs} +107 -34
- package/lib/{git-diff.js → git/git-diff.js} +88 -31
- package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
- package/lib/{git-fix.cjs → git/git-fix.cjs} +140 -14
- package/lib/git/git-fix.d.cts +2 -0
- package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
- package/lib/{git-purge.cjs → git/git-purge.cjs} +8 -13
- package/lib/{git-purge.mjs → git/git-purge.mjs} +5 -5
- package/lib/git/user-config.cjs +137 -12
- package/lib/git/user-config.mjs +4 -2
- package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +292 -222
- package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +30 -11
- package/lib/github-workflows/clean-github-actions-caches.cjs +473 -0
- package/lib/github-workflows/clean-github-actions-caches.d.cts +53 -0
- package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -3
- package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
- package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
- package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.cjs +541 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
- package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
- package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
- package/lib/{ps/isWin.mjs → github-workflows/get-latest-workflow-status.mjs} +3 -5
- package/lib/github-workflows/utils.cjs +271 -0
- package/lib/github-workflows/utils.d.cts +76 -0
- package/lib/github-workflows/utils.mjs +8 -0
- package/lib/github-workflows/workflow-badge-cli.cjs +722 -0
- package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
- package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
- package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
- package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
- package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
- package/lib/github-workflows/workflow-test-data.cjs +73 -0
- package/lib/github-workflows/workflow-test-data.d.cts +63 -0
- package/lib/github-workflows/workflow-test-data.mjs +6 -0
- package/lib/index.cjs +1 -1
- package/lib/index.mjs +1 -1
- package/lib/node-cache-cleaner-cli.cjs +185 -2
- package/lib/node-cache-cleaner-cli.js +2 -5
- package/lib/node-cache-cleaner-cli.mjs +8 -4
- package/lib/node-executor.cjs +183 -2
- package/lib/node-executor.mjs +5 -2
- package/lib/node-package-packer/build-readme.cjs +150 -0
- package/lib/node-package-packer/build-readme.d.mts +10 -0
- package/lib/node-package-packer/build-readme.mjs +10 -0
- package/lib/node-package-packer/build-tarball.cjs +495 -0
- package/lib/node-package-packer/build-tarball.d.mts +33 -0
- package/lib/node-package-packer/build-tarball.mjs +175 -0
- package/lib/node-package-packer-cli.cjs +525 -0
- package/lib/node-package-packer-cli.d.mts +1 -0
- package/lib/node-package-packer-cli.mjs +34 -0
- package/lib/npm-run-series.cjs +7 -12
- package/lib/npm-run-series.mjs +2 -2
- package/lib/opencode/cli/auth-rotate.cjs +143 -0
- package/lib/opencode/cli/auth-rotate.d.ts +1 -0
- package/lib/opencode/cli/auth-rotate.js +70 -0
- package/lib/opencode/cli/auth-rotate.mjs +10 -0
- package/lib/opencode/cli/list-projects.cjs +184 -0
- package/lib/opencode/cli/list-projects.d.ts +1 -0
- package/lib/opencode/cli/list-projects.js +32 -0
- package/lib/opencode/cli/list-projects.mjs +11 -0
- package/lib/opencode/cli/list-sessions.cjs +215 -0
- package/lib/opencode/cli/list-sessions.d.ts +1 -0
- package/lib/opencode/cli/list-sessions.js +45 -0
- package/lib/opencode/cli/list-sessions.mjs +11 -0
- package/lib/opencode/database.cjs +349 -0
- package/lib/opencode/database.d.ts +91 -0
- package/lib/opencode/database.js +252 -0
- package/lib/opencode/database.mjs +28 -0
- package/lib/opencode/database.runner.cjs +145 -0
- package/lib/opencode/database.runner.d.ts +1 -0
- package/lib/opencode/database.runner.js +56 -0
- package/lib/opencode/database.runner.mjs +37 -0
- package/lib/opencode/opencode-zen.runner.cjs +48 -0
- package/lib/opencode/opencode-zen.runner.d.mts +1 -0
- package/lib/opencode/opencode-zen.runner.mjs +31 -0
- package/lib/opencode/sqlite.cjs +114 -0
- package/lib/opencode/sqlite.d.ts +18 -0
- package/lib/opencode/sqlite.js +82 -0
- package/lib/opencode/sqlite.mjs +10 -0
- package/lib/opencode/storage.cjs +124 -0
- package/lib/opencode/storage.d.ts +27 -0
- package/lib/opencode/storage.js +101 -0
- package/lib/opencode/storage.mjs +38 -0
- package/lib/opencode/storage.runner.cjs +50 -0
- package/lib/opencode/storage.runner.d.ts +1 -0
- package/lib/opencode/storage.runner.js +13 -0
- package/lib/opencode/storage.runner.mjs +29 -0
- package/lib/{ps/isWin.cjs → opencode/types.cjs} +3 -12
- package/lib/opencode/types.d.ts +31 -0
- package/lib/{ps/isWin.js → opencode/types.js} +0 -2
- package/lib/opencode/types.mjs +7 -0
- package/lib/opencode/utils/check-api.cjs +59 -0
- package/lib/opencode/utils/check-api.d.ts +12 -0
- package/lib/opencode/utils/check-api.js +46 -0
- package/lib/opencode/utils/check-api.mjs +8 -0
- package/lib/opencode-cli.cjs +473 -0
- package/lib/opencode-cli.d.ts +2 -0
- package/lib/opencode-cli.js +115 -0
- package/lib/opencode-cli.mjs +111 -0
- package/lib/package-resolutions-updater-cli.cjs +218 -194
- package/lib/package-resolutions-updater-cli.mjs +6 -4
- package/lib/package-resolutions-updater.cjs +216 -192
- package/lib/package-resolutions-updater.d.mts +44 -1
- package/lib/package-resolutions-updater.mjs +5 -3
- package/lib/php-cs-fixer-staged.cjs +1 -1
- package/lib/php-cs-fixer-staged.mjs +1 -1
- package/lib/print-directory-tree.cjs +147 -21
- package/lib/print-directory-tree.mjs +17 -11
- package/lib/print-tarball-tree.cjs +262 -0
- package/lib/print-tarball-tree.d.mts +1 -0
- package/lib/print-tarball-tree.mjs +68 -0
- package/lib/ps/index.cjs +10 -10
- package/lib/ps/index.mjs +4 -4
- package/lib/ps/table-parser.d.ts +3 -4
- package/lib/ps/table-parser.js +9 -16
- package/lib/remove-module.cjs +17 -22
- package/lib/remove-module.mjs +2 -2
- package/lib/rm-node-module-cli.cjs +171 -4
- package/lib/rm-node-module-cli.mjs +7 -4
- package/lib/rmpath-cli.cjs +411 -0
- package/lib/rmpath-cli.d.mts +1 -0
- package/lib/rmpath-cli.mjs +25 -0
- package/lib/rmpath.cjs +113 -188
- package/lib/rmpath.mjs +7 -101
- package/lib/run-by-checksum/cache.cjs +69 -0
- package/lib/run-by-checksum/cache.d.ts +19 -0
- package/lib/run-by-checksum/cache.js +50 -0
- package/lib/run-by-checksum/cache.mjs +12 -0
- package/lib/run-by-checksum/hash.cjs +88 -0
- package/lib/run-by-checksum/hash.d.ts +17 -0
- package/lib/run-by-checksum/hash.js +119 -0
- package/lib/run-by-checksum/hash.mjs +10 -0
- package/lib/run-by-checksum/run.cjs +185 -0
- package/lib/run-by-checksum/run.d.ts +22 -0
- package/lib/run-by-checksum/run.js +93 -0
- package/lib/run-by-checksum/run.mjs +10 -0
- package/lib/run-by-checksum-cli.cjs +398 -0
- package/lib/run-by-checksum-cli.d.ts +2 -0
- package/lib/run-by-checksum-cli.js +43 -0
- package/lib/run-by-checksum-cli.mjs +56 -0
- package/lib/submodule-install.cjs +137 -16
- package/lib/submodule-install.mjs +7 -6
- package/lib/submodule-remove-cli.cjs +300 -7
- package/lib/submodule-remove-cli.js +2 -2
- package/lib/submodule-remove-cli.mjs +8 -3
- package/lib/submodule-remove.cjs +146 -5
- package/lib/submodule-remove.mjs +3 -1
- package/lib/utils/fetchResponse.cjs +24 -0
- package/lib/utils/fetchResponse.d.cts +25 -0
- package/lib/utils/fetchResponse.mjs +6 -0
- package/lib/utils/findEnvFiles.cjs +3 -0
- package/lib/utils/findEnvFiles.d.cts +2 -2
- package/lib/utils/findEnvFiles.mjs +1 -1
- package/lib/utils/index.cjs +5 -10
- package/lib/utils/index.d.cts +2 -9
- package/lib/utils/index.mjs +1 -1
- package/lib/utils/isWindows.mjs +3 -1
- package/lib/utils/runBash.cjs +1 -1
- package/lib/utils/runBash.mjs +1 -1
- package/lib/vscode/project.cjs +0 -0
- package/lib/vscode/project.d.ts +0 -0
- package/lib/vscode/project.js +1 -0
- package/lib/vscode/project.mjs +7 -0
- package/lib/vscode/storage.cjs +138 -0
- package/lib/vscode/storage.d.ts +51 -0
- package/lib/vscode/storage.js +169 -0
- package/lib/vscode/storage.mjs +42 -0
- package/lib/vscode/storage.runner.cjs +125 -0
- package/lib/vscode/storage.runner.d.ts +1 -0
- package/lib/vscode/storage.runner.js +47 -0
- package/lib/vscode/storage.runner.mjs +60 -0
- package/lib/vscode-cli.cjs +155 -0
- package/lib/vscode-cli.d.ts +2 -0
- package/lib/vscode-cli.js +80 -0
- package/lib/vscode-cli.mjs +71 -0
- package/lib/yarn-per-branch-lock-installer.cjs +202 -11
- package/lib/yarn-per-branch-lock-installer.mjs +24 -11
- package/lib/yarn-reinstall.cjs +6 -11
- package/lib/yarn-reinstall.mjs +1 -1
- package/package.json +75 -28
- package/readme.html +2 -2
- package/readme.md +44 -11
- package/releases/readme.md +6 -3
- package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
- package/tmp/test-repo-runChecksum/test-complex-glob/README.md +1 -0
- package/tmp/test-repo-runChecksum/test-mixed-args/README.md +1 -0
- package/vendor/clue/ndjson-react/README.md +365 -0
- package/vendor/composer/pcre/README.md +189 -0
- package/vendor/composer/semver/README.md +99 -0
- package/vendor/composer/xdebug-handler/README.md +305 -0
- package/vendor/ergebnis/agent-detector/README.md +107 -0
- package/vendor/evenement/evenement/README.md +64 -0
- package/vendor/fidry/cpu-core-counter/README.md +138 -0
- package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
- package/vendor/psr/container/README.md +13 -0
- package/vendor/psr/event-dispatcher/README.md +6 -0
- package/vendor/psr/log/README.md +58 -0
- package/vendor/react/cache/README.md +367 -0
- package/vendor/react/child-process/README.md +619 -0
- package/vendor/react/dns/README.md +453 -0
- package/vendor/react/event-loop/README.md +930 -0
- package/vendor/react/promise/README.md +722 -0
- package/vendor/react/socket/README.md +1564 -0
- package/vendor/react/stream/README.md +1249 -0
- package/vendor/sebastian/diff/README.md +151 -0
- package/vendor/symfony/console/README.md +30 -0
- package/vendor/symfony/deprecation-contracts/README.md +26 -0
- package/vendor/symfony/event-dispatcher/README.md +25 -0
- package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
- package/vendor/symfony/filesystem/README.md +23 -0
- package/vendor/symfony/finder/README.md +24 -0
- package/vendor/symfony/options-resolver/README.md +25 -0
- package/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
- package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
- package/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/vendor/symfony/polyfill-php80/README.md +25 -0
- package/vendor/symfony/polyfill-php81/README.md +18 -0
- package/vendor/symfony/polyfill-php84/README.md +23 -0
- package/vendor/symfony/polyfill-php85/README.md +20 -0
- package/vendor/symfony/process/README.md +23 -0
- package/vendor/symfony/service-contracts/README.md +9 -0
- package/vendor/symfony/stopwatch/README.md +52 -0
- package/vendor/symfony/string/README.md +24 -0
- package/.opencode/package.json +0 -5
- package/lib/chunk-6S4NXESK.mjs +0 -26
- package/lib/clean-github-actions-caches.cjs +0 -249
- package/lib/clean-github-actions-caches.d.cts +0 -15
- package/lib/del-gradle.js +0 -16
- package/lib/del-node-modules.js +0 -211
- package/lib/del-ps.js +0 -32
- package/lib/del-ps.mjs +0 -43
- package/lib/find-node-modules-cli.js +0 -4
- package/lib/ps/isWin.d.ts +0 -2
- package/test/package.json +0 -20
- package/test-project/package.json +0 -22
- package/test-project/workspaces/workspace-a/package.json +0 -135
- package/test-project/workspaces/workspace-a/test/demo/package.json +0 -25
- package/test-project/workspaces/workspace-b/package.json +0 -139
- package/test-project/workspaces/workspace-b/test/sample-project/package.json +0 -7
- package/test-project/workspaces/workspace-b/themes/hexo-theme-flowbite/package.json +0 -96
- package/tmp/rm-node-modules-test-project/package.json +0 -17
- package/tmp/rm-node-modules-test-project/packages/workspace-a/package.json +0 -16
- package/tmp/rm-node-modules-test-project/packages/workspace-b/package.json +0 -16
- package/tmp/test-repo/package.json +0 -17
- /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
- /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
- /package/lib/{del-node-modules.d.ts → del-ps-cli.d.mts} +0 -0
- /package/lib/{find-node-modules-cli.d.ts → downloader-cli.d.cts} +0 -0
- /package/lib/{git-diff-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
- /package/lib/{git-fix.d.cts → git/git-diff-cli.d.ts} +0 -0
- /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
- /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
- /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
- /package/lib/{del-ps.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
|
@@ -0,0 +1,473 @@
|
|
|
1
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
2
|
+
var __esm = (fn, res) => function __init() {
|
|
3
|
+
return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
|
|
4
|
+
};
|
|
5
|
+
var __commonJS = (cb, mod) => function __require() {
|
|
6
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
// node_modules/tsup/assets/cjs_shims.js
|
|
10
|
+
var init_cjs_shims = __esm({
|
|
11
|
+
"node_modules/tsup/assets/cjs_shims.js"() {
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
// src/utils/index.cjs
|
|
16
|
+
var require_utils = __commonJS({
|
|
17
|
+
"src/utils/index.cjs"(exports2, module2) {
|
|
18
|
+
init_cjs_shims();
|
|
19
|
+
var fs = require("fs");
|
|
20
|
+
var path = require("upath");
|
|
21
|
+
var minimistLib = require("minimist");
|
|
22
|
+
var argv2 = minimistLib(process.argv.slice(2));
|
|
23
|
+
var { exec } = require("child_process");
|
|
24
|
+
var { promisify } = require("util");
|
|
25
|
+
var execAsync = promisify(exec);
|
|
26
|
+
async function parseGitRemotes() {
|
|
27
|
+
try {
|
|
28
|
+
const { stdout } = await execAsync("git remote -v");
|
|
29
|
+
const lines = stdout.split("\n");
|
|
30
|
+
const remotes = {};
|
|
31
|
+
lines.forEach((line) => {
|
|
32
|
+
const [name, url] = line.split(" ");
|
|
33
|
+
if (name && url) {
|
|
34
|
+
const [repoUrl] = url.split(" ");
|
|
35
|
+
try {
|
|
36
|
+
const parsedUrl = new URL(repoUrl);
|
|
37
|
+
const pathParts = parsedUrl.pathname.split("/").filter(Boolean);
|
|
38
|
+
if (parsedUrl.hostname === "github.com" && pathParts.length === 2) {
|
|
39
|
+
let repoPath = pathParts.join("/");
|
|
40
|
+
if (repoPath.endsWith(".git")) {
|
|
41
|
+
repoPath = repoPath.slice(0, -4);
|
|
42
|
+
}
|
|
43
|
+
remotes[name] = repoPath;
|
|
44
|
+
}
|
|
45
|
+
} catch (e) {
|
|
46
|
+
console.error("URL Parsing Error:", e.message);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
return remotes;
|
|
51
|
+
} catch (error) {
|
|
52
|
+
console.error("Error:", error.message);
|
|
53
|
+
return {};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
module2.exports.parseGitRemotes = parseGitRemotes;
|
|
57
|
+
function getArgs2(opts) {
|
|
58
|
+
if (opts) {
|
|
59
|
+
return minimistLib(process.argv.slice(2), opts);
|
|
60
|
+
}
|
|
61
|
+
return argv2;
|
|
62
|
+
}
|
|
63
|
+
module2.exports.getArgs = getArgs2;
|
|
64
|
+
function del(fullPath) {
|
|
65
|
+
try {
|
|
66
|
+
if (!fs.existsSync(fullPath)) return;
|
|
67
|
+
const stat = fs.lstatSync(fullPath);
|
|
68
|
+
if (stat.isSymbolicLink()) {
|
|
69
|
+
try {
|
|
70
|
+
fs.unlinkSync(fullPath);
|
|
71
|
+
console.log("deleted symlink", fullPath);
|
|
72
|
+
} catch (e) {
|
|
73
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
74
|
+
}
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
if (stat.isDirectory()) {
|
|
78
|
+
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
79
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
80
|
+
del(subdir[i]);
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
fs.rmdirSync(fullPath);
|
|
84
|
+
console.log("deleted", fullPath);
|
|
85
|
+
} catch (_e) {
|
|
86
|
+
try {
|
|
87
|
+
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
88
|
+
console.log("deleted", fullPath);
|
|
89
|
+
} catch (ee) {
|
|
90
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
try {
|
|
96
|
+
fs.unlinkSync(fullPath);
|
|
97
|
+
console.log("deleted", fullPath);
|
|
98
|
+
} catch (_e) {
|
|
99
|
+
try {
|
|
100
|
+
fs.rmSync(fullPath, { recursive: true, force: true, retryDelay: 7e3 });
|
|
101
|
+
console.log("deleted", fullPath);
|
|
102
|
+
} catch (ee) {
|
|
103
|
+
console.log("failed delete", fullPath, ee && ee.message);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
} catch (err) {
|
|
107
|
+
console.log("failed delete", fullPath, err && err.message);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
module2.exports.del = del;
|
|
111
|
+
function delStream(globStream) {
|
|
112
|
+
globStream.stream().on("data", (result) => {
|
|
113
|
+
const fullPath = path.resolve(process.cwd(), result);
|
|
114
|
+
try {
|
|
115
|
+
if (fs.existsSync(fullPath)) {
|
|
116
|
+
const stat = fs.lstatSync(fullPath);
|
|
117
|
+
if (stat.isSymbolicLink()) {
|
|
118
|
+
try {
|
|
119
|
+
fs.unlinkSync(fullPath);
|
|
120
|
+
console.log("deleted symlink", fullPath);
|
|
121
|
+
} catch (e) {
|
|
122
|
+
console.log("failed delete symlink", fullPath, e && e.message);
|
|
123
|
+
}
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
if (stat.isDirectory()) {
|
|
127
|
+
const subdir = fs.readdirSync(fullPath).map((dirPath) => path.resolve(fullPath, dirPath));
|
|
128
|
+
for (let i = 0; i < subdir.length; i++) {
|
|
129
|
+
del(subdir[i]);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
del(fullPath);
|
|
134
|
+
} catch (err) {
|
|
135
|
+
console.log("failed processing", fullPath, err && err.message);
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
module2.exports.delStream = delStream;
|
|
140
|
+
function getFileTreeString(hashArray) {
|
|
141
|
+
const tree = {};
|
|
142
|
+
const hashMap = {};
|
|
143
|
+
for (const entry of hashArray) {
|
|
144
|
+
const [filePath, hash] = entry.split(" ");
|
|
145
|
+
hashMap[filePath] = hash;
|
|
146
|
+
const parts = filePath.split("/");
|
|
147
|
+
let current = tree;
|
|
148
|
+
for (let i = 0; i < parts.length; i++) {
|
|
149
|
+
const part = parts[i];
|
|
150
|
+
if (i === parts.length - 1) {
|
|
151
|
+
current[part] = null;
|
|
152
|
+
} else {
|
|
153
|
+
current[part] = current[part] || {};
|
|
154
|
+
current = current[part];
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
function printNode(node, prefix = "", parentPath = "") {
|
|
159
|
+
const keys = Object.keys(node).sort();
|
|
160
|
+
let lines = [];
|
|
161
|
+
keys.forEach((key, idx) => {
|
|
162
|
+
const isLast = idx === keys.length - 1;
|
|
163
|
+
const branch = isLast ? "\u2514\u2500\u2500 " : "\u251C\u2500\u2500 ";
|
|
164
|
+
const currentPath = parentPath ? parentPath + "/" + key : key;
|
|
165
|
+
if (node[key] === null) {
|
|
166
|
+
lines.push(prefix + branch + key + " [" + (hashMap[currentPath] || "") + "]");
|
|
167
|
+
} else {
|
|
168
|
+
lines.push(prefix + branch + key + "/");
|
|
169
|
+
lines = lines.concat(printNode(node[key], prefix + (isLast ? " " : "\u2502 "), currentPath));
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
return lines;
|
|
173
|
+
}
|
|
174
|
+
return printNode(tree, "", "").join("\n");
|
|
175
|
+
}
|
|
176
|
+
module2.exports.getFileTreeString = getFileTreeString;
|
|
177
|
+
var delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
178
|
+
module2.exports.delay = delay;
|
|
179
|
+
}
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
// src/utils/findEnvFiles.cjs
|
|
183
|
+
var require_findEnvFiles = __commonJS({
|
|
184
|
+
"src/utils/findEnvFiles.cjs"(exports2, module2) {
|
|
185
|
+
init_cjs_shims();
|
|
186
|
+
var fs = require("fs");
|
|
187
|
+
var path = require("path");
|
|
188
|
+
var glob = require("glob");
|
|
189
|
+
var DEFAULT_IGNORES = [
|
|
190
|
+
"**/node_modules/**",
|
|
191
|
+
"**/.git/**",
|
|
192
|
+
"**/.yarn/**",
|
|
193
|
+
"**/.pnpm/**",
|
|
194
|
+
"**/dist/**",
|
|
195
|
+
"**/build/**",
|
|
196
|
+
"**/coverage/**",
|
|
197
|
+
"**/vendor/**",
|
|
198
|
+
"**/tmp/**",
|
|
199
|
+
"**/.cache/**",
|
|
200
|
+
"**/assets/**",
|
|
201
|
+
"**/logs/**",
|
|
202
|
+
"**/output/**",
|
|
203
|
+
"**/public/**",
|
|
204
|
+
"**/static/**",
|
|
205
|
+
"**/temp/**",
|
|
206
|
+
"**/backup/**",
|
|
207
|
+
"**/backups/**",
|
|
208
|
+
"**/examples/**",
|
|
209
|
+
"**/docs/**",
|
|
210
|
+
"**/tests/**",
|
|
211
|
+
"**/__tests__/**",
|
|
212
|
+
"**/spec/**",
|
|
213
|
+
"**/__specs__/**",
|
|
214
|
+
"**/scripts/**",
|
|
215
|
+
"**/bin/**",
|
|
216
|
+
"**/hooks/**",
|
|
217
|
+
"**/config/**",
|
|
218
|
+
"**/configs/**",
|
|
219
|
+
"**/settings/**",
|
|
220
|
+
"**/.vscode/**",
|
|
221
|
+
"**/.idea/**"
|
|
222
|
+
];
|
|
223
|
+
function findEnvFiles(startDir = process.cwd(), filter) {
|
|
224
|
+
const found = /* @__PURE__ */ new Set();
|
|
225
|
+
function addFile(file) {
|
|
226
|
+
const normalized = path.normalize(file);
|
|
227
|
+
if (typeof filter === "function" && !filter(normalized)) {
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
found.add(normalized);
|
|
231
|
+
}
|
|
232
|
+
let current = path.resolve(startDir);
|
|
233
|
+
while (true) {
|
|
234
|
+
const envPath = path.join(current, ".env");
|
|
235
|
+
if (fs.existsSync(envPath)) {
|
|
236
|
+
addFile(envPath);
|
|
237
|
+
}
|
|
238
|
+
const parent = path.dirname(current);
|
|
239
|
+
if (parent === current) {
|
|
240
|
+
break;
|
|
241
|
+
}
|
|
242
|
+
current = parent;
|
|
243
|
+
}
|
|
244
|
+
const files = glob.globSync("**/.env*", {
|
|
245
|
+
cwd: startDir,
|
|
246
|
+
absolute: true,
|
|
247
|
+
nodir: true,
|
|
248
|
+
ignore: DEFAULT_IGNORES
|
|
249
|
+
});
|
|
250
|
+
for (const file of files) {
|
|
251
|
+
addFile(file);
|
|
252
|
+
}
|
|
253
|
+
return [...found];
|
|
254
|
+
}
|
|
255
|
+
function findEnvWithToken(startDir = process.cwd(), tokenName = "GITHUB_TOKEN") {
|
|
256
|
+
const envFiles = findEnvFiles(startDir);
|
|
257
|
+
return envFiles.find((file) => {
|
|
258
|
+
try {
|
|
259
|
+
const content = fs.readFileSync(file, "utf-8");
|
|
260
|
+
if (tokenName instanceof RegExp) {
|
|
261
|
+
return tokenName.test(content);
|
|
262
|
+
}
|
|
263
|
+
const regex = new RegExp(`^\\s*${tokenName}\\s*=`, "m");
|
|
264
|
+
return regex.test(content);
|
|
265
|
+
} catch (err) {
|
|
266
|
+
console.warn(`Failed to read ${file}: ${err instanceof Error ? err.message : String(err)}`);
|
|
267
|
+
return false;
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
module2.exports = {
|
|
272
|
+
DEFAULT_IGNORES,
|
|
273
|
+
findEnvFiles,
|
|
274
|
+
findEnvWithToken,
|
|
275
|
+
default: findEnvFiles
|
|
276
|
+
};
|
|
277
|
+
}
|
|
278
|
+
});
|
|
279
|
+
|
|
280
|
+
// src/binary-collections/config.cjs
|
|
281
|
+
var require_config = __commonJS({
|
|
282
|
+
"src/binary-collections/config.cjs"(exports2, module2) {
|
|
283
|
+
init_cjs_shims();
|
|
284
|
+
var path = require("upath");
|
|
285
|
+
var minimistLib = require("minimist");
|
|
286
|
+
var { findEnvWithToken } = require_findEnvFiles();
|
|
287
|
+
var dotenv = require("dotenv");
|
|
288
|
+
var loadDotenv = (tokenKey = /ACCESS_TOKEN|GITHUB_TOKEN/) => dotenv.config({ path: findEnvWithToken(void 0, tokenKey), quiet: true, overwrite: true });
|
|
289
|
+
loadDotenv();
|
|
290
|
+
var cliArgv = minimistLib(process.argv.slice(2), {
|
|
291
|
+
string: ["token"]
|
|
292
|
+
});
|
|
293
|
+
var GITHUB_ACCESS_TOKEN = cliArgv.token || process.env.ACCESS_TOKEN || process.env.GITHUB_TOKEN || process.env.GH_TOKEN;
|
|
294
|
+
function getTempDir() {
|
|
295
|
+
return process.env.TEMP_DIR || path.join(process.cwd(), "tmp");
|
|
296
|
+
}
|
|
297
|
+
function getTempPath(...segments) {
|
|
298
|
+
return path.join(getTempDir(), ...segments);
|
|
299
|
+
}
|
|
300
|
+
var TEMP_BASE_DIR = getTempDir();
|
|
301
|
+
module2.exports = {
|
|
302
|
+
getTempDir,
|
|
303
|
+
getTempPath,
|
|
304
|
+
TEMP_BASE_DIR,
|
|
305
|
+
GITHUB_ACCESS_TOKEN,
|
|
306
|
+
loadDotenv
|
|
307
|
+
};
|
|
308
|
+
}
|
|
309
|
+
});
|
|
310
|
+
|
|
311
|
+
// src/github-workflows/clean-github-actions-caches.cjs
|
|
312
|
+
init_cjs_shims();
|
|
313
|
+
var axios = require("axios");
|
|
314
|
+
var { getArgs } = require_utils();
|
|
315
|
+
var { GITHUB_ACCESS_TOKEN: ACCESS_TOKEN } = require_config();
|
|
316
|
+
if (!ACCESS_TOKEN) {
|
|
317
|
+
throw new Error(
|
|
318
|
+
"Access token is not provided. Please set ACCESS_TOKEN or GITHUB_TOKEN in your environment variables."
|
|
319
|
+
);
|
|
320
|
+
}
|
|
321
|
+
function printHelp() {
|
|
322
|
+
console.log(`
|
|
323
|
+
GitHub Actions Cache Cleaner
|
|
324
|
+
|
|
325
|
+
Description:
|
|
326
|
+
Removes outdated GitHub Actions caches for a repository, keeping only the newest
|
|
327
|
+
cache for each cache-key prefix. Authenticates via ACCESS_TOKEN or GITHUB_TOKEN
|
|
328
|
+
from your environment or .env file.
|
|
329
|
+
|
|
330
|
+
Usage:
|
|
331
|
+
clean-github-actions-caches [options]
|
|
332
|
+
|
|
333
|
+
Options:
|
|
334
|
+
-h, --help Show this help message
|
|
335
|
+
-r, --repo <repo> GitHub repository (owner/repo). If omitted, the tool will
|
|
336
|
+
attempt to infer the repository from the current working
|
|
337
|
+
directory's git remotes.
|
|
338
|
+
-p, --prefix-depth <n>
|
|
339
|
+
Number of leading cache key segments to use as the
|
|
340
|
+
grouping prefix when splitting on /[-_]/. Default: 3.
|
|
341
|
+
|
|
342
|
+
Environment Variables:
|
|
343
|
+
ACCESS_TOKEN GitHub access token (preferred)
|
|
344
|
+
GITHUB_TOKEN GitHub access token (fallback)
|
|
345
|
+
|
|
346
|
+
Behavior & Safety:
|
|
347
|
+
- Groups caches by a derived prefix from the cache key and keeps the most
|
|
348
|
+
recently created cache for each group.
|
|
349
|
+
- Deletes only caches older than the latest per prefix to reduce risk of
|
|
350
|
+
removing needed artifacts.
|
|
351
|
+
|
|
352
|
+
Examples:
|
|
353
|
+
# Run against a specific repo (owner/repo)
|
|
354
|
+
clean-github-actions-caches --repo octocat/hello-world
|
|
355
|
+
|
|
356
|
+
# Run via npx without installing
|
|
357
|
+
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
|
|
358
|
+
|
|
359
|
+
# Run via yarn dlx
|
|
360
|
+
yarn dlx binary-collections@https://raw.githubusercontent.com/dimaslanjaka/bin/master/releases/bin.tgz clean-github-actions-caches --prefix-depth 3
|
|
361
|
+
|
|
362
|
+
Notes:
|
|
363
|
+
- Ensure ACCESS_TOKEN or GITHUB_TOKEN is set and has permissions to manage Actions caches.
|
|
364
|
+
- Intended for repository maintainers with appropriate permissions.
|
|
365
|
+
`);
|
|
366
|
+
}
|
|
367
|
+
var argv = getArgs({
|
|
368
|
+
alias: {
|
|
369
|
+
h: "help",
|
|
370
|
+
p: "prefix-depth",
|
|
371
|
+
r: "repo"
|
|
372
|
+
},
|
|
373
|
+
string: ["prefix-depth", "repo"],
|
|
374
|
+
boolean: ["help"]
|
|
375
|
+
});
|
|
376
|
+
if (argv.help) {
|
|
377
|
+
printHelp();
|
|
378
|
+
process.exit(0);
|
|
379
|
+
}
|
|
380
|
+
function deleteGitHubActionsCache(GH_REPO, cacheId) {
|
|
381
|
+
return new Promise((resolve, reject) => {
|
|
382
|
+
const url = `https://api.github.com/repos/${GH_REPO}/actions/caches/${cacheId}`;
|
|
383
|
+
const token = ACCESS_TOKEN;
|
|
384
|
+
if (!token) {
|
|
385
|
+
return reject(new Error("Access token is not provided"));
|
|
386
|
+
}
|
|
387
|
+
axios.delete(url, {
|
|
388
|
+
headers: {
|
|
389
|
+
Authorization: `token ${token}`,
|
|
390
|
+
Accept: "application/vnd.github.v3+json"
|
|
391
|
+
}
|
|
392
|
+
}).then((response) => {
|
|
393
|
+
console.log(`Cache (${cacheId}) deleted successfully`, response.data);
|
|
394
|
+
resolve(response.data);
|
|
395
|
+
}).catch((error) => {
|
|
396
|
+
var _a;
|
|
397
|
+
console.error("Error deleting cache:", ((_a = error.response) == null ? void 0 : _a.data) || error.message || "Unknown error");
|
|
398
|
+
reject(error);
|
|
399
|
+
});
|
|
400
|
+
});
|
|
401
|
+
}
|
|
402
|
+
function normalizePrefixDepth(prefixDepth) {
|
|
403
|
+
const parsed = Number(prefixDepth);
|
|
404
|
+
if (!Number.isFinite(parsed) || parsed < 1) {
|
|
405
|
+
return 3;
|
|
406
|
+
}
|
|
407
|
+
return Math.floor(parsed);
|
|
408
|
+
}
|
|
409
|
+
function isChecksumSegment(segment) {
|
|
410
|
+
return /^[a-f0-9]{32,}$/i.test(segment);
|
|
411
|
+
}
|
|
412
|
+
function getMeaningfulCacheKeyParts(key) {
|
|
413
|
+
return String(key).split(/[-_]/).filter(Boolean).filter((segment) => !isChecksumSegment(segment));
|
|
414
|
+
}
|
|
415
|
+
function getCachePrefix(key, prefixDepth = 3) {
|
|
416
|
+
const normalizedDepth = normalizePrefixDepth(prefixDepth);
|
|
417
|
+
const parts = String(key).split(/[-_]/).filter(Boolean);
|
|
418
|
+
const meaningfulParts = getMeaningfulCacheKeyParts(key);
|
|
419
|
+
if (meaningfulParts.length !== parts.length) {
|
|
420
|
+
if (meaningfulParts.length < normalizedDepth) {
|
|
421
|
+
return `${meaningfulParts.join("-")}-`;
|
|
422
|
+
}
|
|
423
|
+
return meaningfulParts.join("-");
|
|
424
|
+
}
|
|
425
|
+
if (parts.length <= normalizedDepth) {
|
|
426
|
+
return parts.join("-");
|
|
427
|
+
}
|
|
428
|
+
return parts.slice(0, normalizedDepth).join("-");
|
|
429
|
+
}
|
|
430
|
+
function groupCachesByPrefix(caches, prefixDepth = 3) {
|
|
431
|
+
return caches.reduce(
|
|
432
|
+
/**
|
|
433
|
+
* @param {Record<string, Record<string, any>[]>} acc
|
|
434
|
+
* @param {Record<string, any>} item
|
|
435
|
+
* @returns {Record<string, Record<string, any>[]>}
|
|
436
|
+
*/
|
|
437
|
+
(acc, item) => {
|
|
438
|
+
const prefix = getCachePrefix(item.key, prefixDepth);
|
|
439
|
+
if (!acc[prefix]) {
|
|
440
|
+
acc[prefix] = [];
|
|
441
|
+
}
|
|
442
|
+
acc[prefix].push(item);
|
|
443
|
+
return acc;
|
|
444
|
+
},
|
|
445
|
+
{}
|
|
446
|
+
);
|
|
447
|
+
}
|
|
448
|
+
function get_caches(GH_REPO, prefixDepth = 3) {
|
|
449
|
+
const url = `https://api.github.com/repos/${GH_REPO}/actions/caches`;
|
|
450
|
+
return new Promise((resolve, reject) => {
|
|
451
|
+
axios.get(url, {
|
|
452
|
+
headers: {
|
|
453
|
+
Accept: "application/vnd.github.v3+json",
|
|
454
|
+
Authorization: `token ${ACCESS_TOKEN}`
|
|
455
|
+
}
|
|
456
|
+
}).then((response) => {
|
|
457
|
+
const data = response.data.actions_caches;
|
|
458
|
+
const grouped = groupCachesByPrefix(data, prefixDepth);
|
|
459
|
+
resolve(grouped);
|
|
460
|
+
}).catch((error) => {
|
|
461
|
+
reject(error);
|
|
462
|
+
});
|
|
463
|
+
});
|
|
464
|
+
}
|
|
465
|
+
module.exports = {
|
|
466
|
+
deleteGitHubActionsCache,
|
|
467
|
+
getCachePrefix,
|
|
468
|
+
getMeaningfulCacheKeyParts,
|
|
469
|
+
get_caches,
|
|
470
|
+
groupCachesByPrefix,
|
|
471
|
+
isChecksumSegment,
|
|
472
|
+
normalizePrefixDepth
|
|
473
|
+
};
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Deletes a GitHub Actions cache.
|
|
3
|
+
*
|
|
4
|
+
* @param {string} GH_REPO - The GitHub repository in the format "owner/repo".
|
|
5
|
+
* @param {string|number} cacheId - The ID of the cache to delete.
|
|
6
|
+
* @returns {Promise<any>} Promise resolving with GitHub API response.
|
|
7
|
+
*/
|
|
8
|
+
export function deleteGitHubActionsCache(GH_REPO: string, cacheId: string | number): Promise<any>;
|
|
9
|
+
/**
|
|
10
|
+
* Extract the grouping prefix from a cache key.
|
|
11
|
+
*
|
|
12
|
+
* @param {string} key
|
|
13
|
+
* @param {number} [prefixDepth=3]
|
|
14
|
+
* @returns {string}
|
|
15
|
+
*/
|
|
16
|
+
export function getCachePrefix(key: string, prefixDepth?: number): string;
|
|
17
|
+
/**
|
|
18
|
+
* Remove checksum-like segments from a cache key.
|
|
19
|
+
*
|
|
20
|
+
* @param {string} key
|
|
21
|
+
* @returns {string[]}
|
|
22
|
+
*/
|
|
23
|
+
export function getMeaningfulCacheKeyParts(key: string): string[];
|
|
24
|
+
/**
|
|
25
|
+
* List GitHub Actions caches grouped by cache key prefix.
|
|
26
|
+
*
|
|
27
|
+
* @param {string} GH_REPO GitHub repository in format `owner/repo`.
|
|
28
|
+
* @param {number} [prefixDepth=3]
|
|
29
|
+
* @returns {Promise<Record<string, Record<string, any>[]>>}
|
|
30
|
+
*/
|
|
31
|
+
export function get_caches(GH_REPO: string, prefixDepth?: number): Promise<Record<string, Record<string, any>[]>>;
|
|
32
|
+
/**
|
|
33
|
+
* Group GitHub Actions caches by their derived prefix.
|
|
34
|
+
*
|
|
35
|
+
* @param {Record<string, any>[]} caches
|
|
36
|
+
* @param {number} [prefixDepth=3]
|
|
37
|
+
* @returns {Record<string, Record<string, any>[]>}
|
|
38
|
+
*/
|
|
39
|
+
export function groupCachesByPrefix(caches: Record<string, any>[], prefixDepth?: number): Record<string, Record<string, any>[]>;
|
|
40
|
+
/**
|
|
41
|
+
* Detect cache-key segments that look like checksum hashes.
|
|
42
|
+
*
|
|
43
|
+
* @param {string} segment
|
|
44
|
+
* @returns {boolean}
|
|
45
|
+
*/
|
|
46
|
+
export function isChecksumSegment(segment: string): boolean;
|
|
47
|
+
/**
|
|
48
|
+
* Normalize the number of cache key segments to use for grouping.
|
|
49
|
+
*
|
|
50
|
+
* @param {unknown} prefixDepth
|
|
51
|
+
* @returns {number}
|
|
52
|
+
*/
|
|
53
|
+
export function normalizePrefixDepth(prefixDepth: unknown): number;
|
package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs}
RENAMED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { createRequire } from 'module'; const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
require_clean_github_actions_caches
|
|
4
|
-
} from "
|
|
5
|
-
import "
|
|
6
|
-
import "
|
|
4
|
+
} from "../chunk-BEUM4LH4.mjs";
|
|
5
|
+
import "../chunk-SARIXFHP.mjs";
|
|
6
|
+
import "../chunk-J4M5EL5P.mjs";
|
|
7
|
+
import "../chunk-6RK5UCTP.mjs";
|
|
8
|
+
import "../chunk-QQ4A6DLD.mjs";
|
|
7
9
|
export default require_clean_github_actions_caches();
|