@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,345 @@
3
3
  /**
4
4
  * @fileoverview Install Elmedia Player.
5
5
  * @module installs/elmedia-player
6
+ *
7
+ * Elmedia Player is a premium media player developed by Electronic Team, Inc.
8
+ * exclusively for macOS. It supports virtually all video and audio formats
9
+ * including AVI, MP4, FLV, WMV, MKV, MP3, M4V, MOV, and many others without
10
+ * requiring additional codecs.
11
+ *
12
+ * IMPORTANT PLATFORM LIMITATION:
13
+ * Elmedia Player is ONLY available on macOS. It is not available for Windows,
14
+ * Linux, or any other operating system. For unsupported platforms, this
15
+ * installer will display a simple message and return gracefully without error.
6
16
  */
7
17
 
18
+ const fs = require('fs');
8
19
  const os = require('../utils/common/os');
20
+ const brew = require('../utils/macos/brew');
21
+ const macosApps = require('../utils/macos/apps');
22
+
23
+ /**
24
+ * Whether this installer requires a desktop environment to function.
25
+ * Elmedia Player is a GUI media player application.
26
+ */
27
+ const REQUIRES_DESKTOP = true;
28
+
29
+ /**
30
+ * The Homebrew cask name for Elmedia Player.
31
+ * This is the identifier used by Homebrew to install the application.
32
+ */
33
+ const HOMEBREW_CASK_NAME = 'elmedia-player';
34
+
35
+ /**
36
+ * The application bundle name as it appears in /Applications.
37
+ * Elmedia Player uses a space in its name when installed.
38
+ */
39
+ const MACOS_APP_NAME = 'Elmedia Player';
40
+
41
+ /**
42
+ * The full path to the Elmedia Player application bundle.
43
+ * This is where Homebrew installs the application.
44
+ */
45
+ const MACOS_APP_PATH = '/Applications/Elmedia Player.app';
46
+
47
+ /**
48
+ * Check if Elmedia Player is already installed on macOS.
49
+ *
50
+ * Checks both the standard /Applications folder and ~/Applications
51
+ * for the Elmedia Player.app bundle.
52
+ *
53
+ * @returns {boolean} True if Elmedia Player is installed, false otherwise
54
+ */
55
+ function isInstalledMacOS() {
56
+ // Check if the application bundle exists in the standard location
57
+ if (fs.existsSync(MACOS_APP_PATH)) {
58
+ return true;
59
+ }
60
+
61
+ // Also check using the macOS apps utility which handles ~/Applications
62
+ return macosApps.isAppInstalled(MACOS_APP_NAME);
63
+ }
64
+
65
+ /**
66
+ * Install Elmedia Player on macOS using Homebrew.
67
+ *
68
+ * This function performs an idempotent installation of Elmedia Player:
69
+ * 1. Checks if Elmedia Player is already installed (skips if yes)
70
+ * 2. Verifies Homebrew is available
71
+ * 3. Installs via Homebrew cask
72
+ * 4. Verifies the installation succeeded
73
+ *
74
+ * Prerequisites:
75
+ * - macOS 10.15 (Catalina) or later (Homebrew cask requirement)
76
+ * - Homebrew package manager installed
77
+ * - A graphical desktop session (not SSH-only)
78
+ *
79
+ * NOTE: This installs the free version of Elmedia Player. The Pro version
80
+ * with additional features (streaming, playlist management, video tuning)
81
+ * requires a separate license purchase from the Electronic Team website.
82
+ *
83
+ * @returns {Promise<void>}
84
+ * @throws {Error} If Homebrew is not installed or installation fails
85
+ */
86
+ async function install_macos() {
87
+ console.log('Checking if Elmedia Player is already installed...');
88
+
89
+ // Idempotency check: skip installation if already present
90
+ if (isInstalledMacOS()) {
91
+ console.log('Elmedia Player is already installed, skipping installation.');
92
+ return;
93
+ }
94
+
95
+ // Verify Homebrew is available before attempting installation
96
+ // Homebrew is required to install cask applications
97
+ if (!brew.isInstalled()) {
98
+ throw new Error(
99
+ 'Homebrew is not installed. Please install Homebrew first using:\n' +
100
+ ' dev install homebrew\n' +
101
+ 'Then retry installing Elmedia Player.'
102
+ );
103
+ }
104
+
105
+ console.log('Installing Elmedia Player via Homebrew...');
106
+
107
+ // Install the cask using the Homebrew utility
108
+ // The brew.installCask function handles the --cask flag automatically
109
+ const result = await brew.installCask(HOMEBREW_CASK_NAME);
110
+
111
+ // Check if the installation command succeeded
112
+ if (!result.success) {
113
+ throw new Error(
114
+ `Failed to install Elmedia Player via Homebrew.\n` +
115
+ `Output: ${result.output}\n\n` +
116
+ `Troubleshooting:\n` +
117
+ ` 1. Run 'brew update && brew cleanup' and retry\n` +
118
+ ` 2. If using Apple Silicon, ensure Homebrew is properly configured\n` +
119
+ ` 3. Try reinstalling: brew reinstall --cask elmedia-player\n` +
120
+ ` 4. Check for Gatekeeper issues: xattr -dr com.apple.quarantine /Applications/Elmedia\\ Player.app`
121
+ );
122
+ }
123
+
124
+ // Verify the installation succeeded by checking if the app bundle exists
125
+ // This catches cases where Homebrew reports success but the app was not installed
126
+ if (!isInstalledMacOS()) {
127
+ throw new Error(
128
+ 'Installation appeared to complete but Elmedia Player was not found at:\n' +
129
+ ` ${MACOS_APP_PATH}\n\n` +
130
+ 'Please try reinstalling manually: brew reinstall --cask elmedia-player'
131
+ );
132
+ }
133
+
134
+ console.log('Elmedia Player installed successfully.');
135
+ console.log('');
136
+ console.log('You can launch Elmedia Player from your Applications folder');
137
+ console.log('or by searching for "Elmedia" in Spotlight (Cmd+Space).');
138
+ }
139
+
140
+ /**
141
+ * Install Elmedia Player on Ubuntu/Debian.
142
+ *
143
+ * IMPORTANT: Elmedia Player is NOT available for Ubuntu or Debian.
144
+ * It is a macOS-exclusive application developed by Electronic Team, Inc.
145
+ * and has no Linux version.
146
+ *
147
+ * This function returns gracefully with a message rather than throwing
148
+ * an error, following the project's pattern for unsupported platforms.
149
+ *
150
+ * @returns {Promise<void>}
151
+ */
152
+ async function install_ubuntu() {
153
+ console.log('Elmedia Player is not available for Ubuntu/Debian.');
154
+ }
155
+
156
+ /**
157
+ * Install Elmedia Player on Ubuntu running in WSL (Windows Subsystem for Linux).
158
+ *
159
+ * IMPORTANT: Elmedia Player is NOT available for WSL. It is a macOS-exclusive
160
+ * application. Neither WSL (Linux environment) nor the Windows host can run
161
+ * Elmedia Player because it only exists for macOS.
162
+ *
163
+ * This function returns gracefully with a message rather than throwing
164
+ * an error, following the project's pattern for unsupported platforms.
165
+ *
166
+ * @returns {Promise<void>}
167
+ */
168
+ async function install_ubuntu_wsl() {
169
+ console.log('Elmedia Player is not available for WSL.');
170
+ }
9
171
 
