@fredlackey/devutils 0.0.1 → 0.0.3

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 (259) hide show
  1. package/README.md +5 -5
  2. package/package.json +1 -1
  3. package/src/commands/install.js +374 -36
  4. package/src/installs/adobe-creative-cloud.js +527 -25
  5. package/src/installs/adobe-creative-cloud.md +605 -0
  6. package/src/installs/appcleaner.js +303 -26
  7. package/src/installs/appcleaner.md +699 -0
  8. package/src/installs/apt-transport-https.js +390 -0
  9. package/src/installs/apt-transport-https.md +678 -0
  10. package/src/installs/atomicparsley.js +624 -26
  11. package/src/installs/atomicparsley.md +795 -0
  12. package/src/installs/aws-cli.js +779 -26
  13. package/src/installs/aws-cli.md +727 -0
  14. package/src/installs/balena-etcher.js +688 -26
  15. package/src/installs/balena-etcher.md +761 -0
  16. package/src/installs/bambu-studio.js +912 -26
  17. package/src/installs/bambu-studio.md +780 -0
  18. package/src/installs/bash-completion.js +554 -23
  19. package/src/installs/bash-completion.md +833 -0
  20. package/src/installs/bash.js +399 -26
  21. package/src/installs/bash.md +993 -0
  22. package/src/installs/beyond-compare.js +585 -26
  23. package/src/installs/beyond-compare.md +813 -0
  24. package/src/installs/build-essential.js +511 -26
  25. package/src/installs/build-essential.md +977 -0
  26. package/src/installs/ca-certificates.js +618 -0
  27. package/src/installs/ca-certificates.md +937 -0
  28. package/src/installs/caffeine.js +490 -26
  29. package/src/installs/caffeine.md +839 -0
  30. package/src/installs/camtasia.js +577 -25
  31. package/src/installs/camtasia.md +762 -0
  32. package/src/installs/chatgpt.js +458 -26
  33. package/src/installs/chatgpt.md +814 -0
  34. package/src/installs/chocolatey.js +447 -0
  35. package/src/installs/chocolatey.md +661 -0
  36. package/src/installs/chrome-canary.js +472 -26
  37. package/src/installs/chrome-canary.md +641 -0
  38. package/src/installs/chromium.js +645 -26
  39. package/src/installs/chromium.md +838 -0
  40. package/src/installs/claude-code.js +558 -26
  41. package/src/installs/claude-code.md +1173 -0
  42. package/src/installs/curl.js +361 -26
  43. package/src/installs/curl.md +714 -0
  44. package/src/installs/cursor.js +561 -26
  45. package/src/installs/cursor.md +970 -0
  46. package/src/installs/dbschema.js +674 -26
  47. package/src/installs/dbschema.md +925 -0
  48. package/src/installs/dependencies.md +435 -0
  49. package/src/installs/development-tools.js +600 -0
  50. package/src/installs/development-tools.md +977 -0
  51. package/src/installs/docker.js +1010 -25
  52. package/src/installs/docker.md +1109 -0
  53. package/src/installs/drawio.js +1001 -26
  54. package/src/installs/drawio.md +795 -0
  55. package/src/installs/elmedia-player.js +328 -25
  56. package/src/installs/elmedia-player.md +556 -0
  57. package/src/installs/ffmpeg.js +870 -25
  58. package/src/installs/ffmpeg.md +852 -0
  59. package/src/installs/file.js +464 -0
  60. package/src/installs/file.md +987 -0
  61. package/src/installs/gemini-cli.js +793 -26
  62. package/src/installs/gemini-cli.md +1153 -0
  63. package/src/installs/git.js +382 -26
  64. package/src/installs/git.md +907 -0
  65. package/src/installs/gitego.js +931 -26
  66. package/src/installs/gitego.md +1172 -0
  67. package/src/installs/go.js +913 -26
  68. package/src/installs/go.md +958 -0
  69. package/src/installs/google-chrome.js +801 -25
  70. package/src/installs/google-chrome.md +862 -0
  71. package/src/installs/gpg.js +412 -73
  72. package/src/installs/gpg.md +1056 -0
  73. package/src/installs/homebrew.js +1015 -26
  74. package/src/installs/homebrew.md +988 -0
  75. package/src/installs/imageoptim.js +950 -26
  76. package/src/installs/imageoptim.md +1119 -0
  77. package/src/installs/installers.json +2297 -0
  78. package/src/installs/jq.js +382 -26
  79. package/src/installs/jq.md +809 -0
  80. package/src/installs/keyboard-maestro.js +701 -26
  81. package/src/installs/keyboard-maestro.md +825 -0
  82. package/src/installs/latex.js +771 -26
  83. package/src/installs/latex.md +1095 -0
  84. package/src/installs/lftp.js +338 -26
  85. package/src/installs/lftp.md +907 -0
  86. package/src/installs/lsb-release.js +346 -0
  87. package/src/installs/lsb-release.md +814 -0
  88. package/src/installs/messenger.js +829 -26
  89. package/src/installs/messenger.md +900 -0
  90. package/src/installs/microsoft-office.js +550 -26
  91. package/src/installs/microsoft-office.md +760 -0
  92. package/src/installs/microsoft-teams.js +782 -25
  93. package/src/installs/microsoft-teams.md +886 -0
  94. package/src/installs/node.js +886 -26
  95. package/src/installs/node.md +1153 -0
  96. package/src/installs/nordpass.js +698 -26
  97. package/src/installs/nordpass.md +921 -0
  98. package/src/installs/nvm.js +977 -26
  99. package/src/installs/nvm.md +1057 -0
  100. package/src/installs/openssh.js +734 -64
  101. package/src/installs/openssh.md +1056 -0
  102. package/src/installs/pandoc.js +644 -26
  103. package/src/installs/pandoc.md +1036 -0
  104. package/src/installs/pinentry.js +492 -26
  105. package/src/installs/pinentry.md +1142 -0
  106. package/src/installs/pngyu.js +851 -26
  107. package/src/installs/pngyu.md +896 -0
  108. package/src/installs/postman.js +781 -26
  109. package/src/installs/postman.md +940 -0
  110. package/src/installs/procps.js +425 -0
  111. package/src/installs/procps.md +851 -0
  112. package/src/installs/safari-tech-preview.js +355 -25
  113. package/src/installs/safari-tech-preview.md +533 -0
  114. package/src/installs/sfnt2woff.js +640 -26
  115. package/src/installs/sfnt2woff.md +795 -0
  116. package/src/installs/shellcheck.js +463 -26
  117. package/src/installs/shellcheck.md +1005 -0
  118. package/src/installs/slack.js +722 -25
  119. package/src/installs/slack.md +865 -0
  120. package/src/installs/snagit.js +566 -25
  121. package/src/installs/snagit.md +844 -0
  122. package/src/installs/software-properties-common.js +372 -0
  123. package/src/installs/software-properties-common.md +805 -0
  124. package/src/installs/spotify.js +858 -25
  125. package/src/installs/spotify.md +901 -0
  126. package/src/installs/studio-3t.js +803 -26
  127. package/src/installs/studio-3t.md +918 -0
  128. package/src/installs/sublime-text.js +780 -25
  129. package/src/installs/sublime-text.md +914 -0
  130. package/src/installs/superwhisper.js +687 -25
  131. package/src/installs/superwhisper.md +630 -0
  132. package/src/installs/tailscale.js +727 -26
  133. package/src/installs/tailscale.md +1100 -0
  134. package/src/installs/tar.js +389 -0
  135. package/src/installs/tar.md +946 -0
  136. package/src/installs/termius.js +780 -26
  137. package/src/installs/termius.md +844 -0
  138. package/src/installs/terraform.js +761 -26
  139. package/src/installs/terraform.md +899 -0
  140. package/src/installs/tidal.js +752 -25
  141. package/src/installs/tidal.md +864 -0
  142. package/src/installs/tmux.js +328 -26
  143. package/src/installs/tmux.md +1030 -0
  144. package/src/installs/tree.js +393 -26
  145. package/src/installs/tree.md +833 -0
  146. package/src/installs/unzip.js +460 -0
  147. package/src/installs/unzip.md +879 -0
  148. package/src/installs/vim.js +403 -26
  149. package/src/installs/vim.md +1040 -0
  150. package/src/installs/vlc.js +803 -26
  151. package/src/installs/vlc.md +927 -0
  152. package/src/installs/vscode.js +825 -26
  153. package/src/installs/vscode.md +1002 -0
  154. package/src/installs/wget.js +415 -0
  155. package/src/installs/wget.md +791 -0
  156. package/src/installs/whatsapp.js +710 -25
  157. package/src/installs/whatsapp.md +854 -0
  158. package/src/installs/winpty.js +352 -0
  159. package/src/installs/winpty.md +620 -0
  160. package/src/installs/woff2.js +535 -26
  161. package/src/installs/woff2.md +977 -0
  162. package/src/installs/wsl.js +572 -0
  163. package/src/installs/wsl.md +699 -0
  164. package/src/installs/xcode-clt.js +520 -0
  165. package/src/installs/xcode-clt.md +351 -0
  166. package/src/installs/xcode.js +542 -26
  167. package/src/installs/xcode.md +573 -0
  168. package/src/installs/yarn.js +806 -26
  169. package/src/installs/yarn.md +1074 -0
  170. package/src/installs/yq.js +636 -26
  171. package/src/installs/yq.md +944 -0
  172. package/src/installs/yt-dlp.js +683 -26
  173. package/src/installs/yt-dlp.md +946 -0
  174. package/src/installs/yum-utils.js +297 -0
  175. package/src/installs/yum-utils.md +648 -0
  176. package/src/installs/zoom.js +740 -25
  177. package/src/installs/zoom.md +884 -0
  178. package/src/scripts/README.md +567 -45
  179. package/src/scripts/STATUS.md +208 -0
  180. package/src/scripts/afk.js +395 -7
  181. package/src/scripts/backup-all.js +731 -9
  182. package/src/scripts/backup-source.js +711 -8
  183. package/src/scripts/brewd.js +373 -7
  184. package/src/scripts/brewi.js +505 -9
  185. package/src/scripts/brewr.js +512 -9
  186. package/src/scripts/brews.js +462 -9
  187. package/src/scripts/brewu.js +488 -7
  188. package/src/scripts/c.js +185 -7
  189. package/src/scripts/ccurl.js +325 -8
  190. package/src/scripts/certbot-crontab-init.js +488 -8
  191. package/src/scripts/certbot-init.js +641 -9
  192. package/src/scripts/ch.js +339 -7
  193. package/src/scripts/claude-danger.js +253 -8
  194. package/src/scripts/clean-dev.js +419 -8
  195. package/src/scripts/clear-dns-cache.js +525 -7
  196. package/src/scripts/clone.js +417 -7
  197. package/src/scripts/code-all.js +420 -7
  198. package/src/scripts/count-files.js +195 -8
  199. package/src/scripts/count-folders.js +195 -8
  200. package/src/scripts/count.js +248 -8
  201. package/src/scripts/d.js +203 -7
  202. package/src/scripts/datauri.js +373 -8
  203. package/src/scripts/delete-files.js +363 -7
  204. package/src/scripts/docker-clean.js +410 -8
  205. package/src/scripts/dp.js +426 -7
  206. package/src/scripts/e.js +375 -9
  207. package/src/scripts/empty-trash.js +497 -7
  208. package/src/scripts/evm.js +428 -9
  209. package/src/scripts/fetch-github-repos.js +441 -10
  210. package/src/scripts/get-channel.js +329 -8
  211. package/src/scripts/get-course.js +384 -11
  212. package/src/scripts/get-dependencies.js +290 -9
  213. package/src/scripts/get-folder.js +783 -10
  214. package/src/scripts/get-tunes.js +411 -10
  215. package/src/scripts/get-video.js +352 -9
  216. package/src/scripts/git-backup.js +561 -9
  217. package/src/scripts/git-clone.js +477 -9
  218. package/src/scripts/git-pup.js +303 -7
  219. package/src/scripts/git-push.js +380 -8
  220. package/src/scripts/h.js +607 -9
  221. package/src/scripts/hide-desktop-icons.js +483 -7
  222. package/src/scripts/hide-hidden-files.js +522 -7
  223. package/src/scripts/install-dependencies-from.js +440 -9
  224. package/src/scripts/ips.js +647 -10
  225. package/src/scripts/iso.js +354 -8
  226. package/src/scripts/killni.js +561 -7
  227. package/src/scripts/ll.js +451 -8
  228. package/src/scripts/local-ip.js +310 -8
  229. package/src/scripts/m.js +508 -8
  230. package/src/scripts/map.js +293 -8
  231. package/src/scripts/mkd.js +287 -7
  232. package/src/scripts/ncu-update-all.js +441 -8
  233. package/src/scripts/nginx-init.js +702 -12
  234. package/src/scripts/npmi.js +366 -7
  235. package/src/scripts/o.js +495 -8
  236. package/src/scripts/org-by-date.js +321 -7
  237. package/src/scripts/p.js +208 -7
  238. package/src/scripts/packages.js +313 -8
  239. package/src/scripts/path.js +209 -7
  240. package/src/scripts/ports.js +582 -8
  241. package/src/scripts/q.js +290 -8
  242. package/src/scripts/refresh-files.js +378 -10
  243. package/src/scripts/remove-smaller-files.js +500 -8
  244. package/src/scripts/rename-files-with-date.js +517 -9
  245. package/src/scripts/resize-image.js +523 -9
  246. package/src/scripts/rm-safe.js +653 -8
  247. package/src/scripts/s.js +525 -9
  248. package/src/scripts/set-git-public.js +349 -7
  249. package/src/scripts/show-desktop-icons.js +459 -7
  250. package/src/scripts/show-hidden-files.js +456 -7
  251. package/src/scripts/tpa.js +265 -8
  252. package/src/scripts/tpo.js +264 -7
  253. package/src/scripts/u.js +489 -7
  254. package/src/scripts/vpush.js +422 -8
  255. package/src/scripts/y.js +267 -7
  256. package/src/utils/common/os.js +94 -2
  257. package/src/utils/ubuntu/apt.js +13 -7
  258. package/src/utils/windows/choco.js +82 -26
  259. package/src/utils/windows/winget.js +89 -27
