@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
@@ -1,44 +1,931 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Install Go.
4
+ * @fileoverview Install Go (Golang) programming language.
5
5
  * @module installs/go
6
+ *
7
+ * Go is an open-source programming language developed by Google that makes it
8
+ * simple to build secure, scalable systems. Go is statically typed, compiled,
9
+ * and designed for simplicity and reliability.
10
+ *
11
+ * This installer provides:
12
+ * - Homebrew installation for macOS
13
+ * - Official Go distribution for Linux platforms (Ubuntu, Raspberry Pi OS, Amazon Linux)
14
+ * - Chocolatey installation for Windows
15
+ *
16
+ * IMPORTANT PLATFORM NOTES:
17
+ * - macOS: Installs via Homebrew formula
18
+ * - Ubuntu/Debian: Downloads official tarball from go.dev
19
+ * - Raspberry Pi OS: Downloads ARM-specific tarball (auto-detects 32/64-bit)
20
+ * - Amazon Linux: Downloads official tarball from go.dev
21
+ * - Windows: Installs via Chocolatey
22
+ * - WSL: Downloads official tarball (same as Ubuntu)
23
+ * - Git Bash: Installs on Windows host via Chocolatey/PowerShell
6
24
  */
7
25
 
8
26
  const os = require('../utils/common/os');
27
+ const shell = require('../utils/common/shell');
28
+ const brew = require('../utils/macos/brew');
29
+ const choco = require('../utils/windows/choco');
30
+
31
+ /**
32
+ * The Homebrew formula name for Go on macOS.
33
+ */
34
+ const HOMEBREW_FORMULA_NAME = 'go';
35
+
36
+ /**
37
+ * The Chocolatey package name for Go on Windows.
38
+ */
39
+ const CHOCO_PACKAGE_NAME = 'golang';
40
+
41
+ /**
42
+ * The Go version API endpoint that returns the latest stable version.
43
+ * This URL returns plain text with the version string (e.g., "go1.25.5").
44
+ */
45
+ const GO_VERSION_URL = 'https://go.dev/VERSION?m=text';
46
+
47
+ /**
48
+ * The base URL for downloading Go tarballs from the official website.
49
+ */
50
+ const GO_DOWNLOAD_BASE_URL = 'https://go.dev/dl';
51
+
52
+ /**
53
+ * The standard installation directory for Go on Linux systems.
54
+ * This is the recommended location per the official Go installation guide.
55
+ */
56
+ const GO_INSTALL_DIR = '/usr/local/go';
57
+
58
+ /**
59
+ * Check if Go is installed by verifying the 'go' command exists.
60
+ *
61
+ * This performs a quick check across all platforms. Note that if Go is
62
+ * installed but not in PATH, this will return false.
63
+ *
64
+ * @returns {boolean} True if the go command is available, false otherwise
65
+ */
66
+ function isGoCommandAvailable() {
67
+ return shell.commandExists('go');
68
+ }
69
+
70
+ /**
71
+ * Get the installed Go version.
72
+ *
73
+ * Executes 'go version' to determine the currently installed version.
74
+ * Returns the version string (e.g., "1.25.5") if successful.
75
+ *
76
+ * This function checks both:
77
+ * 1. The 'go' command in PATH (for convenience)
78
+ * 2. The standard installation location /usr/local/go/bin/go (for Linux)
79
+ *
80
+ * This ensures idempotency works correctly even when the shell profile
81
+ * hasn't been sourced yet in the current session.
82
+ *
83
+ * @returns {Promise<string|null>} Go version string, or null if not installed
84
+ */
85
+ async function getGoVersion() {
86
+ // First try the go command if it's in PATH
87
+ if (isGoCommandAvailable()) {
88
+ const result = await shell.exec('go version');
89
+ if (result.code === 0 && result.stdout) {
90
+ // Output format: "go version go1.25.5 darwin/arm64"
91
+ const match = result.stdout.match(/go version go([\d.]+)/);
92
+ return match ? match[1] : result.stdout.trim();
93
+ }
94
+ }
95
+
96
+ // If not in PATH, check the standard Linux installation location
97
+ // This is important for idempotency in the same session before profile is sourced
98
+ const result = await shell.exec('/usr/local/go/bin/go version 2>/dev/null');
99
+ if (result.code === 0 && result.stdout) {
100
+ const match = result.stdout.match(/go version go([\d.]+)/);
101
+ return match ? match[1] : result.stdout.trim();
102
+ }
103
+
104
+ return null;
105
+ }
9
106
 
