@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
@@ -1,44 +1,356 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Install LFTP.
4
+ * @fileoverview Install LFTP - a sophisticated command-line file transfer program.
5
+ *
6
+ * LFTP supports multiple protocols including FTP, FTPS, HTTP, HTTPS, HFTP, FISH,
7
+ * SFTP, and BitTorrent. Key features include automatic retry and resume, mirror
8
+ * capabilities, segmented transfers, job control, and full scriptability for
9
+ * automation in CI/CD pipelines and scheduled tasks.
10
+ *
5
11
  * @module installs/lftp
6
12
  */
7
13
 
8
14
  const os = require('../utils/common/os');
15
+ const shell = require('../utils/common/shell');
16
+ const brew = require('../utils/macos/brew');
17
+ const apt = require('../utils/ubuntu/apt');
18
+ const choco = require('../utils/windows/choco');
19
+
20
+ /**
21
+ * Install LFTP on macOS using Homebrew.
22
+ *
23
+ * Installs LFTP via Homebrew, which automatically handles all dependencies
24
+ * including libidn2, openssl@3, readline, and gettext.
25
+ *
26
+ * @returns {Promise<void>}
27
+ */
28
+ async function install_macos() {
29
+ // Check if Homebrew is available - it is required for macOS installation
30
+ if (!brew.isInstalled()) {
31
+ console.log('Homebrew is not installed. Please install Homebrew first.');
32
+ console.log('Run: dev install homebrew');
33
+ return;
34
+ }
35
+
36
+ // Check if LFTP is already installed via Homebrew
37
+ const isBrewLftpInstalled = await brew.isFormulaInstalled('lftp');
38
+ if (isBrewLftpInstalled) {
39
+ console.log('LFTP is already installed via Homebrew, skipping...');
40
+ return;
41
+ }
42
+
43
+ // Install LFTP using Homebrew
44
+ // The --quiet flag is handled by brew.install internally if needed
45
+ console.log('Installing LFTP via Homebrew...');
46
+ const result = await brew.install('lftp');
47
+
48
+ if (!result.success) {
49
+ console.log('Failed to install LFTP via Homebrew.');
50
+ console.log(result.output);
51
+ return;
52
+ }
53
+
54
+ // Verify the installation succeeded by checking if the formula is now installed
55
+ const verified = await brew.isFormulaInstalled('lftp');
56
+ if (!verified) {
57
+ console.log('Installation may have failed: LFTP formula not found after install.');
58
+ return;
59
+ }
60
+
61
+ console.log('LFTP installed successfully via Homebrew.');
62
+ }
63
+
64
+ /**
65
+ * Install LFTP on Ubuntu/Debian using APT.
66
+ *
67
+ * LFTP is available in the official Ubuntu and Debian repositories, so no
68
+ * additional repository configuration is required. The installation uses
69
+ * non-interactive mode for automation compatibility.
70
+ *
71
+ * @returns {Promise<void>}
72
+ */
73
+ async function install_ubuntu() {
74
+ // Check if LFTP is already installed by looking for the command
75
+ const isInstalled = shell.commandExists('lftp');
76
+ if (isInstalled) {
77
+ console.log('LFTP is already installed, skipping...');
78
+ return;
79
+ }
80
+
81
+ // Update package lists before installing to ensure we get the latest version
82
+ console.log('Updating package lists...');
83
+ const updateResult = await apt.update();
84
+ if (!updateResult.success) {
85
+ console.log('Warning: Failed to update package lists. Continuing with installation...');
86
+ }
87
+
88
+ // Install LFTP using APT
89
+ // The apt.install function handles sudo and -y flag automatically
90
+ console.log('Installing LFTP via APT...');
91
+ const result = await apt.install('lftp');
92
+
93
+ if (!result.success) {
94
+ console.log('Failed to install LFTP via APT.');
95
+ console.log(result.output);
96
+ return;
97
+ }
98
+
99
+ // Verify the installation succeeded by checking if the command exists
100
+ const verified = shell.commandExists('lftp');
101
+ if (!verified) {
102
+ console.log('Installation may have failed: lftp command not found after install.');
103
+ return;
104
+ }
105
+
106
+ console.log('LFTP installed successfully.');
107
+ }
108
+
109
+ /**
110
+ * Install LFTP on Ubuntu running in WSL.
111
+ *
112
+ * WSL Ubuntu installations follow the same process as native Ubuntu using APT.
113
+ * The installation is identical because WSL provides a full Ubuntu userspace.
114
+ *
115
+ * @returns {Promise<void>}
116
+ */
117
+ async function install_ubuntu_wsl() {
118
+ // WSL Ubuntu uses the same APT-based installation as native Ubuntu
119
+ await install_ubuntu();
120
+ }
121
+
122
+ /**
123
+ * Install LFTP on Raspberry Pi OS using APT.
124
+ *
125
+ * Raspberry Pi OS is based on Debian, so LFTP installation follows the same
126
+ * process as Ubuntu/Debian. The ARM architecture is handled automatically
127
+ * by the package manager.
128
+ *
129
+ * @returns {Promise<void>}
130
+ */
131
+ async function install_raspbian() {
132
+ // Raspberry Pi OS uses the same APT-based installation as Ubuntu/Debian
133
+ await install_ubuntu();
134
+ }
135
+
136
+ /**
137
+ * Install LFTP on Amazon Linux/RHEL using DNF or YUM.
138
+ *
139
+ * LFTP is available in the base repositories for Amazon Linux 2, Amazon Linux
140
+ * 2023, RHEL, CentOS, Rocky Linux, and AlmaLinux. This function detects
141
+ * which package manager (dnf or yum) is available and uses it accordingly.
142
+ *
143
+ * @returns {Promise<void>}
144
+ */
145
+ async function install_amazon_linux() {
146
+ // Check if LFTP is already installed by looking for the command
147
+ const isInstalled = shell.commandExists('lftp');
148
+ if (isInstalled) {
149
+ console.log('LFTP is already installed, skipping...');
150
+ return;
151
+ }
152
+
153
+ // Detect the platform to determine which package manager to use
154
+ // Amazon Linux 2023 uses dnf, Amazon Linux 2 uses yum
155
+ const platform = os.detect();
156
+ const packageManager = platform.packageManager;
157
+
158
+ // Construct the install command based on available package manager
159
+ // The -y flag automatically confirms the installation for non-interactive execution
160
+ const installCommand = packageManager === 'dnf'
161
+ ? 'sudo dnf install -y lftp'
162
+ : 'sudo yum install -y lftp';
163
+
164
+ // Install LFTP
165
+ console.log(`Installing LFTP via ${packageManager}...`);
166
+ const result = await shell.exec(installCommand);
167
+
168
+ if (result.code !== 0) {
169
+ console.log(`Failed to install LFTP via ${packageManager}.`);
170
+ console.log(result.stderr || result.stdout);
171
+ return;
172
+ }
173
+
174
+ // Verify the installation succeeded by checking if the command exists
175
+ const verified = shell.commandExists('lftp');
176
+ if (!verified) {
177
+ console.log('Installation may have failed: lftp command not found after install.');
178
+ return;
179
+ }
180
+
181
+ console.log('LFTP installed successfully.');
182
+ }
183
+
184
+ /**
185
+ * Install LFTP on Windows using Chocolatey.
186
+ *
187
+ * LFTP is not available in winget, so Chocolatey is used. The Chocolatey
188
+ * package provides unofficial Windows builds from the LFTP4WIN project.
189
+ *
190
+ * Note: After installation, users may need to open a new terminal window
191
+ * to pick up PATH changes.
192
+ *
193
+ * @returns {Promise<void>}
194
+ */
195
+ async function install_windows() {
196
+ // Check if Chocolatey is available - it is required for Windows installation
197
+ if (!choco.isInstalled()) {
198
+ console.log('Chocolatey is not installed. Please install Chocolatey first.');
199
+ console.log('Run: dev install chocolatey');
200
+ return;
201
+ }
202
+
203
+ // Check if LFTP is already installed via Chocolatey
204
+ const isChocoLftpInstalled = await choco.isPackageInstalled('lftp');
205
+ if (isChocoLftpInstalled) {
206
+ console.log('LFTP is already installed via Chocolatey, skipping...');
207
+ return;
208
+ }
209
+
210
+ // Install LFTP using Chocolatey
211
+ // The -y flag is handled by choco.install automatically
212
+ console.log('Installing LFTP via Chocolatey...');
213
+ const result = await choco.install('lftp');
214
+
215
+ if (!result.success) {
216
+ console.log('Failed to install LFTP via Chocolatey.');
217
+ console.log(result.output);
218
+ return;
219
+ }
220
+
221
+ // Verify the installation succeeded by checking if the package is now installed
222
+ const verified = await choco.isPackageInstalled('lftp');
223
+ if (!verified) {
224
+ console.log('Installation may have failed: LFTP package not found after install.');
225
+ return;
226
+ }
227
+
228
+ console.log('LFTP installed successfully via Chocolatey.');
229
+ console.log('');
230
+ console.log('Note: You may need to open a new terminal window to use the lftp command.');
231
+ }
232
+
233
+ /**
234
+ * Install LFTP on Git Bash (Windows).
235
+ *
236
+ * LFTP is not natively available in Git Bash because Git Bash uses MinGW.
237
+ * This function informs users that LFTP is not available in Git Bash and
238
+ * returns gracefully without error.
239
+ *
240
+ * @returns {Promise<void>}
241
+ */
242
+ async function install_gitbash() {
243
+ // LFTP is not available in Git Bash - inform the user and return gracefully
244
+ // Note: The documentation mentions LFTP4WIN as a workaround, but per project
245
+ // guidelines we should not suggest alternatives
246
+ console.log('LFTP is not available for Git Bash.');
247
+ return;
248
+ }
9
249
 
