@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
@@ -3,42 +3,757 @@
3
3
  /**
4
4
  * @fileoverview Install Zoom.
5
5
  * @module installs/zoom
6
+ *
7
+ * Zoom is a video conferencing and collaboration platform that provides video
8
+ * meetings, webinars, chat, and phone services. It enables teams and individuals
9
+ * to connect through high-quality video and audio across desktop and mobile devices.
10
+ *
11
+ * This installer provides:
12
+ * - Zoom Desktop App for macOS via Homebrew cask
13
+ * - Zoom Desktop App for Windows via Chocolatey
14
+ * - Zoom Desktop App for Ubuntu/Debian via direct .deb download
15
+ * - Zoom Desktop App for Amazon Linux/RHEL via direct RPM download
16
+ * - Instructions for WSL and Git Bash (uses Windows installation)
17
+ *
18
+ * IMPORTANT PLATFORM NOTES:
19
+ * - Raspberry Pi OS: Zoom does not provide native ARM packages. Users should
20
+ * use the Zoom web application at https://zoom.us/wc instead.
21
+ * - Linux requires 64-bit x86_64 architecture - ARM is not supported.
6
22
  */
7
23
 
8
24
  const os = require('../utils/common/os');
25
+ const shell = require('../utils/common/shell');
26
+ const brew = require('../utils/macos/brew');
27
+ const macosApps = require('../utils/macos/apps');
28
+ const apt = require('../utils/ubuntu/apt');
29
+ const choco = require('../utils/windows/choco');
30
+
31
+ /**
32
+ * Indicates whether this installer requires a desktop environment.
33
+ * Zoom is a GUI video conferencing application and requires a display.
34
+ * @type {boolean}
35
+ */
36
+ const REQUIRES_DESKTOP = true;
37
+
38
+ /**
39
+ * The Homebrew cask name for Zoom on macOS.
40
+ * This installs the full desktop application to /Applications.
41
+ */
42
+ const HOMEBREW_CASK_NAME = 'zoom';
43
+
44
+ /**
45
+ * The Chocolatey package name for Zoom on Windows.
46
+ */
47
+ const CHOCO_PACKAGE_NAME = 'zoom';
48
+
49
+ /**
50
+ * The download URL for Zoom's .deb package (Ubuntu/Debian).
51
+ * This downloads the latest 64-bit x86_64 version directly from Zoom.
52
+ */
53
+ const ZOOM_DEB_URL = 'https://zoom.us/client/latest/zoom_amd64.deb';
54
+
55
+ /**
56
+ * The download URL for Zoom's RPM package (Amazon Linux/RHEL).
57
+ * This downloads the latest 64-bit x86_64 version directly from Zoom.
58
+ */
59
+ const ZOOM_RPM_URL = 'https://zoom.us/client/latest/zoom_x86_64.rpm';
60
+
61
+ /**
62
+ * Temporary file path for the downloaded Zoom .deb package.
63
+ */
64
+ const ZOOM_DEB_TEMP_PATH = '/tmp/zoom_amd64.deb';
65
+
66
+ /**
67
+ * Check if Zoom Desktop application is installed on macOS.
68
+ *
69
+ * Looks for zoom.us.app in /Applications or ~/Applications.
70
+ * Zoom uses "zoom.us.app" as its bundle name, not "Zoom.app".
71
+ *
72
+ * @returns {boolean} True if zoom.us.app exists, false otherwise
73
+ */
74
+ function isZoomInstalledMacOS() {
75
+ return macosApps.isAppInstalled('zoom.us');
76
+ }
77
+
78
+ /**
79
+ * Check if the Zoom command is available in PATH on Linux systems.
80
+ *
81
+ * After installation, the 'zoom' command should be available.
82
+ *
83
+ * @returns {boolean} True if zoom command exists, false otherwise
84
+ */
85
+ function isZoomCommandAvailable() {
86
+ return shell.commandExists('zoom');
87
+ }
88
+
89
+ /**
90
+ * Check if Zoom is installed on Linux via dpkg.
91
+ *
92
+ * Queries the dpkg database to see if the 'zoom' package is installed.
93
+ * This is more reliable than checking for the zoom command since the
94
+ * command might not be in PATH in all scenarios.
95
+ *
96
+ * @returns {Promise<boolean>} True if Zoom package is installed, false otherwise
97
+ */
98
+ async function isZoomInstalledDpkg() {
99
+ const result = await shell.exec('dpkg -l | grep -i "^ii.*zoom"');
100
+ return result.code === 0 && result.stdout.trim().length > 0;
101
+ }
102
+
103
+ /**
104
+ * Check if Zoom is installed on RPM-based systems.
105
+ *
106
+ * Queries the rpm database to see if any zoom package is installed.
107
+ *
108
+ * @returns {Promise<boolean>} True if Zoom package is installed, false otherwise
109
+ */
110
+ async function isZoomInstalledRpm() {
111
+ const result = await shell.exec('rpm -qa | grep -i "^zoom"');
112
+ return result.code === 0 && result.stdout.trim().length > 0;
113
+ }
114
+
115
+ /**
116
+ * Install Zoom Desktop on macOS using Homebrew cask.
117
+ *
118
+ * Prerequisites:
119
+ * - macOS 10.15 (Catalina) or later
120
+ * - Homebrew package manager installed
121
+ * - At least 500 MB free disk space
122
+ * - Apple Silicon (M1/M2/M3/M4) or Intel processor
123
+ *
124
+ * The installation uses the Homebrew cask 'zoom' which downloads and installs
125
+ * the Zoom desktop application to /Applications/zoom.us.app.
126
+ *
127
+ * NOTE: After installation, Zoom must be launched manually. On first launch,
128
+ * it will prompt you to sign in or join a meeting.
129
+ *
130
+ * @returns {Promise<void>}
131
+ * @throws {Error} If Homebrew is not installed or installation fails
132
+ */
133
+ async function install_macos() {
134
+ console.log('Checking if Zoom is already installed...');
135
+
136
+ // Check if zoom.us.app already exists in Applications
137
+ if (isZoomInstalledMacOS()) {
138
+ console.log('Zoom is already installed, skipping installation.');
139
+ return;
140
+ }
141
+
142
+ // Also check if the cask is installed via Homebrew
143
+ const caskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
144
+ if (caskInstalled) {
145
+ console.log('Zoom is already installed via Homebrew, skipping installation.');
146
+ return;
147
+ }
148
+
149
+ // Verify Homebrew is available
150
+ if (!brew.isInstalled()) {
151
+ throw new Error(
152
+ 'Homebrew is not installed. Please install Homebrew first using:\n' +
153
+ ' dev install homebrew\n' +
154
+ 'Then retry installing Zoom.'
155
+ );
156
+ }
157
+
158
+ console.log('Installing Zoom via Homebrew...');
159
+
160
+ // Install Zoom cask with quiet flag for cleaner output
161
+ const result = await shell.exec('brew install --quiet --cask zoom');
162
+
163
+ if (result.code !== 0) {
164
+ throw new Error(
165
+ `Failed to install Zoom via Homebrew.\n` +
166
+ `Output: ${result.stderr || result.stdout}\n\n` +
167
+ `Troubleshooting:\n` +
168
+ ` 1. Run 'brew update && brew cleanup' and retry\n` +
169
+ ` 2. Check if macOS version is 10.15 (Catalina) or later\n` +
170
+ ` 3. Try manual installation: brew reinstall --cask zoom`
171
+ );
172
+ }
173
+
174
+ // Verify installation succeeded
175
+ if (!isZoomInstalledMacOS()) {
176
+ throw new Error(
177
+ 'Installation command completed but zoom.us.app was not found in Applications.\n\n' +
178
+ 'Please try:\n' +
179
+ ' 1. Check /Applications for zoom.us.app\n' +
180
+ ' 2. Run: brew reinstall --cask zoom'
181
+ );
182
+ }
183
+
184
+ console.log('Zoom installed successfully.');
185
+ console.log('');
186
+ console.log('To launch Zoom:');
187
+ console.log(' - Open from Applications folder, or');
188
+ console.log(' - Run: open -a "zoom.us"');
189
+ console.log('');
190
+ console.log('On first launch, you will be prompted to sign in or join a meeting.');
191
+ }
192
+
193
+ /**
194
+ * Install Zoom on Ubuntu/Debian by downloading the .deb package.
195
+ *
196
+ * Prerequisites:
197
+ * - Ubuntu 18.04 or later, or Debian 10 (Buster) or later (64-bit x86_64)
198
+ * - sudo privileges
199
+ * - At least 500 MB free disk space
200
+ *
201
+ * IMPORTANT: Zoom only provides 64-bit x86_64 packages for Debian/Ubuntu.
202
+ * ARM-based systems are not supported with native packages.
203
+ *
204
+ * This function:
205
+ * 1. Downloads the latest Zoom .deb package from zoom.us
206
+ * 2. Installs it using apt-get (which handles dependencies)
207
+ * 3. Cleans up the downloaded file
208
+ *
209
+ * @returns {Promise<void>}
210
+ * @throws {Error} If architecture is not supported or installation fails
211
+ */
212
+ async function install_ubuntu() {
213
+ console.log('Checking if Zoom is already installed...');
214
+
215
+ // Check if Zoom is already installed
216
+ const isInstalled = await isZoomInstalledDpkg();
217
+ if (isInstalled) {
218
+ console.log('Zoom is already installed, skipping installation.');
219
+ return;
220
+ }
221
+
222
+ // Also check if zoom command exists (could be installed another way)
223
+ if (isZoomCommandAvailable()) {
224
+ console.log('Zoom is already installed, skipping installation.');
225
+ return;
226
+ }
227
+
228
+ // Verify architecture - Zoom only provides x86_64 packages
229
+ const archResult = await shell.exec('uname -m');
230
+ const arch = archResult.stdout.trim();
231
+ if (arch !== 'x86_64') {
232
+ console.log(`Zoom is not available for ${arch} architecture.`);
233
+ console.log('');
234
+ console.log('Zoom requires 64-bit x86_64 architecture for the native desktop app.');
235
+ console.log('You can use the Zoom web application at https://zoom.us/wc instead.');
236
+ return;
237
+ }
238
+
239
+ console.log('Downloading Zoom .deb package...');
240
+
241
+ // Step 1: Download the Zoom .deb package
242
+ const downloadResult = await shell.exec(
243
+ `wget -q "${ZOOM_DEB_URL}" -O "${ZOOM_DEB_TEMP_PATH}"`
244
+ );
245
+
246
+ if (downloadResult.code !== 0) {
247
+ throw new Error(
248
+ `Failed to download Zoom package.\n` +
249
+ `Output: ${downloadResult.stderr}\n\n` +
250
+ `Troubleshooting:\n` +
251
+ ` 1. Check your internet connection\n` +
252
+ ` 2. Ensure wget is installed: sudo apt-get install -y wget\n` +
253
+ ` 3. Try manual download: wget "${ZOOM_DEB_URL}"`
254
+ );
255
+ }
256
+
257
+ console.log('Updating package lists...');
258
+
259
+ // Update apt package lists first
260
+ const updateResult = await shell.exec(
261
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get update -y'
262
+ );
263
+ if (updateResult.code !== 0) {
264
+ console.log('Warning: apt-get update had issues, continuing with installation...');
265
+ }
266
+
267
+ console.log('Installing Zoom...');
268
+
269
+ // Step 2: Install the .deb package using apt-get (handles dependencies)
270
+ const installResult = await shell.exec(
271
+ `sudo DEBIAN_FRONTEND=noninteractive apt-get install -y "${ZOOM_DEB_TEMP_PATH}"`
272
+ );
273
+
274
+ // Step 3: Clean up the downloaded file regardless of install result
275
+ await shell.exec(`rm -f "${ZOOM_DEB_TEMP_PATH}"`);
276
+
277
+ if (installResult.code !== 0) {
278
+ // Try to fix broken dependencies and retry
279
+ console.log('Attempting to fix dependencies...');
280
+ const fixResult = await shell.exec(
281
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get --fix-broken install -y'
282
+ );
283
+
284
+ if (fixResult.code !== 0) {
285
+ throw new Error(
286
+ `Failed to install Zoom.\n` +
287
+ `Output: ${installResult.stderr}\n\n` +
288
+ `Troubleshooting:\n` +
289
+ ` 1. Run: sudo apt-get --fix-broken install -y\n` +
290
+ ` 2. Install missing dependencies:\n` +
291
+ ` sudo apt-get install -y libgl1-mesa-glx libegl1-mesa libxcb-xtest0 libxcb-xinerama0\n` +
292
+ ` 3. Retry installation`
293
+ );
294
+ }
295
+ }
296
+
297
+ // Verify installation succeeded
298
+ const verifyInstalled = await isZoomInstalledDpkg();
299
+ if (!verifyInstalled && !isZoomCommandAvailable()) {
300
+ throw new Error(
301
+ 'Installation command completed but Zoom was not found.\n\n' +
302
+ 'Please try:\n' +
303
+ ' 1. Run: dpkg -l | grep zoom\n' +
304
+ ' 2. Download manually from https://zoom.us/download'
305
+ );
306
+ }
307
+
308
+ console.log('Zoom installed successfully.');
309
+ console.log('');
310
+ console.log('To launch Zoom:');
311
+ console.log(' - Run: zoom &');
312
+ console.log(' - Or find Zoom in your application menu');
313
+ console.log('');
314
+ console.log('On first launch, you will be prompted to sign in or join a meeting.');
315
+ }
316
+
317
+ /**
318
+ * Install Zoom on Raspberry Pi OS.
319
+ *
320
+ * PLATFORM LIMITATION: Zoom does not provide native ARM packages. The official
321
+ * Zoom desktop application is only available for x86_64 architecture. Raspberry
322
+ * Pi devices use ARM processors, which are not supported.
323
+ *
324
+ * This function gracefully informs the user that Zoom is not available for
325
+ * Raspberry Pi and suggests using the web application instead.
326
+ *
327
+ * @returns {Promise<void>}
328
+ */
329
+ async function install_raspbian() {
330
+ console.log('Zoom is not available for Raspberry Pi OS.');
331
+ return;
332
+ }
9
333
 
