@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,372 @@
3
3
  /**
4
4
  * @fileoverview Install Safari Technology Preview.
5
5
  * @module installs/safari-tech-preview
6
+ *
7
+ * Safari Technology Preview is Apple's experimental browser for developers,
8
+ * providing early access to upcoming WebKit features, web APIs, and developer
9
+ * tools before they reach the stable Safari release. It updates approximately
10
+ * every two weeks and runs alongside your existing Safari installation.
11
+ *
12
+ * CRITICAL PLATFORM LIMITATION:
13
+ * Safari Technology Preview is EXCLUSIVELY available for macOS. Apple does not
14
+ * release Safari (or Safari Technology Preview) for Windows, Linux, or any
15
+ * other operating system. This is a fundamental platform restriction, not a
16
+ * packaging limitation.
17
+ *
18
+ * Supported Platforms:
19
+ * - macOS (Sequoia 15.0 or later) via Homebrew Cask
20
+ *
21
+ * Not Available On:
22
+ * - Ubuntu/Debian (Apple does not release Safari for Linux)
23
+ * - Raspberry Pi OS (Apple does not release Safari for Linux)
24
+ * - Amazon Linux/RHEL (Apple does not release Safari for Linux)
25
+ * - Windows (Safari for Windows was discontinued in 2012)
26
+ * - WSL (Linux environment on Windows, Safari unavailable)
27
+ * - Git Bash (Windows environment, Safari unavailable)
6
28
  */
7
29
 
8
30
  const os = require('../utils/common/os');
31
+ const brew = require('../utils/macos/brew');
32
+ const macosApps = require('../utils/macos/apps');
33
+
34
+ /**
35
+ * Whether this installer requires a desktop environment to function.
36
+ * Safari Technology Preview is a GUI web browser.
37
+ */
38
+ const REQUIRES_DESKTOP = true;
39
+
40
+ /**
41
+ * The Homebrew cask name for Safari Technology Preview.
42
+ * This cask downloads the application directly from Apple's servers.
43
+ */
44
+ const HOMEBREW_CASK_NAME = 'safari-technology-preview';
45
+
46
+ /**
47
+ * The application name as it appears in /Applications.
48
+ * Used for checking if the application is already installed.
49
+ */
50
+ const APP_NAME = 'Safari Technology Preview';
51
+
52
+ /**
53
+ * Check if Safari Technology Preview is already installed.
54
+ *
55
+ * This function checks for the existence of the Safari Technology Preview
56
+ * application bundle in /Applications. This is more reliable than checking
57
+ * for a command-line tool since Safari Technology Preview is a GUI application.
58
+ *
59
+ * @returns {boolean} True if Safari Technology Preview.app exists in /Applications
60
+ */
61
+ function isAlreadyInstalled() {
62
+ return macosApps.isAppInstalled(APP_NAME);
63
+ }
9
64
 
