@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,799 @@
3
3
  /**
4
4
  * @fileoverview Install Microsoft Teams.
5
5
  * @module installs/microsoft-teams
6
+ *
7
+ * Microsoft Teams is a collaboration and communication platform developed by Microsoft.
8
+ * It provides chat, video meetings, file storage, and application integration for teams
9
+ * and organizations.
10
+ *
11
+ * IMPORTANT PLATFORM NOTES:
12
+ * - macOS: Installs Microsoft Teams via Homebrew cask (native client)
13
+ * - Windows: Installs Microsoft Teams via Chocolatey (native client)
14
+ * - Ubuntu/Debian: Installs unofficial "Teams for Linux" via APT repository (Electron wrapper)
15
+ * - Raspberry Pi OS: Installs "Teams for Linux" via Snap (ARM support)
16
+ * - Amazon Linux/RHEL: Installs "Teams for Linux" via RPM repository
17
+ * - WSL: Installs on Windows host via Chocolatey (accessed from WSL)
18
+ * - Git Bash: Installs on Windows host via Chocolatey
19
+ *
20
+ * NOTE: Microsoft discontinued native Linux desktop applications for Teams at the end of 2022.
21
+ * Linux platforms use the unofficial "Teams for Linux" Electron-based client which wraps
22
+ * the Teams web application.
6
23
  */
7
24
 
8
25
  const os = require('../utils/common/os');