10
334
  /**
11
- * Install Zoom across supported platforms.
335
+ * Install Zoom on Amazon Linux/RHEL using DNF/YUM with direct RPM download.
336
+ *
337
+ * Prerequisites:
338
+ * - Amazon Linux 2023, Amazon Linux 2, RHEL 8/9, or Fedora (64-bit x86_64)
339
+ * - sudo privileges
340
+ * - Graphical desktop environment (required for Zoom GUI)
341
+ * - At least 500 MB free disk space
342
+ *
343
+ * IMPORTANT: Amazon Linux EC2 instances typically run headless (no GUI).
344
+ * If you are running a headless server, use the Zoom web application at
345
+ * https://zoom.us/wc or the Zoom API for automation.
346
+ *
347
+ * This function:
348
+ * 1. Imports the Zoom GPG key for package verification
349
+ * 2. Installs Zoom directly from the RPM URL using dnf/yum
350
+ *
351
+ * @returns {Promise<void>}
352
+ * @throws {Error} If installation fails
353
+ */
354
+ async function install_amazon_linux() {
355
+ console.log('Checking if Zoom is already installed...');
356
+
357
+ // Check if Zoom is already installed
358
+ const isInstalled = await isZoomInstalledRpm();
359
+ if (isInstalled) {
360
+ console.log('Zoom is already installed, skipping installation.');
361
+ return;
362
+ }
363
+
364
+ // Also check if zoom command exists (could be installed another way)
365
+ if (isZoomCommandAvailable()) {
366
+ console.log('Zoom is already installed, skipping installation.');
367
+ return;
368
+ }
369
+
370
+ // Verify architecture - Zoom only provides x86_64 packages
371
+ const archResult = await shell.exec('uname -m');
372
+ const arch = archResult.stdout.trim();
373
+ if (arch !== 'x86_64') {
374
+ console.log(`Zoom is not available for ${arch} architecture.`);
375
+ console.log('');
376
+ console.log('Zoom requires 64-bit x86_64 architecture for the native desktop app.');
377
+ console.log('You can use the Zoom web application at https://zoom.us/wc instead.');
378
+ return;
379
+ }
380
+
381
+ // Detect package manager (dnf for AL2023/RHEL8+, yum for AL2)
382
+ const hasDnf = shell.commandExists('dnf');
383
+ const hasYum = shell.commandExists('yum');
384
+ const packageManager = hasDnf ? 'dnf' : (hasYum ? 'yum' : null);
385
+
386
+ if (!packageManager) {
387
+ throw new Error(
388
+ 'Neither dnf nor yum package manager found.\n' +
389
+ 'This installer supports Amazon Linux 2023 (dnf) and Amazon Linux 2 (yum).'
390
+ );
391
+ }
392
+
393
+ console.log(`Detected package manager: ${packageManager}`);
394
+
395
+ // Step 1: Import the Zoom GPG key for package verification
396
+ console.log('Importing Zoom GPG key...');
397
+ const gpgResult = await shell.exec(
398
+ 'sudo rpm --import "https://zoom.us/linux/download/pubkey?version=6-3-10"'
399
+ );
400
+ if (gpgResult.code !== 0) {
401
+ // GPG key import failure is not always fatal - continue with installation
402
+ console.log('Warning: Could not import GPG key. Continuing with installation...');
403
+ }
404
+
405
+ // Step 2: Install Zoom directly from the RPM URL
406
+ console.log('Installing Zoom...');
407
+ console.log('This may take a few minutes...');
408
+
409
+ const installResult = await shell.exec(
410
+ `sudo ${packageManager} install -y "${ZOOM_RPM_URL}"`
411
+ );
412
+
413
+ if (installResult.code !== 0) {
414
+ throw new Error(
415
+ `Failed to install Zoom.\n` +
416
+ `Output: ${installResult.stderr}\n\n` +
417
+ `Troubleshooting:\n` +
418
+ ` 1. Update system packages: sudo ${packageManager} update -y\n` +
419
+ ` 2. Retry: sudo ${packageManager} install -y ${ZOOM_RPM_URL}\n` +
420
+ ` 3. Check network connectivity`
421
+ );
422
+ }
423
+
424
+ // Verify installation succeeded
425
+ const verifyInstalled = await isZoomInstalledRpm();
426
+ if (!verifyInstalled && !isZoomCommandAvailable()) {
427
+ throw new Error(
428
+ 'Installation command completed but Zoom was not found.\n\n' +
429
+ 'Please try:\n' +
430
+ ' 1. Run: rpm -qa | grep zoom\n' +
431
+ ' 2. Download manually from https://zoom.us/download'
432
+ );
433
+ }
434
+
435
+ console.log('Zoom installed successfully.');
436
+ console.log('');
437
+ console.log('To launch Zoom:');
438
+ console.log(' - Run: zoom &');
439
+ console.log(' - Or find Zoom in your application menu');
440
+ console.log('');
441
+ console.log('NOTE: Zoom requires a graphical desktop environment.');
442
+ console.log('If running on a headless server, use the web application at:');
443
+ console.log(' https://zoom.us/wc');
444
+ }
445
+
446
+ /**
447
+ * Install Zoom on Windows using Chocolatey.
448
+ *
449
+ * Prerequisites:
450
+ * - Windows 10 version 1903 or later, or Windows 11 (64-bit)
451
+ * - At least 500 MB free disk space
452
+ * - Administrator PowerShell or Command Prompt
453
+ * - Chocolatey package manager installed
454
+ *
455
+ * The installation uses Chocolatey's 'zoom' package which downloads and
456
+ * installs the official Zoom desktop application.
457
+ *
458
+ * NOTE: After installation, Zoom can be launched from the Start Menu or
459
+ * via the 'zoom' command.
460
+ *
461
+ * @returns {Promise<void>}
462
+ * @throws {Error} If Chocolatey is not installed or installation fails
463
+ */
464
+ async function install_windows() {
465
+ console.log('Checking if Zoom is already installed...');
466
+
467
+ // Check if Zoom is already installed via Chocolatey
468
+ const isInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
469
+ if (isInstalled) {
470
+ console.log('Zoom is already installed, skipping installation.');
471
+ return;
472
+ }
473
+
474
+ // Verify Chocolatey is available
475
+ if (!choco.isInstalled()) {
476
+ throw new Error(
477
+ 'Chocolatey is not installed. Please install Chocolatey first:\n\n' +
478
+ 'Run the following in an Administrator PowerShell:\n' +
479
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
480
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
481
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
482
+ 'Then retry installing Zoom.'
483
+ );
484
+ }
485
+
486
+ console.log('Installing Zoom via Chocolatey...');
487
+ console.log('This may take a few minutes...');
488
+
489
+ // Install Zoom
490
+ const result = await choco.install(CHOCO_PACKAGE_NAME);
491
+
492
+ if (!result.success) {
493
+ throw new Error(
494
+ `Failed to install Zoom via Chocolatey.\n` +
495
+ `Output: ${result.output}\n\n` +
496
+ `Troubleshooting:\n` +
497
+ ` 1. Ensure you are running as Administrator\n` +
498
+ ` 2. Run 'choco list zoom' to check availability\n` +
499
+ ` 3. Try manual installation: choco install zoom -y --force`
500
+ );
501
+ }
502
+
503
+ // Verify installation
504
+ const verifyInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
505
+ if (!verifyInstalled) {
506
+ throw new Error(
507
+ 'Installation command completed but Zoom was not found.\n\n' +
508
+ 'Please try:\n' +
509
+ ' 1. Run: choco list zoom\n' +
510
+ ' 2. Retry: choco install zoom -y'
511
+ );
512
+ }
513
+
514
+ console.log('Zoom installed successfully.');
515
+ console.log('');
516
+ console.log('To launch Zoom:');
517
+ console.log(' - Open from Start Menu, or');
518
+ console.log(' - Run: Start-Process zoom');
519
+ console.log('');
520
+ console.log('On first launch, you will be prompted to sign in or join a meeting.');
521
+ }
522
+
523
+ /**
524
+ * Install Zoom when running from Ubuntu on WSL (Windows Subsystem for Linux).
525
+ *
526
+ * PLATFORM APPROACH: Zoom is installed on the Windows host and accessed from
527
+ * WSL. While WSL with WSLg can technically run Linux GUI applications, the
528
+ * recommended approach is to install Zoom on Windows and launch it from WSL
529
+ * using Windows interoperability.
530
+ *
531
+ * Prerequisites:
532
+ * - Windows 10 version 2004 or higher, or Windows 11
533
+ * - WSL 2 enabled with Ubuntu distribution installed
534
+ * - Chocolatey installed on Windows for Zoom installation
535
+ *
536
+ * This function installs Zoom on the Windows host via PowerShell/Chocolatey.
537
+ *
538
+ * @returns {Promise<void>}
539
+ * @throws {Error} If installation on Windows host fails
540
+ */
541
+ async function install_ubuntu_wsl() {
542
+ console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
543
+ console.log('');
544
+ console.log('Installing Zoom on the Windows host...');
545
+ console.log('');
546
+
547
+ // Check if Zoom is already available on Windows (via Chocolatey)
548
+ const slackCheck = await shell.exec('cmd.exe /c "choco list zoom --local-only" 2>/dev/null');
549
+ if (slackCheck.code === 0 && slackCheck.stdout.toLowerCase().includes('zoom')) {
550
+ console.log('Zoom is already installed on Windows, skipping installation.');
551
+ console.log('');
552
+ console.log('To launch Zoom from WSL:');
553
+ console.log(' cmd.exe /c start zoom');
554
+ return;
555
+ }
556
+
557
+ console.log('Installing Zoom via Chocolatey on Windows...');
558
+ console.log('This may take a few minutes...');
559
+
560
+ // Install via PowerShell using Chocolatey
561
+ const installResult = await shell.exec(
562
+ 'powershell.exe -NoProfile -Command "choco install zoom -y"'
563
+ );
564
+
565
+ if (installResult.code !== 0) {
566
+ throw new Error(
567
+ `Failed to install Zoom on Windows host.\n` +
568
+ `Output: ${installResult.stdout || installResult.stderr}\n\n` +
569
+ `Troubleshooting:\n` +
570
+ ` 1. Ensure Chocolatey is installed on Windows\n` +
571
+ ` 2. Open an Administrator PowerShell on Windows and run:\n` +
572
+ ` choco install zoom -y\n` +
573
+ ` 3. Then launch from WSL with: cmd.exe /c start zoom`
574
+ );
575
+ }
576
+
577
+ console.log('Zoom installed successfully on Windows.');
578
+ console.log('');
579
+ console.log('To launch Zoom from WSL:');
580
+ console.log(' cmd.exe /c start zoom');
581
+ console.log('');
582
+ console.log('Alternative - open Zoom web in browser:');
583
+ console.log(' cmd.exe /c start https://zoom.us/wc');
584
+ console.log('');
585
+ console.log('TIP: Add an alias to ~/.bashrc for convenience:');
586
+ console.log(' echo \'alias zoom="cmd.exe /c start zoom"\' >> ~/.bashrc');
587
+ }
588
+
589
+ /**
590
+ * Install Zoom from Git Bash on Windows.
591
+ *
592
+ * Git Bash runs within Windows, so this function installs Zoom on the
593
+ * Windows host using Chocolatey via PowerShell interop.
594
+ *
595
+ * Prerequisites:
596
+ * - Windows 10 or Windows 11 (64-bit)
597
+ * - Git Bash installed (comes with Git for Windows)
598
+ * - Chocolatey package manager installed on Windows
599
+ * - Administrator privileges
600
+ *
601
+ * @returns {Promise<void>}
602
+ * @throws {Error} If installation fails
603
+ */
604
+ async function install_gitbash() {
605
+ console.log('Detected Git Bash on Windows.');
606
+ console.log('Installing Zoom on the Windows host...');
607
+ console.log('');
608
+
609
+ // Check if Zoom is already installed
610
+ const zoomCheck = await shell.exec('choco list zoom --local-only 2>/dev/null');
611
+ if (zoomCheck.code === 0 && zoomCheck.stdout.toLowerCase().includes('zoom')) {
612
+ console.log('Zoom is already installed, skipping installation.');
613
+ console.log('');
614
+ console.log('To launch Zoom:');
615
+ console.log(' start zoom');
616
+ return;
617
+ }
618
+
619
+ console.log('Installing Zoom via Chocolatey...');
620
+ console.log('This may take a few minutes...');
621
+
622
+ // Install via PowerShell using Chocolatey
623
+ const installResult = await shell.exec(
624
+ 'powershell.exe -NoProfile -Command "choco install zoom -y"'
625
+ );
626
+
627
+ if (installResult.code !== 0) {
628
+ throw new Error(
629
+ `Failed to install Zoom.\n` +
630
+ `Output: ${installResult.stdout || installResult.stderr}\n\n` +
631
+ `Troubleshooting:\n` +
632
+ ` 1. Ensure Chocolatey is installed on Windows\n` +
633
+ ` 2. Run Git Bash as Administrator and retry\n` +
634
+ ` 3. Try installing directly from PowerShell:\n` +
635
+ ` choco install zoom -y`
636
+ );
637
+ }
638
+
639
+ console.log('Zoom installed successfully.');
640
+ console.log('');
641
+ console.log('To launch Zoom from Git Bash:');
642
+ console.log(' start zoom');
643
+ console.log('');
644
+ console.log('Or use the explicit Windows command:');
645
+ console.log(' cmd //c "start zoom"');
646
+ }
647
+
648
+ /**
649
+ * Check if Zoom is installed on the current system.
650
+ * @returns {Promise<boolean>} True if Zoom is installed
651
+ */
652
+ async function isInstalled() {
653
+ const platform = os.detect();
654
+ if (platform.type === 'macos') {
655
+ return isZoomInstalledMacOS();
656
+ }
657
+ if (platform.type === 'windows') {
658
+ return choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
659
+ }
660
+ if (['ubuntu', 'debian'].includes(platform.type)) {
661
+ return isZoomInstalledDpkg();
662
+ }
663
+ if (['amazon_linux', 'fedora', 'rhel'].includes(platform.type)) {
664
+ return isZoomInstalledRpm();
665
+ }
666
+ return isZoomCommandAvailable();
667
+ }
668
+
669
+ /**
670
+ * Check if this installer is supported on the current platform.
671
+ * Zoom is supported on all major platforms except Raspberry Pi OS
672
+ * (ARM architecture not supported by Zoom).
673
+ * @returns {boolean} True if installation is supported on this platform
674
+ */
675
+ function isEligible() {
676
+ const platform = os.detect();
677
+
678
+ // First check if the platform is supported
679
+ const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'amazon_linux', 'fedora', 'rhel', 'windows', 'gitbash'];
680
+ if (!supportedPlatforms.includes(platform.type)) {
681
+ return false;
682
+ }
683
+
684
+ // This installer requires a desktop environment
685
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
686
+ return false;
687
+ }
688
+
689
+ return true;
690
+ }
691
+
692
+ /**
693
+ * Main installation entry point.
694
+ *
695
+ * Detects the current platform and runs the appropriate installer function.
696
+ * Handles platform-specific mappings to ensure all supported platforms
697
+ * have appropriate installation logic.
698
+ *
699
+ * Supported platforms:
700
+ * - macOS: Zoom Desktop via Homebrew cask
701
+ * - Ubuntu/Debian: Zoom Desktop via .deb package download (x86_64 only)
702
+ * - Raspberry Pi OS: Not supported (graceful message)
703
+ * - Amazon Linux/RHEL: Zoom Desktop via RPM download (x86_64 only)
704
+ * - Windows: Zoom Desktop via Chocolatey
705
+ * - WSL (Ubuntu): Installs Zoom on Windows host
706
+ * - Git Bash: Installs Zoom on Windows host
12
707
  *
13
708
  * @returns {Promise<void>}
14
709
  */