10
65
  /**
11
- * Install Safari Technology Preview across supported platforms.
66
+ * Get the installed version of Safari Technology Preview.
67
+ *
68
+ * Reads the version from the application's Info.plist file. The version
69
+ * is typically formatted as "Release XX" where XX is the release number.
70
+ *
71
+ * @returns {string|null} The installed version, or null if not installed
72
+ */
73
+ function getInstalledVersion() {
74
+ return macosApps.getAppVersion(APP_NAME);
75
+ }
76
+
77
+ /**
78
+ * Install Safari Technology Preview on macOS using Homebrew.
79
+ *
80
+ * This function installs Safari Technology Preview via the Homebrew cask
81
+ * 'safari-technology-preview'. The cask downloads the application directly
82
+ * from Apple's servers and installs it to /Applications.
83
+ *
84
+ * Prerequisites:
85
+ * - macOS Sequoia (15.0) or later
86
+ * - Homebrew package manager installed
87
+ * - Administrative privileges (for Homebrew cask installation)
88
+ * - Approximately 200 MB disk space
89
+ *
90
+ * The installation is idempotent:
91
+ * - If already installed via the app bundle, it will skip installation
92
+ * - If already installed via Homebrew cask, it will skip installation
93
+ *
94
+ * After installation, Safari Technology Preview will be available:
95
+ * - In /Applications/Safari Technology Preview.app
96
+ * - In Launchpad
97
+ * - Via Spotlight search
98
+ *
99
+ * @returns {Promise<void>}
100
+ */
101
+ async function install_macos() {
102
+ console.log('Checking if Safari Technology Preview is already installed...');
103
+
104
+ // First check: Is the application bundle already present?
105
+ // This catches installations done manually or via Mac App Store
106
+ if (isAlreadyInstalled()) {
107
+ const version = getInstalledVersion();
108
+ if (version) {
109
+ console.log(`Safari Technology Preview ${version} is already installed, skipping installation.`);
110
+ } else {
111
+ console.log('Safari Technology Preview is already installed, skipping installation.');
112
+ }
113
+ return;
114
+ }
115
+
116
+ // Second check: Is the Homebrew cask already installed?
117
+ // This catches cases where the app might have been moved or renamed
118
+ const caskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
119
+ if (caskInstalled) {
120
+ console.log('Safari Technology Preview is already installed via Homebrew, skipping installation.');
121
+ console.log('');
122
+ console.log('NOTE: If the application is not visible, check /Applications or reinstall:');
123
+ console.log(' brew reinstall --cask safari-technology-preview');
124
+ return;
125
+ }
126
+
127
+ // Verify Homebrew is available before attempting installation
128
+ if (!brew.isInstalled()) {
129
+ console.log('Homebrew is not installed. Please install Homebrew first.');
130
+ console.log('Run: dev install homebrew');
131
+ return;
132
+ }
133
+
134
+ console.log('Installing Safari Technology Preview via Homebrew...');
135
+ console.log('');
136
+ console.log('NOTE: Safari Technology Preview requires macOS 15.0 (Sequoia) or later.');
137
+ console.log('');
138
+
139
+ // Install Safari Technology Preview using Homebrew cask
140
+ // The --cask flag is handled by the brew.installCask() function
141
+ const result = await brew.installCask(HOMEBREW_CASK_NAME);
142
+
143
+ if (!result.success) {
144
+ // Check for the specific macOS version requirement error
145
+ if (result.output && result.output.includes('requires macOS')) {
146
+ console.log('Installation failed: Safari Technology Preview requires macOS 15.0 (Sequoia) or later.');
147
+ console.log('');
148
+ console.log('Your macOS version does not meet the minimum requirement.');
149
+ console.log('Please upgrade macOS before installing Safari Technology Preview.');
150
+ return;
151
+ }
152
+
153
+ console.log('Failed to install Safari Technology Preview via Homebrew.');
154
+ console.log(result.output);
155
+ return;
156
+ }
157
+
158
+ // Verify installation succeeded by checking if the app now exists
159
+ const verified = isAlreadyInstalled();
160
+ if (!verified) {
161
+ console.log('Installation may have completed, but the application was not found.');
162
+ console.log('Check /Applications for Safari Technology Preview.app');
163
+ return;
164
+ }
165
+
166
+ const installedVersion = getInstalledVersion();
167
+ if (installedVersion) {
168
+ console.log(`Safari Technology Preview ${installedVersion} installed successfully.`);
169
+ } else {
170
+ console.log('Safari Technology Preview installed successfully.');
171
+ }
172
+ console.log('');
173
+ console.log('To get started:');
174
+ console.log(' 1. Launch Safari Technology Preview from /Applications or Spotlight');
175
+ console.log(' 2. Enable the Develop menu: Settings > Advanced > Show features for web developers');
176
+ console.log(' 3. Access experimental features via Develop > Experimental Features');
177
+ console.log('');
178
+ console.log('Safari Technology Preview runs alongside your existing Safari installation');
179
+ console.log('and syncs bookmarks via iCloud.');
180
+ }
181
+
182
+ /**
183
+ * Handle Safari Technology Preview installation request on Ubuntu/Debian.
184
+ *
185
+ * Safari Technology Preview is not available for Ubuntu, Debian, or any
186
+ * Linux distribution. Apple develops Safari exclusively for macOS and iOS.
187
+ * This function gracefully informs the user of the platform limitation.
188
+ *
189
+ * @returns {Promise<void>}
190
+ */
191
+ async function install_ubuntu() {
192
+ console.log('Safari Technology Preview is not available for Ubuntu.');
193
+ return;
194
+ }
195
+
196
+ /**
197
+ * Handle Safari Technology Preview installation request on Ubuntu WSL.
198
+ *
199
+ * Safari Technology Preview is not available for WSL. WSL runs a Linux
200
+ * environment, and Safari has never been released for any Linux distribution.
201
+ * This function gracefully informs the user of the platform limitation.
202
+ *
203
+ * @returns {Promise<void>}
204
+ */
205
+ async function install_ubuntu_wsl() {
206
+ console.log('Safari Technology Preview is not available for WSL.');
207
+ return;
208
+ }
209
+
210
+ /**
211
+ * Handle Safari Technology Preview installation request on Raspberry Pi OS.
212
+ *
213
+ * Safari Technology Preview is not available for Raspberry Pi OS. Apple
214
+ * does not release Safari for any Linux distribution, and Raspberry Pi
215
+ * devices run Linux-based operating systems. This function gracefully
216
+ * informs the user of the platform limitation.
217
+ *
218
+ * @returns {Promise<void>}
219
+ */
220
+ async function install_raspbian() {
221
+ console.log('Safari Technology Preview is not available for Raspberry Pi OS.');
222
+ return;
223
+ }
224
+
225
+ /**
226
+ * Handle Safari Technology Preview installation request on Amazon Linux/RHEL.
227
+ *
228
+ * Safari Technology Preview is not available for Amazon Linux, RHEL, CentOS,
229
+ * Fedora, or any RPM-based Linux distribution. Apple develops Safari
230
+ * exclusively for macOS. This function gracefully informs the user of the
231
+ * platform limitation.
232
+ *
233
+ * @returns {Promise<void>}
234
+ */
235
+ async function install_amazon_linux() {
236
+ console.log('Safari Technology Preview is not available for Amazon Linux.');
237
+ return;
238
+ }
239
+
240
+ /**
241
+ * Handle Safari Technology Preview installation request on Windows.
242
+ *
243
+ * Safari Technology Preview is not available for Windows. Apple discontinued
244
+ * Safari for Windows in 2012 with Safari 5.1.7, and Safari Technology Preview
245
+ * has never been released for Windows. This function gracefully informs the
246
+ * user of the platform limitation.
247
+ *
248
+ * @returns {Promise<void>}
249
+ */
250
+ async function install_windows() {
251
+ console.log('Safari Technology Preview is not available for Windows.');
252
+ return;
253
+ }
254
+
255
+ /**
256
+ * Handle Safari Technology Preview installation request on Git Bash.
257
+ *
258
+ * Safari Technology Preview is not available for Windows (Git Bash runs
259
+ * on Windows). Apple discontinued Safari for Windows in 2012, and Safari
260
+ * Technology Preview has only ever been available for macOS. This function
261
+ * gracefully informs the user of the platform limitation.
262
+ *
263
+ * @returns {Promise<void>}
264
+ */
265
+ async function install_gitbash() {
266
+ console.log('Safari Technology Preview is not available for Windows.');
267
+ return;
268
+ }
269
+
270
+ /**
271
+ * Check if Safari Technology Preview is already installed on the system.
272
+ *
273
+ * This function checks for Safari Technology Preview installation on macOS
274
+ * by looking for the application bundle in /Applications. Returns false on
275
+ * all non-macOS platforms since Safari Technology Preview is macOS-only.
276
+ *
277
+ * @returns {Promise<boolean>} True if Safari Technology Preview is installed, false otherwise
278
+ */
279
+ async function isInstalled() {
280
+ const platform = os.detect();
281
+
282
+ // Safari Technology Preview is macOS-only
283
+ if (platform.type !== 'macos') {
284
+ return false;
285
+ }
286
+
287
+ // Check if app bundle exists
288
+ return isAlreadyInstalled();
289
+ }
290
+
291
+ /**
292
+ * Check if this installer is supported on the current platform.
293
+ * Safari Technology Preview is ONLY available on macOS.
294
+ * @returns {boolean} True if installation is supported on this platform
295
+ */
296
+ function isEligible() {
297
+ const platform = os.detect();
298
+ if (platform.type !== 'macos') {
299
+ return false;
300
+ }
301
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
302
+ return false;
303
+ }
304
+ return true;
305
+ }
306
+
307
+ /**
308
+ * Main installation entry point - detects platform and runs appropriate installer.
309
+ *
310
+ * This function detects the current operating system and dispatches to the
311
+ * appropriate platform-specific installer function. Safari Technology Preview
312
+ * is only available on macOS; all other platforms will receive a graceful
313
+ * message indicating the software is not available.
314
+ *
315
+ * Platform Support:
316
+ * - macOS: Full installation via Homebrew Cask
317
+ * - All other platforms: Graceful "not available" message
12
318
  *
13
319
  * @returns {Promise<void>}
14
320
  */