10
250
  /**
11
- * Install LFTP across supported platforms.
251
+ * Check if LFTP is installed on the current platform.
252
+ *
253
+ * On macOS, checks if the lftp formula is installed via Homebrew.
254
+ * On Windows, checks if lftp is installed via Chocolatey.
255
+ * On Linux, checks if the lftp command exists.
256
+ *
257
+ * @returns {Promise<boolean>} True if installed, false otherwise
258
+ */
259
+ async function isInstalled() {
260
+ const platform = os.detect();
261
+
262
+ if (platform.type === 'macos') {
263
+ return brew.isFormulaInstalled('lftp');
264
+ }
265
+
266
+ if (platform.type === 'windows') {
267
+ return choco.isPackageInstalled('lftp');
268
+ }
269
+
270
+ // Linux: Check if lftp command exists
271
+ // Git Bash is not supported for LFTP
272
+ if (platform.type === 'gitbash') {
273
+ return false;
274
+ }
275
+
276
+ return shell.commandExists('lftp');
277
+ }
278
+
279
+ /**
280
+ * Check if this installer is supported on the current platform.
281
+ * LFTP is supported on all major platforms except Git Bash.
282
+ * @returns {boolean} True if installation is supported on this platform
283
+ */
284
+ function isEligible() {
285
+ const platform = os.detect();
286
+ // LFTP is NOT available in Git Bash (MinGW environment)
287
+ return ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'fedora', 'rhel', 'windows'].includes(platform.type);
288
+ }
289
+
290
+ /**
291
+ * Main installation entry point - detects platform and runs appropriate installer.
292
+ *
293
+ * This function detects the current operating system and dispatches to the
294
+ * appropriate platform-specific installer function. Supported platforms:
295
+ * - macOS (Homebrew)
296
+ * - Ubuntu/Debian (APT)
297
+ * - Ubuntu on WSL (APT)
298
+ * - Raspberry Pi OS (APT)
299
+ * - Amazon Linux/RHEL (DNF/YUM)
300
+ * - Windows (Chocolatey)
301
+ *
302
+ * Unsupported platforms:
303
+ * - Git Bash (returns gracefully with message)
12
304
  *
13
305
  * @returns {Promise<void>}
14
306
  */