15
710
  async function install() {
16
711
  const platform = os.detect();
17
712
 
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 };
713
+ // Map platform types to their installer functions
714
+ // This mapping handles aliases and variations
715
+ const installers = {
716
+ 'macos': install_macos,
717
+ 'ubuntu': install_ubuntu,
718
+ 'debian': install_ubuntu,
719
+ 'wsl': install_ubuntu_wsl,
720
+ 'raspbian': install_raspbian,
721
+ 'amazon_linux': install_amazon_linux,
722
+ 'rhel': install_amazon_linux,
723
+ 'fedora': install_amazon_linux,
724
+ 'windows': install_windows,
725
+ 'gitbash': install_gitbash
726
+ };
727
+
728
+ const installer = installers[platform.type];
729
+
730
+ if (!installer) {
731
+ console.log(`Zoom is not available for ${platform.type}.`);
732
+ return;
733
+ }
734
+
735
+ await installer();
736
+ }
737
+
738
+ // Export all functions for use as a module and for testing
739
+ module.exports = {
740
+ REQUIRES_DESKTOP,
741
+ install,
742
+ isInstalled,
743
+ isEligible,
744
+ install_macos,
745
+ install_ubuntu,
746
+ install_ubuntu_wsl,
747
+ install_raspbian,
748
+ install_amazon_linux,
749
+ install_windows,
750
+ install_gitbash
751
+ };
41
752
 
753
+ // Allow direct execution: node zoom.js
42
754
  if (require.main === module) {
43
- install();
755
+ install().catch(err => {
756
+ console.error(err.message);
757
+ process.exit(1);
758
+ });
44
759
  }