10
172
  /**
11
- * Install Elmedia Player across supported platforms.
173
+ * Install Elmedia Player on Raspberry Pi OS.
174
+ *
175
+ * IMPORTANT: Elmedia Player is NOT available for Raspberry Pi OS.
176
+ * It is a macOS-exclusive application and has no ARM Linux version.
177
+ *
178
+ * This function returns gracefully with a message rather than throwing
179
+ * an error, following the project's pattern for unsupported platforms.
180
+ *
181
+ * @returns {Promise<void>}
182
+ */
183
+ async function install_raspbian() {
184
+ console.log('Elmedia Player is not available for Raspberry Pi OS.');
185
+ }
186
+
187
+ /**
188
+ * Install Elmedia Player on Amazon Linux/RHEL.
189
+ *
190
+ * IMPORTANT: Elmedia Player is NOT available for Amazon Linux or RHEL.
191
+ * It is a macOS-exclusive application and has no Linux version.
192
+ *
193
+ * This function returns gracefully with a message rather than throwing
194
+ * an error, following the project's pattern for unsupported platforms.
195
+ *
196
+ * @returns {Promise<void>}
197
+ */
198
+ async function install_amazon_linux() {
199
+ console.log('Elmedia Player is not available for Amazon Linux/RHEL.');
200
+ }
201
+
202
+ /**
203
+ * Install Elmedia Player on Windows.
204
+ *
205
+ * IMPORTANT: Elmedia Player is NOT available for Windows.
206
+ * It is a macOS-exclusive application developed by Electronic Team, Inc.
207
+ * and has no Windows version.
208
+ *
209
+ * This function returns gracefully with a message rather than throwing
210
+ * an error, following the project's pattern for unsupported platforms.
211
+ *
212
+ * @returns {Promise<void>}
213
+ */
214
+ async function install_windows() {
215
+ console.log('Elmedia Player is not available for Windows.');
216
+ }
217
+
218
+ /**
219
+ * Install Elmedia Player from Git Bash on Windows.
220
+ *
221
+ * IMPORTANT: Elmedia Player is NOT available for Windows.
222
+ * Git Bash runs on Windows, and Elmedia Player is a macOS-exclusive
223
+ * application with no Windows version.
224
+ *
225
+ * This function returns gracefully with a message rather than throwing
226
+ * an error, following the project's pattern for unsupported platforms.
227
+ *
228
+ * @returns {Promise<void>}
229
+ */
230
+ async function install_gitbash() {
231
+ console.log('Elmedia Player is not available for Windows.');
232
+ }
233
+
234
+ /**
235
+ * Check if Elmedia Player is currently installed on the system.
236
+ *
237
+ * Elmedia Player is ONLY available on macOS. This function checks for the
238
+ * application bundle in /Applications or ~/Applications.
239
+ *
240
+ * @returns {Promise<boolean>} True if Elmedia Player is installed, false otherwise
241
+ */
242
+ async function isInstalled() {
243
+ const platform = os.detect();
244
+
245
+ if (platform.type === 'macos') {
246
+ // Check if Elmedia Player app bundle exists
247
+ if (isInstalledMacOS()) {
248
+ return true;
249
+ }
250
+ // Also check via Homebrew cask
251
+ return await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
252
+ }
253
+
254
+ // Elmedia Player is not available on any other platform
255
+ return false;
256
+ }
257
+
258
+ /**
259
+ * Check if this installer is supported on the current platform.
260
+ * Elmedia Player is ONLY available on macOS.
261
+ * @returns {boolean} True if installation is supported on this platform
262
+ */
263
+ function isEligible() {
264
+ const platform = os.detect();
265
+ if (platform.type !== 'macos') {
266
+ return false;
267
+ }
268
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
269
+ return false;
270
+ }
271
+ return true;
272
+ }
273
+
274
+ /**
275
+ * Main installation entry point.
276
+ *
277
+ * Detects the current platform and runs the appropriate installer function.
278
+ * For Elmedia Player, only macOS is supported. All other platforms will
279
+ * receive a friendly message and return gracefully without error.
280
+ *
281
+ * Supported platforms:
282
+ * - macOS: Full support via Homebrew cask
283
+ *
284
+ * Unsupported platforms (returns gracefully with message):
285
+ * - Ubuntu/Debian: macOS-exclusive application
286
+ * - Raspberry Pi OS: macOS-exclusive application
287
+ * - Amazon Linux/RHEL: macOS-exclusive application
288
+ * - Windows: macOS-exclusive application
289
+ * - WSL: macOS-exclusive application
290
+ * - Git Bash: macOS-exclusive application
12
291
  *
13
292
  * @returns {Promise<void>}
14
293
  */