26
+ const shell = require('../utils/common/shell');
27
+ const brew = require('../utils/macos/brew');
28
+ const snap = require('../utils/ubuntu/snap');
29
+ const choco = require('../utils/windows/choco');
30
+ const fs = require('fs');
31
+
32
+ /**
33
+ * Indicates whether this installer requires a desktop environment.
34
+ * Microsoft Teams is a GUI collaboration application and requires a display.
35
+ * @type {boolean}
36
+ */
37
+ const REQUIRES_DESKTOP = true;
38
+
39
+ /**
40
+ * The Homebrew cask name for Microsoft Teams on macOS.
41
+ */
42
+ const HOMEBREW_CASK_NAME = 'microsoft-teams';
43
+
44
+ /**
45
+ * The Chocolatey package name for Microsoft Teams on Windows.
46
+ * Uses the new Teams client bootstrapper which downloads the latest MSIX package.
47
+ */
48
+ const CHOCO_PACKAGE_NAME = 'microsoft-teams-new-bootstrapper';
49
+
50
+ /**
51
+ * The Snap package name for Teams for Linux.
52
+ * This is an unofficial Electron wrapper that supports ARM architectures.
53
+ */
54
+ const SNAP_PACKAGE_NAME = 'teams-for-linux';
55
+
56
+ /**
57
+ * The APT package name for Teams for Linux.
58
+ * This is installed from the unofficial teamsforlinux.de repository.
59
+ */
60
+ const APT_PACKAGE_NAME = 'teams-for-linux';
61
+
62
+ /**
63
+ * Check if Microsoft Teams is installed on macOS.
64
+ *
65
+ * Looks for the Microsoft Teams.app in the Applications folder.
66
+ * This is the standard installation location for the Homebrew cask.
67
+ *
68
+ * @returns {boolean} True if Teams is installed, false otherwise
69
+ */
70
+ function isTeamsInstalledMacOS() {
71
+ try {
72
+ return fs.existsSync('/Applications/Microsoft Teams.app');
73
+ } catch {
74
+ return false;
75
+ }
76
+ }
77
+
78
+ /**
79
+ * Check if Teams for Linux command is available.
80
+ *
81
+ * Checks if the teams-for-linux command exists in PATH, which works
82
+ * for both APT and Snap installations.
83
+ *
84
+ * @returns {boolean} True if teams-for-linux command exists, false otherwise
85
+ */
86
+ function isTeamsForLinuxInstalled() {
87
+ return shell.commandExists('teams-for-linux');
88
+ }
89
+
90
+ /**
91
+ * Set up the Teams for Linux APT repository on Ubuntu/Debian.
92
+ *
93
+ * This function:
94
+ * 1. Creates the keyrings directory
95
+ * 2. Downloads and installs the Teams for Linux GPG key
96
+ * 3. Adds the Teams for Linux APT repository to sources
97
+ * 4. Updates the package cache
98
+ *
99
+ * @returns {Promise<void>}
100
+ * @throws {Error} If any step fails
101
+ */
102
+ async function setupTeamsForLinuxAptRepository() {
103
+ console.log('Setting up Teams for Linux APT repository...');
104
+
105
+ // Ensure prerequisites are installed (wget, ca-certificates)
106
+ console.log('Installing prerequisites (wget, ca-certificates)...');
107
+ const prereqResult = await shell.exec(
108
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get update -y && ' +
109
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y wget ca-certificates'
110
+ );
111
+ if (prereqResult.code !== 0) {
112
+ throw new Error(`Failed to install prerequisites: ${prereqResult.stderr}`);
113
+ }
114
+
115
+ // Create keyrings directory
116
+ console.log('Setting up GPG keyring...');
117
+ const keyringResult = await shell.exec('sudo mkdir -p /etc/apt/keyrings');
118
+ if (keyringResult.code !== 0) {
119
+ throw new Error(`Failed to create keyring directory: ${keyringResult.stderr}`);
120
+ }
121
+
122
+ // Download and install the GPG key
123
+ const gpgResult = await shell.exec(
124
+ 'sudo wget -qO /etc/apt/keyrings/teams-for-linux.asc https://repo.teamsforlinux.de/teams-for-linux.asc'
125
+ );
126
+ if (gpgResult.code !== 0) {
127
+ throw new Error(`Failed to add Teams for Linux GPG key: ${gpgResult.stderr}`);
128
+ }
129
+
130
+ // Add the repository source using the modern DEB822 format
131
+ console.log('Adding Teams for Linux repository...');
132
+ const repoContent = `Types: deb
133
+ URIs: https://repo.teamsforlinux.de/debian/
134
+ Suites: stable
135
+ Components: main
136
+ Signed-By: /etc/apt/keyrings/teams-for-linux.asc
137
+ Architectures: amd64`;
138
+
139
+ const repoResult = await shell.exec(
140
+ `echo "${repoContent}" | sudo tee /etc/apt/sources.list.d/teams-for-linux-packages.sources > /dev/null`
141
+ );
142
+ if (repoResult.code !== 0) {
143
+ throw new Error(`Failed to add Teams for Linux repository: ${repoResult.stderr}`);
144
+ }
145
+
146
+ // Update package cache
147
+ console.log('Updating package cache...');
148
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
149
+ if (updateResult.code !== 0) {
150
+ throw new Error(`Failed to update package cache: ${updateResult.stderr}`);
151
+ }
152
+ }
153
+
154
+ /**
155
+ * Set up the Teams for Linux RPM repository on Amazon Linux/RHEL/Fedora.
156
+ *
157
+ * This function:
158
+ * 1. Downloads and imports the GPG key
159
+ * 2. Adds the Teams for Linux RPM repository
160
+ *
161
+ * @returns {Promise<void>}
162
+ * @throws {Error} If any step fails
163
+ */
164
+ async function setupTeamsForLinuxRpmRepository() {
165
+ console.log('Setting up Teams for Linux RPM repository...');
166
+
167
+ // Download and import the GPG key
168
+ console.log('Importing GPG key...');
169
+ const gpgDownloadResult = await shell.exec(
170
+ 'curl -1sLf -o /tmp/teams-for-linux.asc https://repo.teamsforlinux.de/teams-for-linux.asc'
171
+ );
172
+ if (gpgDownloadResult.code !== 0) {
173
+ throw new Error(`Failed to download GPG key: ${gpgDownloadResult.stderr}`);
174
+ }
175
+
176
+ const gpgImportResult = await shell.exec('sudo rpm --import /tmp/teams-for-linux.asc');
177
+ if (gpgImportResult.code !== 0) {
178
+ throw new Error(`Failed to import GPG key: ${gpgImportResult.stderr}`);
179
+ }
180
+
181
+ // Add the repository
182
+ console.log('Adding Teams for Linux repository...');
183
+ const repoResult = await shell.exec(
184
+ 'sudo curl -1sLf -o /etc/yum.repos.d/teams-for-linux.repo https://repo.teamsforlinux.de/rpm/teams-for-linux.repo'
185
+ );
186
+ if (repoResult.code !== 0) {
187
+ throw new Error(`Failed to add Teams for Linux repository: ${repoResult.stderr}`);
188
+ }
189
+ }
190
+
191
+ /**
192
+ * Install Microsoft Teams on macOS using Homebrew.
193
+ *
194
+ * Prerequisites:
195
+ * - macOS 11 (Big Sur) or later
196
+ * - Homebrew package manager installed
197
+ * - At least 2 GB free disk space
198
+ * - Apple Silicon (M1/M2/M3/M4) or Intel processor
199
+ *
200
+ * The installation uses the Homebrew cask 'microsoft-teams' which downloads
201
+ * and installs Microsoft Teams to /Applications/Microsoft Teams.app.
202
+ *
203
+ * @returns {Promise<void>}
204
+ * @throws {Error} If Homebrew is not installed or installation fails
205
+ */
206
+ async function install_macos() {
207
+ console.log('Checking if Microsoft Teams is already installed...');
208
+
209
+ // Check if Teams is already installed via the app bundle
210
+ if (isTeamsInstalledMacOS()) {
211
+ console.log('Microsoft Teams is already installed, skipping installation.');
212
+ return;
213
+ }
214
+
215
+ // Also check if the cask is installed
216
+ const caskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
217
+ if (caskInstalled) {
218
+ console.log('Microsoft Teams is already installed via Homebrew, skipping installation.');
219
+ return;
220
+ }
221
+
222
+ // Verify Homebrew is available
223
+ if (!brew.isInstalled()) {
224
+ throw new Error(
225
+ 'Homebrew is not installed. Please install Homebrew first using:\n' +
226
+ ' dev install homebrew\n' +
227
+ 'Then retry installing Microsoft Teams.'
228
+ );
229
+ }
230
+
231
+ console.log('Installing Microsoft Teams via Homebrew...');
232
+
233
+ // Install Microsoft Teams cask
234
+ const result = await brew.installCask(HOMEBREW_CASK_NAME);
235
+
236
+ if (!result.success) {
237
+ throw new Error(
238
+ `Failed to install Microsoft Teams via Homebrew.\n` +
239
+ `Output: ${result.output}\n\n` +
240
+ `Troubleshooting:\n` +
241
+ ` 1. Run 'brew update && brew cleanup' and retry\n` +
242
+ ` 2. If on Apple Silicon, ensure you have Rosetta 2: softwareupdate --install-rosetta\n` +
243
+ ` 3. Try manual installation: brew reinstall --cask microsoft-teams`
244
+ );
245
+ }
246
+
247
+ console.log('Microsoft Teams installed successfully.');
248
+ console.log('');
249
+ console.log('To launch Microsoft Teams:');
250
+ console.log(' - Open from Applications folder, or');
251
+ console.log(' - Run: open -a "Microsoft Teams"');
252
+ console.log('');
253
+ console.log('On first launch, sign in with your Microsoft account (personal, work, or school).');
254
+ }
255
+
256
+ /**
257
+ * Install Teams for Linux on Ubuntu/Debian using APT.
258
+ *
259
+ * Prerequisites:
260
+ * - Ubuntu 20.04, 22.04, 24.04 or later, or Debian 11, 12 or later (64-bit)
261
+ * - sudo privileges
262
+ * - At least 1 GB free disk space
263
+ *
264
+ * NOTE: Microsoft discontinued native Linux support. This installs the unofficial
265
+ * "Teams for Linux" Electron-based client from https://github.com/IsmaelMartinez/teams-for-linux
266
+ *
267
+ * @returns {Promise<void>}
268
+ * @throws {Error} If installation fails
269
+ */
270
+ async function install_ubuntu() {
271
+ console.log('Checking if Teams for Linux is already installed...');
272
+
273
+ // Check if already installed
274
+ if (isTeamsForLinuxInstalled()) {
275
+ console.log('Teams for Linux is already installed, skipping installation.');
276
+ return;
277
+ }
278
+
279
+ // Also check via Snap as a fallback
280
+ const snapInstalled = await snap.isSnapInstalled(SNAP_PACKAGE_NAME);
281
+ if (snapInstalled) {
282
+ console.log('Teams for Linux is already installed via Snap, skipping installation.');
283
+ return;
284
+ }
285
+
286
+ console.log('');
287
+ console.log('NOTE: Microsoft discontinued native Linux support for Teams.');
288
+ console.log('Installing the unofficial "Teams for Linux" client (Electron wrapper).');
289
+ console.log('');
290
+
291
+ // Set up the APT repository
292
+ await setupTeamsForLinuxAptRepository();
293
+
294
+ // Install Teams for Linux
295
+ console.log('Installing Teams for Linux...');
296
+ const installResult = await shell.exec(
297
+ `sudo DEBIAN_FRONTEND=noninteractive apt-get install -y ${APT_PACKAGE_NAME}`
298
+ );
299
+
300
+ if (installResult.code !== 0) {
301
+ throw new Error(
302
+ `Failed to install Teams for Linux.\n` +
303
+ `Output: ${installResult.stderr}\n\n` +
304
+ `Troubleshooting:\n` +
305
+ ` 1. Run 'sudo apt-get update' and retry\n` +
306
+ ` 2. Verify the repository was added: cat /etc/apt/sources.list.d/teams-for-linux-packages.sources\n` +
307
+ ` 3. Alternative: Try installing via Snap: sudo snap install teams-for-linux`
308
+ );
309
+ }
310
+
311
+ // Verify installation
312
+ if (!isTeamsForLinuxInstalled()) {
313
+ throw new Error(
314
+ 'Installation appeared to complete but Teams for Linux was not found.\n\n' +
315
+ 'Please try:\n' +
316
+ ' 1. Restart your terminal session\n' +
317
+ ' 2. Run: teams-for-linux --version'
318
+ );
319
+ }
320
+
321
+ console.log('Teams for Linux installed successfully.');
322
+ console.log('');
323
+ console.log('To launch Teams for Linux:');
324
+ console.log(' - Run: teams-for-linux');
325
+ console.log(' - Or launch from your application menu');
326
+ console.log('');
327
+ console.log('NOTE: Some features like screen sharing may have limitations on Linux.');
328
+ }
329
+
330
+ /**
331
+ * Install Teams for Linux on Raspberry Pi OS using Snap.
332
+ *
333
+ * Prerequisites:
334
+ * - Raspberry Pi OS (64-bit recommended) - Bookworm or Bullseye
335
+ * - Raspberry Pi 3B+ or later (arm64 or armhf architecture)
336
+ * - At least 2 GB RAM (4 GB recommended for video calls)
337
+ * - sudo privileges
338
+ * - snapd installed
339
+ *
340
+ * NOTE: The APT repository only provides amd64 packages. Snap is required for ARM.
341
+ *
342
+ * @returns {Promise<void>}
343
+ * @throws {Error} If installation fails
344
+ */
345
+ async function install_raspbian() {
346
+ console.log('Checking if Teams for Linux is already installed...');
347
+
348
+ // Check if already installed via Snap
349
+ const snapInstalled = await snap.isSnapInstalled(SNAP_PACKAGE_NAME);
350
+ if (snapInstalled) {
351
+ console.log('Teams for Linux is already installed via Snap, skipping installation.');
352
+ return;
353
+ }
354
+
355
+ // Also check if command exists (from another installation method)
356
+ if (isTeamsForLinuxInstalled()) {
357
+ console.log('Teams for Linux is already installed, skipping installation.');
358
+ return;
359
+ }
360
+
361
+ console.log('');
362
+ console.log('NOTE: Microsoft discontinued native Linux support for Teams.');
363
+ console.log('Installing the unofficial "Teams for Linux" client via Snap.');
364
+ console.log('Snap is required for Raspberry Pi as the APT repository only supports amd64.');
365
+ console.log('');
366
+
367
+ // Ensure snapd is installed
368
+ if (!snap.isInstalled()) {
369
+ console.log('Installing snapd...');
370
+ const snapdResult = await shell.exec(
371
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get update -y && ' +
372
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd'
373
+ );
374
+ if (snapdResult.code !== 0) {
375
+ throw new Error(
376
+ `Failed to install snapd.\n` +
377
+ `Output: ${snapdResult.stderr}\n\n` +
378
+ `Please install snapd manually and retry:\n` +
379
+ ` sudo apt-get install snapd\n` +
380
+ ` sudo reboot`
381
+ );
382
+ }
383
+ console.log('');
384
+ console.log('IMPORTANT: snapd was just installed. You may need to reboot');
385
+ console.log('and run this installer again for Snap to work properly.');
386
+ console.log('');
387
+ }
388
+
389
+ // Install Teams for Linux via Snap
390
+ console.log('Installing Teams for Linux via Snap...');
391
+ const result = await snap.install(SNAP_PACKAGE_NAME);
392
+
393
+ if (!result.success) {
394
+ throw new Error(
395
+ `Failed to install Teams for Linux via Snap.\n` +
396
+ `Output: ${result.output}\n\n` +
397
+ `Troubleshooting:\n` +
398
+ ` 1. If snapd was just installed, try rebooting first\n` +
399
+ ` 2. Ensure snapd socket is running: sudo systemctl enable --now snapd.socket\n` +
400
+ ` 3. Try manual installation: sudo snap install teams-for-linux`
401
+ );
402
+ }
403
+
404
+ console.log('Teams for Linux installed successfully.');
405
+ console.log('');
406
+ console.log('To launch Teams for Linux:');
407
+ console.log(' - Run: teams-for-linux');
408
+ console.log(' - Or launch from your application menu');
409
+ console.log('');
410
+ console.log('PERFORMANCE NOTES for Raspberry Pi:');
411
+ console.log(' - Use a Raspberry Pi 4 or 5 with at least 4 GB RAM for video calls');
412
+ console.log(' - Close other applications during video calls');
413
+ console.log(' - Screen sharing may have limited support on ARM devices');
414
+ }
415
+
416
+ /**
417
+ * Install Teams for Linux on Amazon Linux/RHEL using DNF/YUM.
418
+ *
419
+ * Prerequisites:
420
+ * - Amazon Linux 2023, Amazon Linux 2, RHEL 8, RHEL 9, or Fedora
421
+ * - sudo privileges
422
+ * - At least 1 GB free disk space
423
+ *
424
+ * NOTE: Microsoft discontinued native Linux support. This installs the unofficial
425
+ * "Teams for Linux" client from the teamsforlinux.de RPM repository.
426
+ *
427
+ * @returns {Promise<void>}
428
+ * @throws {Error} If installation fails
429
+ */
430
+ async function install_amazon_linux() {
431
+ console.log('Checking if Teams for Linux is already installed...');
432
+
433
+ // Check if already installed
434
+ if (isTeamsForLinuxInstalled()) {
435
+ console.log('Teams for Linux is already installed, skipping installation.');
436
+ return;
437
+ }
438
+
439
+ console.log('');
440
+ console.log('NOTE: Microsoft discontinued native Linux support for Teams.');
441
+ console.log('Installing the unofficial "Teams for Linux" client.');
442
+ console.log('');
443
+
444
+ // Detect package manager (dnf for AL2023/RHEL 8+/Fedora, yum for AL2)
445
+ const hasDnf = shell.commandExists('dnf');
446
+ const hasYum = shell.commandExists('yum');
447
+ const packageManager = hasDnf ? 'dnf' : (hasYum ? 'yum' : null);
448
+
449
+ if (!packageManager) {
450
+ throw new Error(
451
+ 'Neither dnf nor yum package manager found.\n' +
452
+ 'This installer supports Amazon Linux 2023 (dnf), Amazon Linux 2 (yum),\n' +
453
+ 'RHEL 8/9 (dnf), and Fedora (dnf).'
454
+ );
455
+ }
456
+
457
+ console.log(`Detected package manager: ${packageManager}`);
458
+
459
+ // Set up the RPM repository
460
+ await setupTeamsForLinuxRpmRepository();
461
+
462
+ // Install Teams for Linux
463
+ console.log('Installing Teams for Linux...');
464
+ const installResult = await shell.exec(`sudo ${packageManager} install -y ${APT_PACKAGE_NAME}`);
465
+
466
+ if (installResult.code !== 0) {
467
+ throw new Error(
468
+ `Failed to install Teams for Linux.\n` +
469
+ `Output: ${installResult.stderr}\n\n` +
470
+ `Troubleshooting:\n` +
471
+ ` 1. Verify the repository was added: cat /etc/yum.repos.d/teams-for-linux.repo\n` +
472
+ ` 2. Update system packages: sudo ${packageManager} update -y\n` +
473
+ ` 3. Retry installation: sudo ${packageManager} install -y teams-for-linux`
474
+ );
475
+ }
476
+
477
+ // Verify installation
478
+ if (!isTeamsForLinuxInstalled()) {
479
+ throw new Error(
480
+ 'Installation appeared to complete but Teams for Linux was not found.\n\n' +
481
+ 'Please try:\n' +
482
+ ' 1. Restart your terminal session\n' +
483
+ ' 2. Run: teams-for-linux --version'
484
+ );
485
+ }
486
+
487
+ console.log('Teams for Linux installed successfully.');
488
+ console.log('');
489
+ console.log('To launch Teams for Linux:');
490
+ console.log(' - Run: teams-for-linux');
491
+ console.log(' - Or launch from your application menu');
492
+ console.log('');
493
+ console.log('NOTE: If running on a headless EC2 instance, Teams cannot be used directly.');
494
+ console.log('Consider accessing Teams via a browser on a machine with GUI access.');
495
+ }
496
+
497
+ /**
498
+ * Install Microsoft Teams on Windows using Chocolatey.
499
+ *
500
+ * Prerequisites:
501
+ * - Windows 10 version 20H1 (10.0.19041) or later, or Windows 11
502
+ * - At least 2 GB RAM and 3 GB free disk space
503
+ * - Administrator PowerShell or Command Prompt
504
+ * - Chocolatey package manager installed
505
+ *
506
+ * The installation uses the new Microsoft Teams client (version 2.x) via the
507
+ * official Microsoft bootstrapper, which downloads and installs the latest
508
+ * Teams MSIX package.
509
+ *
510
+ * @returns {Promise<void>}
511
+ * @throws {Error} If Chocolatey is not installed or installation fails
512
+ */
513
+ async function install_windows() {
514
+ console.log('Checking if Microsoft Teams is already installed...');
515
+
516
+ // Check if Teams package is installed via Chocolatey
517
+ const packageInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
518
+ if (packageInstalled) {
519
+ console.log('Microsoft Teams is already installed via Chocolatey, skipping installation.');
520
+ return;
521
+ }
522
+
523
+ // Also check for the older package name
524
+ const oldPackageInstalled = await choco.isPackageInstalled('microsoft-teams');
525
+ if (oldPackageInstalled) {
526
+ console.log('Microsoft Teams (classic) is already installed, skipping installation.');
527
+ console.log('');
528
+ console.log('NOTE: To upgrade to the new Teams client, run:');
529
+ console.log(' choco uninstall microsoft-teams -y');
530
+ console.log(' choco install microsoft-teams-new-bootstrapper -y');
531
+ return;
532
+ }
533
+
534
+ // Verify Chocolatey is available
535
+ if (!choco.isInstalled()) {
536
+ throw new Error(
537
+ 'Chocolatey is not installed. Please install Chocolatey first:\n\n' +
538
+ 'Run the following in an Administrator PowerShell:\n' +
539
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
540
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
541
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
542
+ 'Then retry installing Microsoft Teams.'
543
+ );
544
+ }
545
+
546
+ console.log('Installing Microsoft Teams via Chocolatey...');
547
+ console.log('This may take a few minutes...');
548
+
549
+ // Install Microsoft Teams
550
+ const result = await choco.install(CHOCO_PACKAGE_NAME);
551
+
552
+ if (!result.success) {
553
+ throw new Error(
554
+ `Failed to install Microsoft Teams via Chocolatey.\n` +
555
+ `Output: ${result.output}\n\n` +
556
+ `Troubleshooting:\n` +
557
+ ` 1. Ensure you are running as Administrator\n` +
558
+ ` 2. Update Chocolatey: choco upgrade chocolatey -y\n` +
559
+ ` 3. Try manual installation: choco install microsoft-teams-new-bootstrapper -y --force`
560
+ );
561
+ }
562
+
563
+ console.log('Microsoft Teams installed successfully.');
564
+ console.log('');
565
+ console.log('To launch Microsoft Teams:');
566
+ console.log(' - Search for "Microsoft Teams" in the Start Menu');
567
+ console.log(' - Or run: Start-Process ms-teams:');
568
+ console.log('');
569
+ console.log('On first launch, sign in with your Microsoft account (personal, work, or school).');
570
+ }
571
+
572
+ /**
573
+ * Install Microsoft Teams for WSL (Windows Subsystem for Linux).
574
+ *
575
+ * WSL runs a Linux environment, but the recommended approach is to install
576
+ * Teams on the Windows host and launch it from WSL. This provides better
577
+ * audio/video support and system integration.
578
+ *
579
+ * Prerequisites:
580
+ * - Windows 10 version 2004 or higher, or Windows 11
581
+ * - WSL 2 enabled with Ubuntu distribution installed
582
+ * - Administrator access on Windows for installation
583
+ *
584
+ * @returns {Promise<void>}
585
+ * @throws {Error} If installation fails
586
+ */
587
+ async function install_ubuntu_wsl() {
588
+ console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
589
+ console.log('');
590
+ console.log('Installing Microsoft Teams on the Windows host...');
591
+ console.log('This is the recommended approach for better audio/video support.');
592
+ console.log('');
593
+
594
+ // Install Teams on Windows host via PowerShell
595
+ console.log('Installing Microsoft Teams via Chocolatey on Windows...');
596
+ const installResult = await shell.exec(
597
+ `powershell.exe -NoProfile -Command "choco install ${CHOCO_PACKAGE_NAME} -y"`
598
+ );
599
+
600
+ if (installResult.code !== 0) {
601
+ // Check if Chocolatey is not installed
602
+ if (installResult.stderr && installResult.stderr.includes('not recognized')) {
603
+ throw new Error(
604
+ 'Chocolatey is not installed on Windows. Please install it first:\n\n' +
605
+ 'Run the following in an Administrator PowerShell on Windows:\n' +
606
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
607
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
608
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
609
+ 'Then retry installing Microsoft Teams from WSL.'
610
+ );
611
+ }
612
+
613
+ throw new Error(
614
+ `Failed to install Microsoft Teams.\n` +
615
+ `Output: ${installResult.stdout || installResult.stderr}\n\n` +
616
+ `Troubleshooting:\n` +
617
+ ` 1. Ensure Chocolatey is installed on Windows\n` +
618
+ ` 2. Run the installer from an Administrator terminal\n` +
619
+ ` 3. Try installing directly from PowerShell:\n` +
620
+ ` choco install microsoft-teams-new-bootstrapper -y`
621
+ );
622
+ }
623
+
624
+ console.log('Microsoft Teams installed successfully on Windows.');
625
+ console.log('');
626
+ console.log('To launch Teams from WSL:');
627
+ console.log(' cmd.exe /c start ms-teams:');
628
+ console.log('');
629
+ console.log('On first launch, sign in with your Microsoft account.');
630
+ }
9
631
 