15
321
  async function install() {
16
322
  const platform = os.detect();
17
323
 
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 };
324
+ // Map platform types to their corresponding installer functions
325
+ // Safari Technology Preview is macOS-only, but we provide graceful
326
+ // handlers for all platforms to avoid errors
327
+ const installers = {
328
+ 'macos': install_macos,
329
+ 'ubuntu': install_ubuntu,
330
+ 'debian': install_ubuntu,
331
+ 'wsl': install_ubuntu_wsl,
332
+ 'raspbian': install_raspbian,
333
+ 'amazon_linux': install_amazon_linux,
334
+ 'fedora': install_amazon_linux,
335
+ 'rhel': install_amazon_linux,
336
+ 'windows': install_windows,
337
+ 'gitbash': install_gitbash,
338
+ };
339
+
340
+ // Look up the installer for the detected platform
341
+ const installer = installers[platform.type];
342
+
343
+ // If no installer exists for this platform, inform the user gracefully
344
+ if (!installer) {
345
+ console.log(`Safari Technology Preview is not available for ${platform.type}.`);
346
+ return;
347
+ }
348
+
349
+ // Run the platform-specific installer
350
+ await installer();
351
+ }
352
+
353
+ // Export all functions for use as a module and for testing
354
+ module.exports = {
355
+ REQUIRES_DESKTOP,
356
+ install,
357
+ isInstalled,
358
+ isEligible,
359
+ install_macos,
360
+ install_ubuntu,
361
+ install_ubuntu_wsl,
362
+ install_raspbian,
363
+ install_amazon_linux,
364
+ install_windows,
365
+ install_gitbash,
366
+ };
41
367
 
368
+ // Allow direct execution: node safari-tech-preview.js
42
369
  if (require.main === module) {
43
- install();
370
+ install().catch(err => {
371
+ console.error(err.message);
372
+ process.exit(1);
373
+ });
44
374
  }