10
107
  /**
11
- * Install Go across supported platforms.
108
+ * Fetch the latest Go version from the official Go website.
109
+ *
110
+ * Queries the Go version API to get the current stable version string.
111
+ * The API returns text like "go1.25.5" on the first line.
112
+ *
113
+ * @returns {Promise<string|null>} Version string (e.g., "go1.25.5"), or null on failure
114
+ */
115
+ async function fetchLatestGoVersion() {
116
+ const result = await shell.exec(`curl -sL '${GO_VERSION_URL}' | head -n1`);
117
+ if (result.code === 0 && result.stdout) {
118
+ // The API returns something like "go1.25.5\ntime 2024-01-01..."
119
+ // We only need the first line
120
+ return result.stdout.trim().split('\n')[0];
121
+ }
122
+ return null;
123
+ }
124
+
125
+ /**
126
+ * Remove any existing Go installations from the system.
127
+ *
128
+ * This function removes Go installed via APT (golang-go package) and
129
+ * also removes any manually installed Go in /usr/local/go. This ensures
130
+ * a clean slate before installing the latest version.
131
+ *
132
+ * @returns {Promise<void>}
133
+ */
134
+ async function removeExistingGoInstallations() {
135
+ console.log('Removing any existing Go installations...');
136
+
137
+ // Remove APT-installed Go packages (may be outdated)
138
+ await shell.exec(
139
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get remove -y golang-go golang 2>/dev/null || true'
140
+ );
141
+
142
+ // Remove any manual installation in /usr/local/go
143
+ await shell.exec('sudo rm -rf /usr/local/go 2>/dev/null || true');
144
+ }
145
+
146
+ /**
147
+ * Install required utilities (wget, curl) on Debian-based systems.
148
+ *
149
+ * These utilities are needed to download Go from the official website.
150
+ * Uses DEBIAN_FRONTEND=noninteractive for unattended installation.
151
+ *
152
+ * @returns {Promise<void>}
153
+ * @throws {Error} If utility installation fails
154
+ */
155
+ async function installRequiredUtilities() {
156
+ console.log('Installing required utilities (wget, curl)...');
157
+
158
+ const updateResult = await shell.exec(
159
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get update -y'
160
+ );
161
+ if (updateResult.code !== 0) {
162
+ console.log('Warning: apt-get update had issues, continuing...');
163
+ }
164
+
165
+ const installResult = await shell.exec(
166
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y wget curl'
167
+ );
168
+ if (installResult.code !== 0) {
169
+ throw new Error(`Failed to install required utilities: ${installResult.stderr}`);
170
+ }
171
+ }
172
+
173
+ /**
174
+ * Download and extract Go tarball to /usr/local.
175
+ *
176
+ * Downloads the specified Go version tarball and extracts it to the
177
+ * standard location (/usr/local/go). The tarball is downloaded to /tmp
178
+ * and cleaned up after extraction.
179
+ *
180
+ * @param {string} goVersion - The Go version to download (e.g., "go1.25.5")
181
+ * @param {string} goArch - The architecture suffix (e.g., "linux-amd64", "linux-arm64")
182
+ * @returns {Promise<void>}
183
+ * @throws {Error} If download or extraction fails
184
+ */
185
+ async function downloadAndInstallGo(goVersion, goArch) {
186
+ const tarballName = `${goVersion}.${goArch}.tar.gz`;
187
+ const downloadUrl = `${GO_DOWNLOAD_BASE_URL}/${tarballName}`;
188
+ const tempPath = `/tmp/go.tar.gz`;
189
+
190
+ console.log(`Downloading Go ${goVersion} for ${goArch}...`);
191
+ console.log(`URL: ${downloadUrl}`);
192
+
193
+ // Download the tarball
194
+ const downloadResult = await shell.exec(
195
+ `wget -q "${downloadUrl}" -O ${tempPath}`
196
+ );
197
+ if (downloadResult.code !== 0) {
198
+ throw new Error(
199
+ `Failed to download Go.\n` +
200
+ `URL: ${downloadUrl}\n` +
201
+ `Error: ${downloadResult.stderr}\n\n` +
202
+ `Please check your internet connection and try again.`
203
+ );
204
+ }
205
+
206
+ // Extract to /usr/local
207
+ console.log('Extracting Go to /usr/local...');
208
+ const extractResult = await shell.exec(
209
+ `sudo tar -C /usr/local -xzf ${tempPath}`
210
+ );
211
+ if (extractResult.code !== 0) {
212
+ throw new Error(
213
+ `Failed to extract Go tarball.\n` +
214
+ `Error: ${extractResult.stderr}\n\n` +
215
+ `Ensure you have sudo privileges and /usr/local is writable.`
216
+ );
217
+ }
218
+
219
+ // Clean up the downloaded tarball
220
+ await shell.exec(`rm -f ${tempPath}`);
221
+ }
222
+
223
+ /**
224
+ * Configure Go environment variables by adding to shell profile.
225
+ *
226
+ * Adds the Go binary directory (/usr/local/go/bin) and the user's Go
227
+ * workspace bin directory ($HOME/go/bin) to the PATH. Writes to the
228
+ * appropriate shell profile based on the platform.
229
+ *
230
+ * @param {string} profilePath - Path to the shell profile file (e.g., ~/.profile, ~/.bashrc)
231
+ * @returns {Promise<void>}
232
+ */
233
+ async function configureGoEnvironment(profilePath) {
234
+ console.log(`Configuring Go environment in ${profilePath}...`);
235
+
236
+ // Check if Go path is already configured to avoid duplicates
237
+ const checkResult = await shell.exec(`grep -q '/usr/local/go/bin' ${profilePath} 2>/dev/null`);
238
+ if (checkResult.code === 0) {
239
+ console.log('Go PATH already configured in profile, skipping...');
240
+ return;
241
+ }
242
+
243
+ // Add Go to PATH
244
+ const pathConfig = `
245
+ # Go programming language
246
+ export PATH=$PATH:/usr/local/go/bin
247
+ export PATH=$PATH:$HOME/go/bin
248
+ `;
249
+
250
+ const appendResult = await shell.exec(
251
+ `echo '${pathConfig}' >> ${profilePath}`
252
+ );
253
+ if (appendResult.code !== 0) {
254
+ console.log(`Warning: Could not update ${profilePath}. You may need to add Go to PATH manually.`);
255
+ }
256
+ }
257
+
258
+ /**
259
+ * Install Go on macOS using Homebrew.
260
+ *
261
+ * Prerequisites:
262
+ * - macOS 12 (Monterey) or later
263
+ * - Homebrew package manager installed
264
+ * - Apple Silicon (M1/M2/M3/M4) or Intel processor
265
+ *
266
+ * Homebrew automatically handles PATH configuration and version management.
267
+ * With modern Go (1.16+), you do not need to set GOROOT or GOPATH manually.
268
+ *
269
+ * @returns {Promise<void>}
270
+ * @throws {Error} If Homebrew is not installed or installation fails
271
+ */
272
+ async function install_macos() {
273
+ console.log('Checking if Go is already installed...');
274
+
275
+ // Check if Go is already installed
276
+ const existingVersion = await getGoVersion();
277
+ if (existingVersion) {
278
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
279
+ return;
280
+ }
281
+
282
+ // Also check if the formula is installed (Go may be installed but not in current PATH)
283
+ const formulaInstalled = await brew.isFormulaInstalled(HOMEBREW_FORMULA_NAME);
284
+ if (formulaInstalled) {
285
+ console.log('Go is already installed via Homebrew, skipping installation.');
286
+ console.log('');
287
+ console.log('NOTE: If go commands are not working, ensure Homebrew is in your PATH.');
288
+ console.log('For Apple Silicon: eval "$(/opt/homebrew/bin/brew shellenv)"');
289
+ console.log('For Intel: eval "$(/usr/local/bin/brew shellenv)"');
290
+ return;
291
+ }
292
+
293
+ // Verify Homebrew is available
294
+ if (!brew.isInstalled()) {
295
+ throw new Error(
296
+ 'Homebrew is not installed. Please install Homebrew first using:\n' +
297
+ ' dev install homebrew\n' +
298
+ 'Then retry installing Go.'
299
+ );
300
+ }
301
+
302
+ console.log('Installing Go via Homebrew...');
303
+
304
+ // Install Go formula
305
+ const result = await brew.install(HOMEBREW_FORMULA_NAME);
306
+
307
+ if (!result.success) {
308
+ throw new Error(
309
+ `Failed to install Go via Homebrew.\n` +
310
+ `Output: ${result.output}\n\n` +
311
+ `Troubleshooting:\n` +
312
+ ` 1. Run 'brew update && brew cleanup' and retry\n` +
313
+ ` 2. Try manual installation: brew reinstall go`
314
+ );
315
+ }
316
+
317
+ // Verify installation
318
+ const version = await getGoVersion();
319
+ if (!version) {
320
+ console.log('');
321
+ console.log('Go was installed but may not be in your current PATH.');
322
+ console.log('Please restart your terminal or run:');
323
+ console.log(' source ~/.zprofile');
324
+ console.log('');
325
+ console.log('Then verify with: go version');
326
+ return;
327
+ }
328
+
329
+ console.log(`Go ${version} installed successfully.`);
330
+ console.log('');
331
+ console.log('To use Go tools installed via "go install", add this to ~/.zprofile:');
332
+ console.log(' export PATH="$PATH:$HOME/go/bin"');
333
+ }
334
+
335
+ /**
336
+ * Install Go on Ubuntu/Debian using official tarball from go.dev.
337
+ *
338
+ * Prerequisites:
339
+ * - Ubuntu 20.04 (Focal) or later, or Debian 11 (Bullseye) or later (64-bit)
340
+ * - sudo privileges
341
+ * - At least 500 MB free disk space
342
+ *
343
+ * IMPORTANT: The golang-go package in Ubuntu/Debian repositories may be
344
+ * outdated. This function downloads the latest version from go.dev.
345
+ *
346
+ * @returns {Promise<void>}
347
+ * @throws {Error} If installation fails
348
+ */
349
+ async function install_ubuntu() {
350
+ console.log('Checking if Go is already installed...');
351
+
352
+ // Check if Go is already installed
353
+ const existingVersion = await getGoVersion();
354
+ if (existingVersion) {
355
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
356
+ return;
357
+ }
358
+
359
+ // Remove any existing Go installations (APT packages may be outdated)
360
+ await removeExistingGoInstallations();
361
+
362
+ // Install required utilities
363
+ await installRequiredUtilities();
364
+
365
+ // Fetch the latest Go version
366
+ console.log('Fetching latest Go version...');
367
+ const goVersion = await fetchLatestGoVersion();
368
+ if (!goVersion) {
369
+ throw new Error(
370
+ 'Could not determine the latest Go version.\n' +
371
+ 'Please check your internet connection and try again.'
372
+ );
373
+ }
374
+ console.log(`Latest version: ${goVersion}`);
375
+
376
+ // Download and install Go
377
+ await downloadAndInstallGo(goVersion, 'linux-amd64');
378
+
379
+ // Configure environment
380
+ await configureGoEnvironment('~/.profile');
381
+
382
+ // Source the profile to make Go available in the current session
383
+ await shell.exec('source ~/.profile 2>/dev/null || true');
384
+
385
+ // Verify installation by checking the binary directly
386
+ const verifyResult = await shell.exec('/usr/local/go/bin/go version');
387
+ if (verifyResult.code !== 0) {
388
+ throw new Error(
389
+ 'Installation appeared to complete but Go was not found.\n\n' +
390
+ 'Please try:\n' +
391
+ ' 1. Log out and log back in, or run: source ~/.profile\n' +
392
+ ' 2. Verify installation: /usr/local/go/bin/go version'
393
+ );
394
+ }
395
+
396
+ // Extract version from output for display
397
+ const versionMatch = verifyResult.stdout.match(/go version go([\d.]+)/);
398
+ const installedVersion = versionMatch ? versionMatch[1] : goVersion;
399
+
400
+ console.log(`Go ${installedVersion} installed successfully.`);
401
+ console.log('');
402
+ console.log('IMPORTANT: To use Go in your current terminal session:');
403
+ console.log(' source ~/.profile');
404
+ console.log('');
405
+ console.log('Or log out and log back in for changes to take effect.');
406
+ console.log('');
407
+ console.log('Verify installation with: go version');
408
+ }
409
+
410
+ /**
411
+ * Install Go on Raspberry Pi OS using official tarball from go.dev.
412
+ *
413
+ * Prerequisites:
414
+ * - Raspberry Pi OS (64-bit recommended) - Bookworm or Bullseye
415
+ * - Raspberry Pi 3B+ or later (64-bit capable hardware)
416
+ * - At least 500 MB free disk space
417
+ * - sudo privileges
418
+ *
419
+ * This function automatically detects the architecture (aarch64 vs armv7l)
420
+ * and downloads the appropriate Go binary:
421
+ * - aarch64 (64-bit): linux-arm64
422
+ * - armv7l/armv6l (32-bit): linux-armv6l
423
+ *
424
+ * @returns {Promise<void>}
425
+ * @throws {Error} If installation fails
426
+ */
427
+ async function install_raspbian() {
428
+ console.log('Checking if Go is already installed...');
429
+
430
+ // Check if Go is already installed
431
+ const existingVersion = await getGoVersion();
432
+ if (existingVersion) {
433
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
434
+ return;
435
+ }
436
+
437
+ // Detect architecture
438
+ const archResult = await shell.exec('uname -m');
439
+ const arch = archResult.stdout.trim();
440
+
441
+ let goArch;
442
+ if (arch === 'aarch64') {
443
+ goArch = 'linux-arm64';
444
+ console.log('Detected 64-bit Raspberry Pi OS (arm64).');
445
+ } else if (arch === 'armv7l' || arch === 'armv6l') {
446
+ goArch = 'linux-armv6l';
447
+ console.log(`Detected 32-bit Raspberry Pi OS (${arch}).`);
448
+ console.log('');
449
+ console.log('NOTE: For better performance and long-term support, consider');
450
+ console.log('upgrading to 64-bit Raspberry Pi OS.');
451
+ console.log('');
452
+ } else {
453
+ throw new Error(
454
+ `Unsupported Raspberry Pi architecture: ${arch}\n` +
455
+ 'Expected aarch64 (64-bit) or armv7l/armv6l (32-bit).'
456
+ );
457
+ }
458
+
459
+ // Remove any existing Go installations
460
+ await removeExistingGoInstallations();
461
+
462
+ // Install required utilities
463
+ await installRequiredUtilities();
464
+
465
+ // Fetch the latest Go version
466
+ console.log('Fetching latest Go version...');
467
+ const goVersion = await fetchLatestGoVersion();
468
+ if (!goVersion) {
469
+ throw new Error(
470
+ 'Could not determine the latest Go version.\n' +
471
+ 'Please check your internet connection and try again.'
472
+ );
473
+ }
474
+ console.log(`Latest version: ${goVersion}`);
475
+
476
+ // Download and install Go
477
+ await downloadAndInstallGo(goVersion, goArch);
478
+
479
+ // Configure environment
480
+ await configureGoEnvironment('~/.profile');
481
+
482
+ // Source the profile
483
+ await shell.exec('source ~/.profile 2>/dev/null || true');
484
+
485
+ // Verify installation
486
+ const verifyResult = await shell.exec('/usr/local/go/bin/go version');
487
+ if (verifyResult.code !== 0) {
488
+ throw new Error(
489
+ 'Installation appeared to complete but Go was not found.\n\n' +
490
+ 'Please try:\n' +
491
+ ' 1. Log out and log back in, or run: source ~/.profile\n' +
492
+ ' 2. Verify installation: /usr/local/go/bin/go version'
493
+ );
494
+ }
495
+
496
+ const versionMatch = verifyResult.stdout.match(/go version go([\d.]+)/);
497
+ const installedVersion = versionMatch ? versionMatch[1] : goVersion;
498
+
499
+ console.log(`Go ${installedVersion} installed successfully.`);
500
+ console.log('');
501
+ console.log('IMPORTANT: To use Go in your current terminal session:');
502
+ console.log(' source ~/.profile');
503
+ console.log('');
504
+ console.log('Or log out and log back in for changes to take effect.');
505
+ console.log('');
506
+ console.log('NOTE: Compilation may be slower on Raspberry Pi due to limited');
507
+ console.log('CPU and RAM. Consider adding swap space if you encounter memory issues.');
508
+ }
509
+
510
+ /**
511
+ * Install Go on Amazon Linux using official tarball from go.dev.
512
+ *
513
+ * Prerequisites:
514
+ * - Amazon Linux 2023 (AL2023) or Amazon Linux 2 (AL2)
515
+ * - sudo privileges
516
+ * - EC2 instance or compatible environment
517
+ *
518
+ * This function downloads the latest Go version from go.dev rather than
519
+ * using the Amazon repository version, which may be outdated.
520
+ *
521
+ * @returns {Promise<void>}
522
+ * @throws {Error} If installation fails
523
+ */
524
+ async function install_amazon_linux() {
525
+ console.log('Checking if Go is already installed...');
526
+
527
+ // Check if Go is already installed
528
+ const existingVersion = await getGoVersion();
529
+ if (existingVersion) {
530
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
531
+ return;
532
+ }
533
+
534
+ // Detect package manager (dnf for AL2023, yum for AL2)
535
+ const hasDnf = shell.commandExists('dnf');
536
+ const hasYum = shell.commandExists('yum');
537
+ const packageManager = hasDnf ? 'dnf' : (hasYum ? 'yum' : null);
538
+
539
+ if (!packageManager) {
540
+ throw new Error(
541
+ 'Neither dnf nor yum package manager found.\n' +
542
+ 'This installer supports Amazon Linux 2023 (dnf) and Amazon Linux 2 (yum).'
543
+ );
544
+ }
545
+
546
+ console.log(`Detected package manager: ${packageManager}`);
547
+
548
+ // Remove any existing Go installations
549
+ console.log('Removing any existing Go installations...');
550
+ await shell.exec('sudo rm -rf /usr/local/go 2>/dev/null || true');
551
+
552
+ // Remove repository-installed Go if present
553
+ await shell.exec(`sudo ${packageManager} remove -y golang 2>/dev/null || true`);
554
+
555
+ // Install required utilities
556
+ console.log('Installing required utilities (wget, curl, tar)...');
557
+ const installResult = await shell.exec(
558
+ `sudo ${packageManager} install -y wget curl tar`
559
+ );
560
+ if (installResult.code !== 0) {
561
+ console.log('Warning: Could not install utilities, they may already exist.');
562
+ }
563
+
564
+ // Fetch the latest Go version
565
+ console.log('Fetching latest Go version...');
566
+ const goVersion = await fetchLatestGoVersion();
567
+ if (!goVersion) {
568
+ throw new Error(
569
+ 'Could not determine the latest Go version.\n' +
570
+ 'Please check your internet connection and try again.'
571
+ );
572
+ }
573
+ console.log(`Latest version: ${goVersion}`);
574
+
575
+ // Download and install Go
576
+ await downloadAndInstallGo(goVersion, 'linux-amd64');
577
+
578
+ // Configure environment (Amazon Linux uses .bashrc)
579
+ await configureGoEnvironment('~/.bashrc');
580
+
581
+ // Source the profile
582
+ await shell.exec('source ~/.bashrc 2>/dev/null || true');
583
+
584
+ // Verify installation
585
+ const verifyResult = await shell.exec('/usr/local/go/bin/go version');
586
+ if (verifyResult.code !== 0) {
587
+ throw new Error(
588
+ 'Installation appeared to complete but Go was not found.\n\n' +
589
+ 'Please try:\n' +
590
+ ' 1. Log out and log back in, or run: source ~/.bashrc\n' +
591
+ ' 2. Verify installation: /usr/local/go/bin/go version'
592
+ );
593
+ }
594
+
595
+ const versionMatch = verifyResult.stdout.match(/go version go([\d.]+)/);
596
+ const installedVersion = versionMatch ? versionMatch[1] : goVersion;
597
+
598
+ console.log(`Go ${installedVersion} installed successfully.`);
599
+ console.log('');
600
+ console.log('IMPORTANT: To use Go in your current terminal session:');
601
+ console.log(' source ~/.bashrc');
602
+ console.log('');
603
+ console.log('Or log out and log back in for changes to take effect.');
604
+ }
605
+
606
+ /**
607
+ * Install Go on Windows using Chocolatey.
608
+ *
609
+ * Prerequisites:
610
+ * - Windows 10 version 1809 or later, or Windows 11
611
+ * - Administrator PowerShell or Command Prompt
612
+ * - Chocolatey package manager installed
613
+ *
614
+ * Chocolatey installs Go using the official MSI installer with silent flags.
615
+ * After installation, the PATH is updated automatically.
616
+ *
617
+ * @returns {Promise<void>}
618
+ * @throws {Error} If Chocolatey is not installed or installation fails
619
+ */
620
+ async function install_windows() {
621
+ console.log('Checking if Go is already installed...');
622
+
623
+ // Check if Go is already installed
624
+ const existingVersion = await getGoVersion();
625
+ if (existingVersion) {
626
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
627
+ return;
628
+ }
629
+
630
+ // Check if Go package is installed via Chocolatey
631
+ const packageInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
632
+ if (packageInstalled) {
633
+ console.log('Go is already installed via Chocolatey, skipping installation.');
634
+ console.log('');
635
+ console.log('NOTE: If go commands are not working, close and reopen your terminal');
636
+ console.log('or run: refreshenv');
637
+ return;
638
+ }
639
+
640
+ // Verify Chocolatey is available
641
+ if (!choco.isInstalled()) {
642
+ throw new Error(
643
+ 'Chocolatey is not installed. Please install Chocolatey first:\n\n' +
644
+ 'Run the following in an Administrator PowerShell:\n' +
645
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
646
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
647
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
648
+ 'Then retry installing Go.'
649
+ );
650
+ }
651
+
652
+ console.log('Installing Go via Chocolatey...');
653
+ console.log('This may take a few minutes...');
654
+
655
+ // Install Go
656
+ const result = await choco.install(CHOCO_PACKAGE_NAME);
657
+
658
+ if (!result.success) {
659
+ throw new Error(
660
+ `Failed to install Go via Chocolatey.\n` +
661
+ `Output: ${result.output}\n\n` +
662
+ `Troubleshooting:\n` +
663
+ ` 1. Ensure you are running as Administrator\n` +
664
+ ` 2. Try manual installation: choco install golang -y --force`
665
+ );
666
+ }
667
+
668
+ console.log('Go installed successfully.');
669
+ console.log('');
670
+ console.log('IMPORTANT: Close and reopen your terminal for PATH changes to take effect.');
671
+ console.log('Or in PowerShell, run: refreshenv');
672
+ console.log('');
673
+ console.log('Then verify with: go version');
674
+ console.log('');
675
+ console.log('To use Go tools installed via "go install", ensure this is in your PATH:');
676
+ console.log(' %USERPROFILE%\\go\\bin');
677
+ }
678
+
679
+ /**
680
+ * Install Go on Ubuntu running in WSL (Windows Subsystem for Linux).
681
+ *
682
+ * Prerequisites:
683
+ * - Windows 10 version 2004 or later, or Windows 11
684
+ * - WSL 2 enabled with Ubuntu distribution installed
685
+ * - sudo privileges within WSL
686
+ *
687
+ * This function installs Go directly within WSL using the same method
688
+ * as native Ubuntu. The installation is independent of any Windows
689
+ * Go installation.
690
+ *
691
+ * @returns {Promise<void>}
692
+ * @throws {Error} If installation fails
693
+ */
694
+ async function install_ubuntu_wsl() {
695
+ console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
696
+ console.log('');
697
+ console.log('Installing Go directly within WSL...');
698
+ console.log('');
699
+
700
+ // Check if Go is already installed
701
+ const existingVersion = await getGoVersion();
702
+ if (existingVersion) {
703
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
704
+ return;
705
+ }
706
+
707
+ // Remove any existing Go installations
708
+ await removeExistingGoInstallations();
709
+
710
+ // Install required utilities
711
+ await installRequiredUtilities();
712
+
713
+ // Fetch the latest Go version
714
+ console.log('Fetching latest Go version...');
715
+ const goVersion = await fetchLatestGoVersion();
716
+ if (!goVersion) {
717
+ throw new Error(
718
+ 'Could not determine the latest Go version.\n' +
719
+ 'Please check your internet connection and try again.'
720
+ );
721
+ }
722
+ console.log(`Latest version: ${goVersion}`);
723
+
724
+ // Download and install Go
725
+ await downloadAndInstallGo(goVersion, 'linux-amd64');
726
+
727
+ // Configure environment (WSL Ubuntu uses .bashrc)
728
+ await configureGoEnvironment('~/.bashrc');
729
+
730
+ // Source the profile
731
+ await shell.exec('source ~/.bashrc 2>/dev/null || true');
732
+
733
+ // Verify installation
734
+ const verifyResult = await shell.exec('/usr/local/go/bin/go version');
735
+ if (verifyResult.code !== 0) {
736
+ throw new Error(
737
+ 'Installation appeared to complete but Go was not found.\n\n' +
738
+ 'Please try:\n' +
739
+ ' 1. Close and reopen your WSL terminal, or run: source ~/.bashrc\n' +
740
+ ' 2. Verify installation: /usr/local/go/bin/go version'
741
+ );
742
+ }
743
+
744
+ const versionMatch = verifyResult.stdout.match(/go version go([\d.]+)/);
745
+ const installedVersion = versionMatch ? versionMatch[1] : goVersion;
746
+
747
+ console.log(`Go ${installedVersion} installed successfully.`);
748
+ console.log('');
749
+ console.log('IMPORTANT for WSL users:');
750
+ console.log('');
751
+ console.log('1. To use Go in your current terminal session:');
752
+ console.log(' source ~/.bashrc');
753
+ console.log('');
754
+ console.log('2. For best performance, keep your Go code on the Linux filesystem');
755
+ console.log(' (e.g., ~/projects) rather than /mnt/c/ (Windows filesystem).');
756
+ console.log('');
757
+ console.log('3. Go binaries installed in WSL are Linux executables and cannot');
758
+ console.log(' run directly from Windows.');
759
+ }
760
+
761
+ /**
762
+ * Install Go from Git Bash on Windows.
763
+ *
764
+ * Git Bash runs within Windows, so this function installs Go on the
765
+ * Windows host using Chocolatey via PowerShell interop.
766
+ *
767
+ * Prerequisites:
768
+ * - Windows 10 or Windows 11 (64-bit)
769
+ * - Git Bash installed (comes with Git for Windows)
770
+ * - Chocolatey package manager installed on Windows
771
+ *
772
+ * @returns {Promise<void>}
773
+ * @throws {Error} If installation fails
774
+ */
775
+ async function install_gitbash() {
776
+ console.log('Detected Git Bash on Windows.');
777
+ console.log('Installing Go on the Windows host...');
778
+ console.log('');
779
+
780
+ // Check if Go is already available
781
+ const existingVersion = await getGoVersion();
782
+ if (existingVersion) {
783
+ console.log(`Go ${existingVersion} is already installed, skipping installation.`);
784
+ return;
785
+ }
786
+
787
+ // Install via PowerShell using Chocolatey
788
+ console.log('Installing Go via Chocolatey...');
789
+
790
+ const installResult = await shell.exec(
791
+ 'powershell.exe -NoProfile -Command "choco install golang -y"'
792
+ );
793
+
794
+ if (installResult.code !== 0) {
795
+ throw new Error(
796
+ `Failed to install Go.\n` +
797
+ `Output: ${installResult.stdout || installResult.stderr}\n\n` +
798
+ `Troubleshooting:\n` +
799
+ ` 1. Ensure Chocolatey is installed on Windows\n` +
800
+ ` 2. Run Git Bash as Administrator and retry\n` +
801
+ ` 3. Try installing directly from PowerShell:\n` +
802
+ ` choco install golang -y`
803
+ );
804
+ }
805
+
806
+ console.log('Go installed successfully.');
807
+ console.log('');
808
+ console.log('IMPORTANT: Close and reopen Git Bash for PATH changes to take effect.');
809
+ console.log('');
810
+ console.log('Then verify with: go version');
811
+ console.log('');
812
+ console.log('If go is still not found, you may need to add it to your Git Bash PATH:');
813
+ console.log(' echo \'export PATH="$PATH:/c/Program Files/Go/bin"\' >> ~/.bashrc');
814
+ console.log(' echo \'export PATH="$PATH:$HOME/go/bin"\' >> ~/.bashrc');
815
+ console.log(' source ~/.bashrc');
816
+ }
817
+
818
+ /**
819
+ * Check if Go is currently installed on the system.
820
+ *
821
+ * This function checks for Go installation across all supported platforms:
822
+ * - macOS: Checks for Go via Homebrew formula or go command
823
+ * - Windows: Checks for Go via Chocolatey or go command
824
+ * - Linux/Git Bash: Checks if go command exists in PATH
825
+ *
826
+ * @returns {Promise<boolean>} True if Go is installed, false otherwise
827
+ */
828
+ async function isInstalled() {
829
+ const platform = os.detect();
830
+
831
+ if (platform.type === 'macos') {
832
+ // Check if Go formula is installed via Homebrew
833
+ const formulaInstalled = await brew.isFormulaInstalled(HOMEBREW_FORMULA_NAME);
834
+ if (formulaInstalled) {
835
+ return true;
836
+ }
837
+ // Also check if go command exists
838
+ return isGoCommandAvailable();
839
+ }
840
+
841
+ if (platform.type === 'windows') {
842
+ // Check if Go package is installed via Chocolatey
843
+ const packageInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
844
+ if (packageInstalled) {
845
+ return true;
846
+ }
847
+ // Also check if go command exists
848
+ return isGoCommandAvailable();
849
+ }
850
+
851
+ // Linux, WSL, and Git Bash: Check if go command exists
852
+ return isGoCommandAvailable();
853
+ }
854
+
855
+ /**
856
+ * Check if this installer is supported on the current platform.
857
+ * Go is supported on all major platforms.
858
+ * @returns {boolean} True if installation is supported on this platform
859
+ */
860
+ function isEligible() {
861
+ const platform = os.detect();
862
+ return ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'rhel', 'fedora', 'windows', 'gitbash'].includes(platform.type);
863
+ }
864
+
865
+ /**
866
+ * Main installation entry point.
867
+ *
868
+ * Detects the current platform and runs the appropriate installer function.
869
+ * Handles platform-specific mappings to ensure all supported platforms
870
+ * have appropriate installation logic.
871
+ *
872
+ * Supported platforms:
873
+ * - macOS: Homebrew formula
874
+ * - Ubuntu/Debian: Official tarball from go.dev
875
+ * - Raspberry Pi OS: Official ARM tarball from go.dev
876
+ * - Amazon Linux/RHEL: Official tarball from go.dev
877
+ * - Windows: Chocolatey package
878
+ * - WSL (Ubuntu): Official tarball within WSL
879
+ * - Git Bash: Chocolatey on Windows host
12
880
  *
13
881
  * @returns {Promise<void>}
14
882
  */