10
632
  /**
11
- * Install Microsoft Teams across supported platforms.
633
+ * Install Microsoft Teams from Git Bash on Windows.
634
+ *
635
+ * Git Bash runs within Windows, so this function installs Microsoft Teams
636
+ * on the Windows host using Chocolatey via PowerShell interop.
637
+ *
638
+ * Prerequisites:
639
+ * - Windows 10 or Windows 11 (64-bit)
640
+ * - Git Bash installed (comes with Git for Windows)
641
+ * - Chocolatey package manager installed on Windows
642
+ * - Administrator privileges
643
+ *
644
+ * @returns {Promise<void>}
645
+ * @throws {Error} If installation fails
646
+ */
647
+ async function install_gitbash() {
648
+ console.log('Detected Git Bash on Windows.');
649
+ console.log('Installing Microsoft Teams on the Windows host...');
650
+ console.log('');
651
+
652
+ // Install via PowerShell using Chocolatey
653
+ console.log('Installing Microsoft Teams via Chocolatey...');
654
+ const installResult = await shell.exec(
655
+ `powershell.exe -NoProfile -Command "choco install ${CHOCO_PACKAGE_NAME} -y"`
656
+ );
657
+
658
+ if (installResult.code !== 0) {
659
+ throw new Error(
660
+ `Failed to install Microsoft Teams.\n` +
661
+ `Output: ${installResult.stdout || installResult.stderr}\n\n` +
662
+ `Troubleshooting:\n` +
663
+ ` 1. Ensure Chocolatey is installed on Windows\n` +
664
+ ` 2. Run Git Bash as Administrator and retry\n` +
665
+ ` 3. Try installing directly from PowerShell:\n` +
666
+ ` choco install microsoft-teams-new-bootstrapper -y`
667
+ );
668
+ }
669
+
670
+ console.log('Microsoft Teams installed successfully.');
671
+ console.log('');
672
+ console.log('To launch Teams from Git Bash:');
673
+ console.log(' start ms-teams:');
674
+ console.log(' OR');
675
+ console.log(' cmd //c "start ms-teams:"');
676
+ console.log('');
677
+ console.log('On first launch, sign in with your Microsoft account.');
678
+ }
679
+
680
+ /**
681
+ * Check if Microsoft Teams is installed on the current platform.
682
+ *
683
+ * On macOS, checks if Teams.app exists.
684
+ * On Windows/Git Bash, checks if Teams is installed via Chocolatey.
685
+ * On Linux, checks if teams-for-linux command exists.
686
+ *
687
+ * @returns {Promise<boolean>} True if installed, false otherwise
688
+ */
689
+ async function isInstalled() {
690
+ const platform = os.detect();
691
+
692
+ if (platform.type === 'macos') {
693
+ return brew.isCaskInstalled(HOMEBREW_CASK_NAME);
694
+ }
695
+
696
+ if (platform.type === 'windows' || platform.type === 'gitbash' || platform.type === 'wsl') {
697
+ return choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
698
+ }
699
+
700
+ if (platform.type === 'raspbian') {
701
+ return snap.isSnapInstalled(SNAP_PACKAGE_NAME);
702
+ }
703
+
704
+ // Ubuntu/Debian and other Linux: Check for teams-for-linux command
705
+ if (['ubuntu', 'debian', 'amazon_linux', 'rhel', 'fedora'].includes(platform.type)) {
706
+ return shell.commandExists('teams-for-linux');
707
+ }
708
+
709
+ return false;
710
+ }
711
+
712
+ /**
713
+ * Check if this installer is supported on the current platform.
714
+ * Microsoft Teams is supported on all major platforms.
715
+ * @returns {boolean} True if installation is supported on this platform
716
+ */
717
+ function isEligible() {
718
+ const platform = os.detect();
719
+
720
+ // First check if the platform is supported
721
+ const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'rhel', 'fedora', 'windows', 'gitbash'];
722
+ if (!supportedPlatforms.includes(platform.type)) {
723
+ return false;
724
+ }
725
+
726
+ // This installer requires a desktop environment
727
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
728
+ return false;
729
+ }
730
+
731
+ return true;
732
+ }
733
+
734
+ /**
735
+ * Main installation entry point.
736
+ *
737
+ * Detects the current platform and runs the appropriate installer function.
738
+ * Handles platform-specific mappings to ensure all supported platforms
739
+ * have appropriate installation logic.
740
+ *
741
+ * Supported platforms:
742
+ * - macOS: Microsoft Teams via Homebrew cask
743
+ * - Ubuntu/Debian: Teams for Linux via APT repository
744
+ * - Raspberry Pi OS: Teams for Linux via Snap (ARM support)
745
+ * - Amazon Linux/RHEL/Fedora: Teams for Linux via RPM repository
746
+ * - Windows: Microsoft Teams via Chocolatey
747
+ * - WSL (Ubuntu): Microsoft Teams on Windows host
748
+ * - Git Bash: Microsoft Teams on Windows host
12
749
  *
13
750
  * @returns {Promise<void>}
14
751
  */
