@fredlackey/devutils 0.0.17 → 0.0.19

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 (331) hide show
  1. package/README.md +32 -150
  2. package/package.json +5 -82
  3. package/bin/dev.js +0 -16
  4. package/files/README.md +0 -0
  5. package/files/claude/.claude/commands/setup-context.md +0 -3
  6. package/files/monorepos/_archive/README.md +0 -36
  7. package/files/monorepos/_legacy/README.md +0 -36
  8. package/files/monorepos/ai-docs/README.md +0 -33
  9. package/files/monorepos/apps/README.md +0 -24
  10. package/files/monorepos/docs/README.md +0 -40
  11. package/files/monorepos/packages/README.md +0 -25
  12. package/files/monorepos/research/README.md +0 -29
  13. package/files/monorepos/scripts/README.md +0 -24
  14. package/src/cli.js +0 -72
  15. package/src/commands/README.md +0 -41
  16. package/src/commands/configure.js +0 -199
  17. package/src/commands/identity.js +0 -1630
  18. package/src/commands/ignore.js +0 -247
  19. package/src/commands/install.js +0 -526
  20. package/src/commands/setup.js +0 -246
  21. package/src/commands/status.js +0 -223
  22. package/src/commands/update.js +0 -142
  23. package/src/commands/version.js +0 -100
  24. package/src/completion.js +0 -284
  25. package/src/constants.js +0 -45
  26. package/src/ignore/claude-code.txt +0 -10
  27. package/src/ignore/docker.txt +0 -18
  28. package/src/ignore/linux.txt +0 -23
  29. package/src/ignore/macos.txt +0 -36
  30. package/src/ignore/node.txt +0 -55
  31. package/src/ignore/terraform.txt +0 -37
  32. package/src/ignore/vscode.txt +0 -18
  33. package/src/ignore/windows.txt +0 -35
  34. package/src/index.js +0 -0
  35. package/src/installs/README.md +0 -399
  36. package/src/installs/adobe-creative-cloud.js +0 -546
  37. package/src/installs/adobe-creative-cloud.md +0 -605
  38. package/src/installs/appcleaner.js +0 -321
  39. package/src/installs/appcleaner.md +0 -699
  40. package/src/installs/apt-transport-https.js +0 -390
  41. package/src/installs/apt-transport-https.md +0 -678
  42. package/src/installs/atomicparsley.js +0 -642
  43. package/src/installs/atomicparsley.md +0 -795
  44. package/src/installs/aws-cli.js +0 -797
  45. package/src/installs/aws-cli.md +0 -727
  46. package/src/installs/balena-etcher.js +0 -710
  47. package/src/installs/balena-etcher.md +0 -761
  48. package/src/installs/bambu-studio.js +0 -1143
  49. package/src/installs/bambu-studio.md +0 -780
  50. package/src/installs/bash-completion.js +0 -575
  51. package/src/installs/bash-completion.md +0 -833
  52. package/src/installs/bash.js +0 -417
  53. package/src/installs/bash.md +0 -993
  54. package/src/installs/beyond-compare.js +0 -603
  55. package/src/installs/beyond-compare.md +0 -813
  56. package/src/installs/brave-browser.js +0 -968
  57. package/src/installs/brave-browser.md +0 -650
  58. package/src/installs/build-essential.js +0 -529
  59. package/src/installs/build-essential.md +0 -977
  60. package/src/installs/ca-certificates.js +0 -618
  61. package/src/installs/ca-certificates.md +0 -937
  62. package/src/installs/caffeine.js +0 -508
  63. package/src/installs/caffeine.md +0 -839
  64. package/src/installs/camtasia.js +0 -596
  65. package/src/installs/camtasia.md +0 -762
  66. package/src/installs/chatgpt.js +0 -476
  67. package/src/installs/chatgpt.md +0 -814
  68. package/src/installs/chocolatey.js +0 -456
  69. package/src/installs/chocolatey.md +0 -661
  70. package/src/installs/chrome-canary.js +0 -419
  71. package/src/installs/chrome-canary.md +0 -641
  72. package/src/installs/chromium.js +0 -667
  73. package/src/installs/chromium.md +0 -838
  74. package/src/installs/claude-code.js +0 -576
  75. package/src/installs/claude-code.md +0 -1173
  76. package/src/installs/cloudflare-warp.js +0 -900
  77. package/src/installs/cloudflare-warp.md +0 -1047
  78. package/src/installs/comet-browser.js +0 -588
  79. package/src/installs/comet-browser.md +0 -731
  80. package/src/installs/curl.js +0 -379
  81. package/src/installs/curl.md +0 -714
  82. package/src/installs/cursor.js +0 -579
  83. package/src/installs/cursor.md +0 -970
  84. package/src/installs/dbeaver.js +0 -924
  85. package/src/installs/dbeaver.md +0 -939
  86. package/src/installs/dbschema.js +0 -692
  87. package/src/installs/dbschema.md +0 -925
  88. package/src/installs/dependencies.md +0 -453
  89. package/src/installs/development-tools.js +0 -600
  90. package/src/installs/development-tools.md +0 -977
  91. package/src/installs/docker.js +0 -1029
  92. package/src/installs/docker.md +0 -1109
  93. package/src/installs/drawio.js +0 -1019
  94. package/src/installs/drawio.md +0 -795
  95. package/src/installs/elmedia-player.js +0 -347
  96. package/src/installs/elmedia-player.md +0 -556
  97. package/src/installs/ffmpeg.js +0 -889
  98. package/src/installs/ffmpeg.md +0 -852
  99. package/src/installs/file.js +0 -464
  100. package/src/installs/file.md +0 -987
  101. package/src/installs/gemini-cli.js +0 -811
  102. package/src/installs/gemini-cli.md +0 -1153
  103. package/src/installs/git.js +0 -400
  104. package/src/installs/git.md +0 -907
  105. package/src/installs/gitego.js +0 -949
  106. package/src/installs/gitego.md +0 -1172
  107. package/src/installs/go.js +0 -931
  108. package/src/installs/go.md +0 -958
  109. package/src/installs/google-antigravity.js +0 -913
  110. package/src/installs/google-antigravity.md +0 -1075
  111. package/src/installs/google-chrome.js +0 -833
  112. package/src/installs/google-chrome.md +0 -862
  113. package/src/installs/gpg.js +0 -480
  114. package/src/installs/gpg.md +0 -1056
  115. package/src/installs/homebrew.js +0 -1033
  116. package/src/installs/homebrew.md +0 -988
  117. package/src/installs/imageoptim.js +0 -968
  118. package/src/installs/imageoptim.md +0 -1119
  119. package/src/installs/installers.json +0 -4032
  120. package/src/installs/installers.json.tmp +0 -3953
  121. package/src/installs/jq.js +0 -400
  122. package/src/installs/jq.md +0 -809
  123. package/src/installs/keyboard-maestro.js +0 -719
  124. package/src/installs/keyboard-maestro.md +0 -825
  125. package/src/installs/kiro.js +0 -864
  126. package/src/installs/kiro.md +0 -1015
  127. package/src/installs/latex.js +0 -789
  128. package/src/installs/latex.md +0 -1095
  129. package/src/installs/lftp.js +0 -356
  130. package/src/installs/lftp.md +0 -907
  131. package/src/installs/lsb-release.js +0 -346
  132. package/src/installs/lsb-release.md +0 -814
  133. package/src/installs/messenger.js +0 -847
  134. package/src/installs/messenger.md +0 -900
  135. package/src/installs/microsoft-office.js +0 -568
  136. package/src/installs/microsoft-office.md +0 -760
  137. package/src/installs/microsoft-teams.js +0 -801
  138. package/src/installs/microsoft-teams.md +0 -886
  139. package/src/installs/moom.js +0 -326
  140. package/src/installs/moom.md +0 -570
  141. package/src/installs/node.js +0 -904
  142. package/src/installs/node.md +0 -1153
  143. package/src/installs/nordpass.js +0 -716
  144. package/src/installs/nordpass.md +0 -921
  145. package/src/installs/nordvpn.js +0 -892
  146. package/src/installs/nordvpn.md +0 -1052
  147. package/src/installs/nvm.js +0 -995
  148. package/src/installs/nvm.md +0 -1057
  149. package/src/installs/ohmyzsh.js +0 -529
  150. package/src/installs/ohmyzsh.md +0 -1094
  151. package/src/installs/openssh.js +0 -804
  152. package/src/installs/openssh.md +0 -1056
  153. package/src/installs/pandoc.js +0 -662
  154. package/src/installs/pandoc.md +0 -1036
  155. package/src/installs/parallels-desktop.js +0 -431
  156. package/src/installs/parallels-desktop.md +0 -446
  157. package/src/installs/pinentry.js +0 -510
  158. package/src/installs/pinentry.md +0 -1142
  159. package/src/installs/pngyu.js +0 -869
  160. package/src/installs/pngyu.md +0 -896
  161. package/src/installs/postman.js +0 -799
  162. package/src/installs/postman.md +0 -940
  163. package/src/installs/procps.js +0 -425
  164. package/src/installs/procps.md +0 -851
  165. package/src/installs/safari-tech-preview.js +0 -374
  166. package/src/installs/safari-tech-preview.md +0 -533
  167. package/src/installs/sfnt2woff.js +0 -658
  168. package/src/installs/sfnt2woff.md +0 -795
  169. package/src/installs/shellcheck.js +0 -481
  170. package/src/installs/shellcheck.md +0 -1005
  171. package/src/installs/slack.js +0 -741
  172. package/src/installs/slack.md +0 -865
  173. package/src/installs/snagit.js +0 -585
  174. package/src/installs/snagit.md +0 -844
  175. package/src/installs/software-properties-common.js +0 -372
  176. package/src/installs/software-properties-common.md +0 -805
  177. package/src/installs/spotify.js +0 -877
  178. package/src/installs/spotify.md +0 -901
  179. package/src/installs/studio-3t.js +0 -823
  180. package/src/installs/studio-3t.md +0 -918
  181. package/src/installs/sublime-text.js +0 -804
  182. package/src/installs/sublime-text.md +0 -914
  183. package/src/installs/superwhisper.js +0 -706
  184. package/src/installs/superwhisper.md +0 -630
  185. package/src/installs/tailscale.js +0 -745
  186. package/src/installs/tailscale.md +0 -1100
  187. package/src/installs/tar.js +0 -389
  188. package/src/installs/tar.md +0 -946
  189. package/src/installs/termius.js +0 -798
  190. package/src/installs/termius.md +0 -844
  191. package/src/installs/terraform.js +0 -779
  192. package/src/installs/terraform.md +0 -899
  193. package/src/installs/tfenv.js +0 -778
  194. package/src/installs/tfenv.md +0 -1091
  195. package/src/installs/tidal.js +0 -771
  196. package/src/installs/tidal.md +0 -864
  197. package/src/installs/tmux.js +0 -346
  198. package/src/installs/tmux.md +0 -1030
  199. package/src/installs/tree.js +0 -411
  200. package/src/installs/tree.md +0 -833
  201. package/src/installs/unzip.js +0 -460
  202. package/src/installs/unzip.md +0 -879
  203. package/src/installs/vim.js +0 -421
  204. package/src/installs/vim.md +0 -1040
  205. package/src/installs/vlc.js +0 -821
  206. package/src/installs/vlc.md +0 -927
  207. package/src/installs/vscode.js +0 -843
  208. package/src/installs/vscode.md +0 -1002
  209. package/src/installs/wget.js +0 -420
  210. package/src/installs/wget.md +0 -791
  211. package/src/installs/whatsapp.js +0 -729
  212. package/src/installs/whatsapp.md +0 -854
  213. package/src/installs/winpty.js +0 -352
  214. package/src/installs/winpty.md +0 -620
  215. package/src/installs/woff2.js +0 -553
  216. package/src/installs/woff2.md +0 -977
  217. package/src/installs/wsl.js +0 -572
  218. package/src/installs/wsl.md +0 -699
  219. package/src/installs/xcode-clt.js +0 -520
  220. package/src/installs/xcode-clt.md +0 -351
  221. package/src/installs/xcode.js +0 -560
  222. package/src/installs/xcode.md +0 -573
  223. package/src/installs/yarn.js +0 -824
  224. package/src/installs/yarn.md +0 -1074
  225. package/src/installs/yq.js +0 -654
  226. package/src/installs/yq.md +0 -944
  227. package/src/installs/yt-dlp.js +0 -701
  228. package/src/installs/yt-dlp.md +0 -946
  229. package/src/installs/yum-utils.js +0 -297
  230. package/src/installs/yum-utils.md +0 -648
  231. package/src/installs/zoom.js +0 -759
  232. package/src/installs/zoom.md +0 -884
  233. package/src/installs/zsh.js +0 -455
  234. package/src/installs/zsh.md +0 -1008
  235. package/src/scripts/README.md +0 -617
  236. package/src/scripts/STATUS.md +0 -208
  237. package/src/scripts/afk.js +0 -411
  238. package/src/scripts/backup-all.js +0 -746
  239. package/src/scripts/backup-source.js +0 -727
  240. package/src/scripts/brewd.js +0 -389
  241. package/src/scripts/brewi.js +0 -520
  242. package/src/scripts/brewr.js +0 -527
  243. package/src/scripts/brews.js +0 -477
  244. package/src/scripts/brewu.js +0 -504
  245. package/src/scripts/c.js +0 -201
  246. package/src/scripts/ccurl.js +0 -341
  247. package/src/scripts/certbot-crontab-init.js +0 -504
  248. package/src/scripts/certbot-init.js +0 -657
  249. package/src/scripts/ch.js +0 -355
  250. package/src/scripts/claude-danger.js +0 -268
  251. package/src/scripts/clean-dev.js +0 -435
  252. package/src/scripts/clear-dns-cache.js +0 -541
  253. package/src/scripts/clone.js +0 -435
  254. package/src/scripts/code-all.js +0 -437
  255. package/src/scripts/count-files.js +0 -211
  256. package/src/scripts/count-folders.js +0 -211
  257. package/src/scripts/count.js +0 -264
  258. package/src/scripts/d.js +0 -219
  259. package/src/scripts/datauri.js +0 -389
  260. package/src/scripts/delete-files.js +0 -380
  261. package/src/scripts/docker-clean.js +0 -426
  262. package/src/scripts/dp.js +0 -442
  263. package/src/scripts/e.js +0 -390
  264. package/src/scripts/empty-trash.js +0 -513
  265. package/src/scripts/evm.js +0 -444
  266. package/src/scripts/fetch-github-repos.js +0 -456
  267. package/src/scripts/get-channel.js +0 -345
  268. package/src/scripts/get-course.js +0 -399
  269. package/src/scripts/get-dependencies.js +0 -306
  270. package/src/scripts/get-folder.js +0 -799
  271. package/src/scripts/get-tunes.js +0 -426
  272. package/src/scripts/get-video.js +0 -367
  273. package/src/scripts/git-backup.js +0 -577
  274. package/src/scripts/git-clone.js +0 -493
  275. package/src/scripts/git-pup.js +0 -319
  276. package/src/scripts/git-push.js +0 -396
  277. package/src/scripts/h.js +0 -622
  278. package/src/scripts/hide-desktop-icons.js +0 -499
  279. package/src/scripts/hide-hidden-files.js +0 -538
  280. package/src/scripts/install-dependencies-from.js +0 -456
  281. package/src/scripts/ips.js +0 -663
  282. package/src/scripts/iso.js +0 -370
  283. package/src/scripts/killni.js +0 -577
  284. package/src/scripts/ll.js +0 -467
  285. package/src/scripts/local-ip.js +0 -325
  286. package/src/scripts/m.js +0 -524
  287. package/src/scripts/map.js +0 -309
  288. package/src/scripts/mkd.js +0 -351
  289. package/src/scripts/ncu-update-all.js +0 -457
  290. package/src/scripts/nginx-init.js +0 -718
  291. package/src/scripts/npmi.js +0 -382
  292. package/src/scripts/o.js +0 -511
  293. package/src/scripts/org-by-date.js +0 -338
  294. package/src/scripts/p.js +0 -224
  295. package/src/scripts/packages.js +0 -330
  296. package/src/scripts/path.js +0 -225
  297. package/src/scripts/ports.js +0 -597
  298. package/src/scripts/q.js +0 -305
  299. package/src/scripts/refresh-files.js +0 -394
  300. package/src/scripts/remove-smaller-files.js +0 -516
  301. package/src/scripts/rename-files-with-date.js +0 -533
  302. package/src/scripts/resize-image.js +0 -539
  303. package/src/scripts/rm-safe.js +0 -669
  304. package/src/scripts/s.js +0 -540
  305. package/src/scripts/set-git-public.js +0 -365
  306. package/src/scripts/show-desktop-icons.js +0 -475
  307. package/src/scripts/show-hidden-files.js +0 -472
  308. package/src/scripts/tpa.js +0 -280
  309. package/src/scripts/tpo.js +0 -280
  310. package/src/scripts/u.js +0 -505
  311. package/src/scripts/vpush.js +0 -437
  312. package/src/scripts/y.js +0 -283
  313. package/src/utils/README.md +0 -95
  314. package/src/utils/common/apps.js +0 -143
  315. package/src/utils/common/display.js +0 -157
  316. package/src/utils/common/network.js +0 -185
  317. package/src/utils/common/os.js +0 -294
  318. package/src/utils/common/package-manager.js +0 -301
  319. package/src/utils/common/privileges.js +0 -138
  320. package/src/utils/common/shell.js +0 -216
  321. package/src/utils/macos/apps.js +0 -228
  322. package/src/utils/macos/brew.js +0 -315
  323. package/src/utils/ubuntu/apt.js +0 -307
  324. package/src/utils/ubuntu/desktop.js +0 -292
  325. package/src/utils/ubuntu/snap.js +0 -344
  326. package/src/utils/ubuntu/systemd.js +0 -286
  327. package/src/utils/windows/choco.js +0 -465
  328. package/src/utils/windows/env.js +0 -246
  329. package/src/utils/windows/registry.js +0 -269
  330. package/src/utils/windows/shell.js +0 -240
  331. package/src/utils/windows/winget.js +0 -489
@@ -1,759 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * @fileoverview Install Zoom.
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.
22
- */
23
-
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
- }
333
-
334
- /**
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
707
- *
708
- * @returns {Promise<void>}
709
- */
710
- async function install() {
711
- const platform = os.detect();
712
-
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
- };
752
-
753
- // Allow direct execution: node zoom.js
754
- if (require.main === module) {
755
- install().catch(err => {
756
- console.error(err.message);
757
- process.exit(1);
758
- });
759
- }