15
294
  async function install() {
16
295
  const platform = os.detect();
17
296
 
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 };
297
+ // Map platform types to their installer functions
298
+ // This mapping handles platform aliases (e.g., debian maps to ubuntu)
299
+ const installers = {
300
+ 'macos': install_macos,
301
+ 'ubuntu': install_ubuntu,
302
+ 'debian': install_ubuntu,
303
+ 'ubuntu-wsl': install_ubuntu_wsl,
304
+ 'wsl': install_ubuntu_wsl,
305
+ 'raspbian': install_raspbian,
306
+ 'amazon_linux': install_amazon_linux,
307
+ 'amazon-linux': install_amazon_linux,
308
+ 'rhel': install_amazon_linux,
309
+ 'fedora': install_amazon_linux,
310
+ 'windows': install_windows,
311
+ 'gitbash': install_gitbash
312
+ };
313
+
314
+ const installer = installers[platform.type];
315
+
316
+ // If the platform is not in our mapping, display a friendly message
317
+ // and return without error
318
+ if (!installer) {
319
+ console.log(`Elmedia Player is not available for ${platform.type}.`);
320
+ return;
321
+ }
322
+
323
+ await installer();
324
+ }
325
+
326
+ // Export all functions for use as a module and for testing
327
+ module.exports = {
328
+ REQUIRES_DESKTOP,
329
+ install,
330
+ isInstalled,
331
+ isEligible,
332
+ install_macos,
333
+ install_ubuntu,
334
+ install_ubuntu_wsl,
335
+ install_raspbian,
336
+ install_amazon_linux,
337
+ install_windows,
338
+ install_gitbash
339
+ };
41
340
 
341
+ // Allow direct execution: node elmedia-player.js
42
342
  if (require.main === module) {
43
- install();
343
+ install().catch(err => {
344
+ console.error(err.message);
345
+ process.exit(1);
346
+ });
44
347
  }