15
752
  async function install() {
16
753
  const platform = os.detect();
17
754
 
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 };
755
+ // Map platform types to their installer functions
756
+ // This mapping handles aliases and variant platforms
757
+ const installers = {
758
+ 'macos': install_macos,
759
+ 'ubuntu': install_ubuntu,
760
+ 'debian': install_ubuntu,
761
+ 'wsl': install_ubuntu_wsl,
762
+ 'raspbian': install_raspbian,
763
+ 'amazon_linux': install_amazon_linux,
764
+ 'rhel': install_amazon_linux,
765
+ 'fedora': install_amazon_linux,
766
+ 'windows': install_windows,
767
+ 'gitbash': install_gitbash
768
+ };
769
+
770
+ const installer = installers[platform.type];
771
+
772
+ if (!installer) {
773
+ console.log(`Microsoft Teams is not available for ${platform.type}.`);
774
+ return;
775
+ }
776
+
777
+ await installer();
778
+ }
779
+
780
+ // Export all functions for use as a module and for testing
781
+ module.exports = {
782
+ REQUIRES_DESKTOP,
783
+ install,
784
+ isInstalled,
785
+ isEligible,
786
+ install_macos,
787
+ install_ubuntu,
788
+ install_ubuntu_wsl,
789
+ install_raspbian,
790
+ install_amazon_linux,
791
+ install_windows,
792
+ install_gitbash
793
+ };
41
794
 
795
+ // Allow direct execution: node microsoft-teams.js
42
796
  if (require.main === module) {
43
- install();
797
+ install().catch(err => {
798
+ console.error(err.message);
799
+ process.exit(1);
800
+ });
44
801
  }