15
307
  async function install() {
16
308
  const platform = os.detect();
17
309
 
18
- switch (platform.type) {
19
- case 'macos':
20
- // TODO: Implement macOS installation
21
- break;
22
- case 'debian':
23
- // TODO: Implement Debian/Ubuntu installation
24
- break;
25
- case 'rhel':
26
- // TODO: Implement RHEL/Amazon Linux installation
27
- break;
28
- case 'windows-wsl':
29
- // TODO: Implement WSL installation
30
- break;
31
- case 'windows':
32
- // TODO: Implement Windows installation
33
- break;
34
- default:
35
- console.error(`Unsupported platform: ${platform.type}`);
36
- process.exit(1);
37
- }
38
- }
39
-
40
- module.exports = { install };
310
+ // Map platform types to their corresponding installer functions
311
+ // Multiple platform types can map to the same installer (e.g., debian and ubuntu)
312
+ const installers = {
313
+ 'macos': install_macos,
314
+ 'ubuntu': install_ubuntu,
315
+ 'debian': install_ubuntu,
316
+ 'wsl': install_ubuntu_wsl,
317
+ 'raspbian': install_raspbian,
318
+ 'amazon_linux': install_amazon_linux,
319
+ 'fedora': install_amazon_linux,
320
+ 'rhel': install_amazon_linux,
321
+ 'windows': install_windows,
322
+ 'gitbash': install_gitbash,
323
+ };
324
+
325
+ // Look up the installer for the detected platform
326
+ const installer = installers[platform.type];
327
+
328
+ // If no installer exists for this platform, inform the user gracefully
329
+ if (!installer) {
330
+ console.log(`LFTP is not available for ${platform.type}.`);
331
+ return;
332
+ }
333
+
334
+ // Run the platform-specific installer
335
+ await installer();
336
+ }
337
+
338
+ module.exports = {
339
+ install,
340
+ isInstalled,
341
+ isEligible,
342
+ install_macos,
343
+ install_ubuntu,
344
+ install_ubuntu_wsl,
345
+ install_raspbian,
346
+ install_amazon_linux,
347
+ install_windows,
348
+ install_gitbash,
349
+ };
41
350
 
42
351
  if (require.main === module) {
43
- install();
352
+ install().catch(err => {
353
+ console.error(err.message);
354
+ process.exit(1);
355
+ });
44
356
  }