@@ -0,0 +1,346 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * @fileoverview Install lsb-release - the Linux Standard Base release utility.
5
+ *
6
+ * The lsb-release utility provides information about the Linux Standard Base (LSB)
7
+ * and distribution-specific information. It is a command-line tool that displays
8
+ * details about your Linux distribution, including:
9
+ * - Distributor ID (e.g., Ubuntu, Debian, Raspbian)
10
+ * - Description (human-readable description of the distribution)
11
+ * - Release version number
12
+ * - Codename (e.g., jammy, bookworm)
13
+ *
14
+ * IMPORTANT: lsb-release is a Linux-specific utility. It is NOT available on:
15
+ * - macOS (use sw_vers instead)
16
+ * - Windows (use PowerShell Get-ComputerInfo instead)
17
+ * - Amazon Linux 2023 (use /etc/os-release instead)
18
+ * - Git Bash (runs on Windows, not a Linux environment)
19
+ *
20
+ * On supported platforms (Ubuntu, Debian, Raspberry Pi OS, WSL), the package
21
+ * is often pre-installed but may be missing in minimal or container images.
22
+ *
23
+ * @module installs/lsb-release
24
+ */
25
+
26
+ const os = require('../utils/common/os');
27
+ const shell = require('../utils/common/shell');
28
+ const apt = require('../utils/ubuntu/apt');
29
+
30
+ // -----------------------------------------------------------------------------
31
+ // Helper Functions
32
+ // -----------------------------------------------------------------------------
33
+
34
+ /**
35
+ * Checks if the lsb_release command is available in the system PATH.
36
+ *
37
+ * Note: The package name uses a hyphen (lsb-release) but the command uses
38
+ * an underscore (lsb_release). This function checks for the command.
39
+ *
40
+ * @returns {boolean} - True if the lsb_release command exists
41
+ */
42
+ function isLsbReleaseInstalled() {
43
+ return shell.commandExists('lsb_release');
44
+ }
45
+
46
+ // -----------------------------------------------------------------------------
47
+ // Platform-Specific Installation Functions
48
+ // -----------------------------------------------------------------------------
49
+
50
+ /**
51
+ * Install lsb-release on macOS.
52
+ *
53
+ * lsb-release is NOT available on macOS because macOS is not a Linux distribution
54
+ * and does not implement the Linux Standard Base. This function gracefully
55
+ * returns without error, informing the user that the tool is not available.
56
+ *
57
+ * @returns {Promise<void>}
58
+ */
59
+ async function install_macos() {
60
+ // lsb-release is a Linux-only utility and is not available on macOS
61
+ // Return gracefully without throwing an error
62
+ console.log('lsb-release is not available for macOS.');
63
+ return;
64
+ }
65
+
66
+ /**
67
+ * Install lsb-release on Ubuntu/Debian using APT.
68
+ *
69
+ * On most Ubuntu and Debian installations, lsb-release is pre-installed.
70
+ * However, minimal installations or container images may not include it.
71
+ * This function uses APT to install the lsb-release package, which provides
72
+ * the lsb_release command.
73
+ *
74
+ * @returns {Promise<void>}
75
+ */
76
+ async function install_ubuntu() {
77
+ // Check if lsb_release command is already available
78
+ // The command uses an underscore, not a hyphen
79
+ if (isLsbReleaseInstalled()) {
80
+ console.log('lsb-release is already installed, skipping...');
81
+ return;
82
+ }
83
+
84
+ // Update package lists before installing to ensure we get the latest version
85
+ // Using DEBIAN_FRONTEND=noninteractive prevents interactive prompts
86
+ console.log('Updating package lists...');
87
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
88
+ if (updateResult.code !== 0) {
89
+ // Log a warning but continue with installation attempt
90
+ // The package may still install successfully from cached lists
91
+ console.log('Warning: Failed to update package lists. Continuing with installation...');
92
+ }
93
+
94
+ // Install lsb-release using APT
95
+ // The -y flag automatically confirms the installation prompt
96
+ console.log('Installing lsb-release via APT...');
97
+ const installResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get install -y lsb-release');
98
+
99
+ if (installResult.code !== 0) {
100
+ console.log('Failed to install lsb-release via APT.');
101
+ console.log(installResult.stderr || installResult.stdout);
102
+ return;
103
+ }
104
+
105
+ // Verify the installation succeeded by checking if the command now exists
106
+ const verified = isLsbReleaseInstalled();
107
+ if (!verified) {
108
+ console.log('Installation may have failed: lsb_release command not found after install.');
109
+ return;
110
+ }
111
+
112
+ console.log('lsb-release installed successfully.');
113
+ }
114
+
115
+ /**
116
+ * Install lsb-release on Ubuntu running in WSL.
117
+ *
118
+ * WSL runs a real Linux distribution (typically Ubuntu), so lsb-release
119
+ * is available and works exactly as it does on native Ubuntu. The installation
120
+ * process is identical to native Ubuntu using APT.
121
+ *
122
+ * @returns {Promise<void>}
123
+ */
124
+ async function install_ubuntu_wsl() {
125
+ // WSL Ubuntu uses the same APT-based installation as native Ubuntu
126
+ // The lsb-release package works identically in WSL
127
+ await install_ubuntu();
128
+ }
129
+
130
+ /**
131
+ * Install lsb-release on Raspberry Pi OS using APT.
132
+ *
133
+ * Raspberry Pi OS is based on Debian, so lsb-release installation follows
134
+ * the same process as Ubuntu/Debian. On most Raspberry Pi OS installations,
135
+ * lsb-release is pre-installed by default, but this function handles cases
136
+ * where it may be missing.
137
+ *
138
+ * Note: On 64-bit Raspberry Pi OS, the Distributor ID may show "Debian"
139
+ * instead of "Raspbian" - this is expected behavior.
140
+ *
141
+ * @returns {Promise<void>}
142
+ */
143
+ async function install_raspbian() {
144
+ // Check if lsb_release command is already available
145
+ if (isLsbReleaseInstalled()) {
146
+ console.log('lsb-release is already installed, skipping...');
147
+ return;
148
+ }
149
+
150
+ // Update package lists before installing
151
+ console.log('Updating package lists...');
152
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
153
+ if (updateResult.code !== 0) {
154
+ console.log('Warning: Failed to update package lists. Continuing with installation...');
155
+ }
156
+
157
+ // Install lsb-release using APT
158
+ // Installation may take slightly longer on Raspberry Pi due to slower I/O
159
+ console.log('Installing lsb-release via APT...');
160
+ const installResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get install -y lsb-release');
161
+
162
+ if (installResult.code !== 0) {
163
+ console.log('Failed to install lsb-release via APT.');
164
+ console.log(installResult.stderr || installResult.stdout);
165
+ return;
166
+ }
167
+
168
+ // Verify the installation succeeded
169
+ const verified = isLsbReleaseInstalled();
170
+ if (!verified) {
171
+ console.log('Installation may have failed: lsb_release command not found after install.');
172
+ return;
173
+ }
174
+
175
+ console.log('lsb-release installed successfully.');
176
+ }
177
+
178
+ /**
179
+ * Install lsb-release on Amazon Linux.
180
+ *
181
+ * lsb-release is NOT available on Amazon Linux 2023 (AL2023). Amazon Linux
182
+ * has transitioned to the /etc/os-release standard, which is the modern
183
+ * replacement for LSB-based distribution identification. This function
184
+ * gracefully returns without error, informing the user that the tool is
185
+ * not available on this platform.
186
+ *
187
+ * @returns {Promise<void>}
188
+ */
189
+ async function install_amazon_linux() {
190
+ // lsb-release is not available on Amazon Linux 2023
191
+ // Amazon Linux uses /etc/os-release for distribution information instead
192
+ // Return gracefully without throwing an error
193
+ console.log('lsb-release is not available for Amazon Linux.');
194
+ return;
195
+ }
196
+
197
+ /**
198
+ * Install lsb-release on Windows.
199
+ *
200
+ * lsb-release is NOT available on Windows because Windows is not a Linux
201
+ * distribution and does not implement the Linux Standard Base. This function
202
+ * gracefully returns without error, informing the user that the tool is
203
+ * not available on this platform.
204
+ *
205
+ * @returns {Promise<void>}
206
+ */
207
+ async function install_windows() {
208
+ // lsb-release is a Linux-only utility and is not available on Windows
209
+ // Return gracefully without throwing an error
210
+ console.log('lsb-release is not available for Windows.');
211
+ return;
212
+ }
213
+
214
+ /**
215
+ * Install lsb-release on Git Bash.
216
+ *
217
+ * lsb-release is NOT available in Git Bash. Git Bash is a terminal emulator
218
+ * that runs on Windows and provides a Bash shell environment, but it is not
219
+ * a full Linux environment and does not include Linux-specific system utilities
220
+ * like lsb_release. This function gracefully returns without error.
221
+ *
222
+ * @returns {Promise<void>}
223
+ */
224
+ async function install_gitbash() {
225
+ // lsb-release is a Linux-only utility and is not available in Git Bash
226
+ // Git Bash runs on Windows and does not support Linux-specific utilities
227
+ // Return gracefully without throwing an error
228
+ console.log('lsb-release is not available for Git Bash.');
229
+ return;
230
+ }
231
+
232
+ // -----------------------------------------------------------------------------
233
+ // Main Installation Entry Point
234
+ // -----------------------------------------------------------------------------
235
+
236
+ /**
237
+ * Check if lsb-release is installed on the current platform.
238
+ *
239
+ * lsb-release is a Linux-only utility. On supported platforms
240
+ * (Ubuntu, Debian, Raspberry Pi OS, WSL), checks if the lsb_release
241
+ * command exists.
242
+ *
243
+ * @returns {Promise<boolean>} True if installed, false otherwise
244
+ */
245
+ async function isInstalled() {
246
+ const platform = os.detect();
247
+
248
+ // lsb-release is only available on Debian-based Linux distributions
249
+ if (['ubuntu', 'debian', 'wsl', 'raspbian'].includes(platform.type)) {
250
+ return shell.commandExists('lsb_release');
251
+ }
252
+
253
+ // Not applicable for other platforms (macOS, Windows, Amazon Linux, etc.)
254
+ return false;
255
+ }
256
+
257
+ /**
258
+ * Check if this installer is supported on the current platform.
259
+ * lsb-release is a Linux-only utility, only supported on Debian-based distros.
260
+ * @returns {boolean} True if installation is supported on this platform
261
+ */
262
+ function isEligible() {
263
+ const platform = os.detect();
264
+ // lsb-release is only available on Debian-based Linux distributions
265
+ return ['ubuntu', 'debian', 'wsl', 'raspbian'].includes(platform.type);
266
+ }
267
+
268
+ /**
269
+ * Main installation entry point - detects platform and runs appropriate installer.
270
+ *
271
+ * This function automatically detects the current platform using the os.detect()
272
+ * utility and dispatches to the appropriate platform-specific installation function.
273
+ *
274
+ * Supported platforms (where lsb-release can be installed):
275
+ * - Ubuntu/Debian (APT)
276
+ * - Ubuntu on WSL (APT)
277
+ * - Raspberry Pi OS (APT)
278
+ *
279
+ * Unsupported platforms (gracefully returns with informational message):
280
+ * - macOS (not a Linux distribution)
281
+ * - Windows (not a Linux distribution)
282
+ * - Amazon Linux (uses /etc/os-release instead)
283
+ * - Git Bash (runs on Windows, not a Linux environment)
284
+ *
285
+ * @returns {Promise<void>}
286
+ */
287
+ async function install() {
288
+ const platform = os.detect();
289
+
290
+ // Map platform types to their corresponding installer functions
291
+ // Each platform has a dedicated function that either installs lsb-release
292
+ // or returns gracefully with an informational message if not supported
293
+ const installers = {
294
+ 'macos': install_macos,
295
+ 'ubuntu': install_ubuntu,
296
+ 'debian': install_ubuntu,
297
+ 'wsl': install_ubuntu_wsl,
298
+ 'raspbian': install_raspbian,
299
+ 'amazon_linux': install_amazon_linux,
300
+ 'fedora': install_amazon_linux,
301
+ 'rhel': install_amazon_linux,
302
+ 'windows': install_windows,
303
+ 'gitbash': install_gitbash,
304
+ };
305
+
306
+ // Look up the installer for the detected platform
307
+ const installer = installers[platform.type];
308
+
309
+ // If no installer exists for this platform, inform the user gracefully
310
+ // Do not throw an error - just log a message and return
311
+ if (!installer) {
312
+ console.log(`lsb-release is not available for ${platform.type}.`);
313
+ return;
314
+ }
315
+
316
+ // Run the platform-specific installer
317
+ await installer();
318
+ }
319
+
320
+ // -----------------------------------------------------------------------------
321
+ // Module Exports
322
+ // -----------------------------------------------------------------------------
323
+
324
+ module.exports = {
325
+ install,
326
+ isInstalled,
327
+ isEligible,
328
+ install_macos,
329
+ install_ubuntu,
330
+ install_ubuntu_wsl,
331
+ install_raspbian,
332
+ install_amazon_linux,
333
+ install_windows,
334
+ install_gitbash,
335
+ };
336
+
337
+ // -----------------------------------------------------------------------------
338
+ // Direct Execution Handler
339
+ // -----------------------------------------------------------------------------
340
+
341
+ if (require.main === module) {
342
+ install().catch(err => {
343
+ console.error(err.message);
344
+ process.exit(1);
345
+ });
346
+ }