15
883
  async function install() {
16
884
  const platform = os.detect();
17
885
 
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 };
886
+ // Map platform types to their installer functions
887
+ // This mapping handles aliases (e.g., debian maps to ubuntu installer)
888
+ const installers = {
889
+ 'macos': install_macos,
890
+ 'ubuntu': install_ubuntu,
891
+ 'debian': install_ubuntu,
892
+ 'wsl': install_ubuntu_wsl,
893
+ 'raspbian': install_raspbian,
894
+ 'amazon_linux': install_amazon_linux,
895
+ 'rhel': install_amazon_linux,
896
+ 'fedora': install_amazon_linux,
897
+ 'windows': install_windows,
898
+ 'gitbash': install_gitbash
899
+ };
900
+
901
+ const installer = installers[platform.type];
902
+
903
+ if (!installer) {
904
+ console.log(`Go is not available for ${platform.type}.`);
905
+ return;
906
+ }
907
+
908
+ await installer();
909
+ }
910
+
911
+ // Export all functions for use as a module and for testing
912
+ module.exports = {
913
+ install,
914
+ isInstalled,
915
+ isEligible,
916
+ install_macos,
917
+ install_ubuntu,
918
+ install_ubuntu_wsl,
919
+ install_raspbian,
920
+ install_amazon_linux,
921
+ install_windows,
922
+ install_gitbash
923
+ };
41
924
 
925
+ // Allow direct execution: node go.js
42
926
  if (require.main === module) {
43
- install();
927
+ install().catch(err => {
928
+ console.error(err.message);
929
+ process.exit(1);
930
+ });
44
931
  }