@fredlackey/devutils 0.0.1 → 0.0.2

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 (257) 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
package/src/scripts/u.js CHANGED
@@ -1,23 +1,505 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Update system packages and tools.
4
+ * u - Update system packages and tools
5
+ *
6
+ * Migrated from legacy dotfiles alias.
7
+ * Original aliases:
8
+ * macOS: alias u="sudo softwareupdate --install --all && brew update && brew upgrade && brew cleanup"
9
+ * Ubuntu: alias u="sudo apt-get update && sudo apt-get upgrade"
10
+ * Raspbian: alias u="sudo apt-get update && sudo apt-get upgrade"
11
+ *
12
+ * This script updates the operating system and installed packages:
13
+ * - macOS: Updates macOS software (softwareupdate) and Homebrew packages
14
+ * - Ubuntu/Debian: Updates APT package lists and upgrades installed packages
15
+ * - Raspberry Pi OS: Same as Ubuntu (APT-based)
16
+ * - Amazon Linux: Updates DNF/YUM packages
17
+ * - Windows: Updates winget packages (and optionally Chocolatey)
18
+ *
19
+ * NOTE: This script requires elevated privileges (sudo) on most platforms.
20
+ * The script will prompt for your password when needed.
21
+ *
5
22
  * @module scripts/u
6
23
  */
7
24
 
25
+ const os = require('../utils/common/os');
26
+ const { execSync, spawnSync } = require('child_process');
27
+
28
+ /**
29
+ * Helper function to check if a command exists on the system.
30
+ * Used to detect which package managers are available.
31
+ *
32
+ * @param {string} cmd - The command name to check
33
+ * @returns {boolean} True if the command exists, false otherwise
34
+ */
35
+ function isCommandAvailable(cmd) {
36
+ try {
37
+ // Use 'which' on Unix-like systems, 'where' on Windows
38
+ const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
39
+ execSync(checkCmd, { stdio: 'ignore' });
40
+ return true;
41
+ } catch {
42
+ return false;
43
+ }
44
+ }
45
+
46
+ /**
47
+ * Helper function to run a command and show output to the user.
48
+ * This is a wrapper around execSync that handles errors gracefully.
49
+ *
50
+ * @param {string} command - The command to execute
51
+ * @param {string} description - Human-readable description of what we're doing
52
+ * @returns {boolean} True if the command succeeded, false otherwise
53
+ */
54
+ function runCommand(command, description) {
55
+ console.log(`\n>>> ${description}...`);
56
+ console.log(` Running: ${command}\n`);
57
+
58
+ try {
59
+ // Use spawnSync with shell: true for commands that need shell features
60
+ // stdio: 'inherit' passes through stdin/stdout/stderr so user sees progress
61
+ const result = spawnSync(command, {
62
+ shell: true,
63
+ stdio: 'inherit'
64
+ });
65
+
66
+ if (result.status !== 0) {
67
+ console.error(`\n Warning: Command exited with code ${result.status}`);
68
+ return false;
69
+ }
70
+ return true;
71
+ } catch (error) {
72
+ console.error(`\n Error running command: ${error.message}`);
73
+ return false;
74
+ }
75
+ }
76
+
77
+ /**
78
+ * Pure Node.js implementation - NOT APPLICABLE for this script.
79
+ *
80
+ * System updates require OS-level package managers (brew, apt, dnf, winget, etc.)
81
+ * that cannot be replicated in pure Node.js. Each platform has its own package
82
+ * management system that must be invoked directly.
83
+ *
84
+ * @param {string[]} args - Command line arguments (unused)
85
+ * @returns {Promise<void>}
86
+ * @throws {Error} Always throws - this function should not be called directly
87
+ */
88
+ async function do_u_nodejs(args) {
89
+ // System updates are inherently platform-specific and require OS package managers.
90
+ // There is no pure Node.js way to update system packages.
91
+ throw new Error(
92
+ 'do_u_nodejs should not be called directly. ' +
93
+ 'System updates require OS-specific package managers.'
94
+ );
95
+ }
96
+
97
+ /**
98
+ * Update system on macOS using softwareupdate and Homebrew.
99
+ *
100
+ * This function replicates the original dotfiles alias:
101
+ * sudo softwareupdate --install --all && brew update && brew upgrade && brew cleanup
102
+ *
103
+ * It performs the following steps:
104
+ * 1. softwareupdate --install --all: Installs all available macOS updates (requires sudo)
105
+ * 2. brew update: Updates Homebrew's list of available packages
106
+ * 3. brew upgrade: Upgrades all installed Homebrew packages to latest versions
107
+ * 4. brew cleanup: Removes old versions and clears download cache
108
+ *
109
+ * @param {string[]} args - Command line arguments (unused)
110
+ * @returns {Promise<void>}
111
+ */
112
+ async function do_u_macos(args) {
113
+ console.log('=== macOS System Update ===');
114
+ console.log('This will update macOS and Homebrew packages.');
115
+ console.log('You may be prompted for your password.\n');
116
+
117
+ let hasErrors = false;
118
+
119
+ // Step 1: Update macOS using softwareupdate
120
+ // The --install --all flags install all available updates
121
+ // Note: This requires sudo, but softwareupdate will prompt for it
122
+ const softwareUpdateSuccess = runCommand(
123
+ 'sudo softwareupdate --install --all',
124
+ 'Checking for and installing macOS updates'
125
+ );
126
+ if (!softwareUpdateSuccess) {
127
+ console.error('Warning: macOS software update encountered issues.');
128
+ hasErrors = true;
129
+ }
130
+
131
+ // Step 2-4: Update Homebrew (only if Homebrew is installed)
132
+ if (isCommandAvailable('brew')) {
133
+ // Step 2: Update Homebrew's package list
134
+ const brewUpdateSuccess = runCommand(
135
+ 'brew update',
136
+ 'Updating Homebrew package list'
137
+ );
138
+ if (!brewUpdateSuccess) {
139
+ console.error('Warning: brew update encountered issues.');
140
+ hasErrors = true;
141
+ }
142
+
143
+ // Step 3: Upgrade all installed packages
144
+ const brewUpgradeSuccess = runCommand(
145
+ 'brew upgrade',
146
+ 'Upgrading installed Homebrew packages'
147
+ );
148
+ if (!brewUpgradeSuccess) {
149
+ console.error('Warning: brew upgrade encountered issues.');
150
+ hasErrors = true;
151
+ }
152
+
153
+ // Step 4: Clean up old versions and cache
154
+ const brewCleanupSuccess = runCommand(
155
+ 'brew cleanup',
156
+ 'Cleaning up old Homebrew versions and cache'
157
+ );
158
+ if (!brewCleanupSuccess) {
159
+ console.error('Warning: brew cleanup encountered issues.');
160
+ hasErrors = true;
161
+ }
162
+ } else {
163
+ console.log('\nHomebrew is not installed. Skipping Homebrew updates.');
164
+ console.log('To install Homebrew, visit: https://brew.sh');
165
+ }
166
+
167
+ // Summary
168
+ console.log('\n=== Update Complete ===');
169
+ if (hasErrors) {
170
+ console.log('Some updates encountered issues. Review the output above.');
171
+ } else {
172
+ console.log('All updates completed successfully.');
173
+ }
174
+ }
175
+
176
+ /**
177
+ * Update system on Ubuntu using APT.
178
+ *
179
+ * This function replicates the original dotfiles alias:
180
+ * sudo apt-get update && sudo apt-get upgrade
181
+ *
182
+ * It performs the following steps:
183
+ * 1. apt-get update: Refreshes the list of available packages from repositories
184
+ * 2. apt-get upgrade: Upgrades all installed packages to their latest versions
185
+ *
186
+ * The -y flag is NOT used by default to match the original alias behavior,
187
+ * which prompts the user to confirm before upgrading packages.
188
+ *
189
+ * @param {string[]} args - Command line arguments (unused)
190
+ * @returns {Promise<void>}
191
+ */
192
+ async function do_u_ubuntu(args) {
193
+ console.log('=== Ubuntu System Update ===');
194
+ console.log('This will update APT packages.');
195
+ console.log('You may be prompted for your password.\n');
196
+
197
+ let hasErrors = false;
198
+
199
+ // Step 1: Update package lists
200
+ // This downloads the latest package information from configured repositories
201
+ const updateSuccess = runCommand(
202
+ 'sudo apt-get update',
203
+ 'Updating package lists from repositories'
204
+ );
205
+ if (!updateSuccess) {
206
+ console.error('Warning: apt-get update encountered issues.');
207
+ hasErrors = true;
208
+ }
209
+
210
+ // Step 2: Upgrade installed packages
211
+ // This upgrades all installed packages to their newest versions
212
+ // The user will be prompted to confirm the upgrade (matching original alias behavior)
213
+ const upgradeSuccess = runCommand(
214
+ 'sudo apt-get upgrade',
215
+ 'Upgrading installed packages'
216
+ );
217
+ if (!upgradeSuccess) {
218
+ console.error('Warning: apt-get upgrade encountered issues.');
219
+ hasErrors = true;
220
+ }
221
+
222
+ // Summary
223
+ console.log('\n=== Update Complete ===');
224
+ if (hasErrors) {
225
+ console.log('Some updates encountered issues. Review the output above.');
226
+ } else {
227
+ console.log('All updates completed successfully.');
228
+ }
229
+ }
230
+
231
+ /**
232
+ * Update system on Raspberry Pi OS using APT.
233
+ *
234
+ * Raspberry Pi OS is Debian-based, so it uses the same APT commands as Ubuntu.
235
+ * This function is essentially identical to do_u_ubuntu but with Raspberry Pi
236
+ * specific messaging.
237
+ *
238
+ * @param {string[]} args - Command line arguments (unused)
239
+ * @returns {Promise<void>}
240
+ */
241
+ async function do_u_raspbian(args) {
242
+ console.log('=== Raspberry Pi OS System Update ===');
243
+ console.log('This will update APT packages.');
244
+ console.log('You may be prompted for your password.\n');
245
+
246
+ let hasErrors = false;
247
+
248
+ // Step 1: Update package lists
249
+ const updateSuccess = runCommand(
250
+ 'sudo apt-get update',
251
+ 'Updating package lists from repositories'
252
+ );
253
+ if (!updateSuccess) {
254
+ console.error('Warning: apt-get update encountered issues.');
255
+ hasErrors = true;
256
+ }
257
+
258
+ // Step 2: Upgrade installed packages
259
+ const upgradeSuccess = runCommand(
260
+ 'sudo apt-get upgrade',
261
+ 'Upgrading installed packages'
262
+ );
263
+ if (!upgradeSuccess) {
264
+ console.error('Warning: apt-get upgrade encountered issues.');
265
+ hasErrors = true;
266
+ }
267
+
268
+ // Summary
269
+ console.log('\n=== Update Complete ===');
270
+ if (hasErrors) {
271
+ console.log('Some updates encountered issues. Review the output above.');
272
+ } else {
273
+ console.log('All updates completed successfully.');
274
+ }
275
+ }
276
+
277
+ /**
278
+ * Update system on Amazon Linux using DNF or YUM.
279
+ *
280
+ * Amazon Linux 2023 uses DNF, while Amazon Linux 2 uses YUM.
281
+ * This function detects which package manager is available and uses it.
282
+ *
283
+ * @param {string[]} args - Command line arguments (unused)
284
+ * @returns {Promise<void>}
285
+ */
286
+ async function do_u_amazon_linux(args) {
287
+ console.log('=== Amazon Linux System Update ===');
288
+ console.log('This will update system packages.');
289
+ console.log('You may be prompted for your password.\n');
290
+
291
+ let hasErrors = false;
292
+
293
+ // Detect which package manager to use
294
+ // Amazon Linux 2023 uses DNF, Amazon Linux 2 uses YUM
295
+ const useDnf = isCommandAvailable('dnf');
296
+ const packageManager = useDnf ? 'dnf' : 'yum';
297
+
298
+ console.log(`Using package manager: ${packageManager}`);
299
+
300
+ // Step 1: Check for updates (optional, but informative)
301
+ const checkSuccess = runCommand(
302
+ `sudo ${packageManager} check-update`,
303
+ 'Checking for available updates'
304
+ );
305
+ // Note: check-update returns exit code 100 if updates are available,
306
+ // which would be treated as an error. We'll continue regardless.
307
+
308
+ // Step 2: Upgrade all packages
309
+ // The -y flag could be added for non-interactive mode, but we match
310
+ // the interactive behavior of the original Ubuntu alias
311
+ const upgradeSuccess = runCommand(
312
+ `sudo ${packageManager} upgrade`,
313
+ 'Upgrading installed packages'
314
+ );
315
+ if (!upgradeSuccess) {
316
+ console.error(`Warning: ${packageManager} upgrade encountered issues.`);
317
+ hasErrors = true;
318
+ }
319
+
320
+ // Step 3: Clean up cached packages (optional but good practice)
321
+ const cleanSuccess = runCommand(
322
+ `sudo ${packageManager} clean all`,
323
+ 'Cleaning up package cache'
324
+ );
325
+ if (!cleanSuccess) {
326
+ console.error(`Warning: ${packageManager} clean encountered issues.`);
327
+ // Don't set hasErrors for cleanup failure - it's not critical
328
+ }
329
+
330
+ // Summary
331
+ console.log('\n=== Update Complete ===');
332
+ if (hasErrors) {
333
+ console.log('Some updates encountered issues. Review the output above.');
334
+ } else {
335
+ console.log('All updates completed successfully.');
336
+ }
337
+ }
338
+
8
339
  /**
9
- * Updates the system's package manager and installed packages.
10
- * Platform-specific: macOS (softwareupdate + Homebrew), Linux (apt/yum).
340
+ * Update system on Windows using winget (and optionally Chocolatey).
341
+ *
342
+ * Windows doesn't have a built-in equivalent to softwareupdate, but:
343
+ * - winget (Windows Package Manager) can upgrade installed packages
344
+ * - Chocolatey can upgrade packages it manages
345
+ *
346
+ * This function uses winget by default (included in Windows 10/11) and
347
+ * also updates Chocolatey packages if Chocolatey is installed.
11
348
  *
12
349
  * @param {string[]} args - Command line arguments (unused)
13
350
  * @returns {Promise<void>}
14
351
  */
15
- async function main(args) {
16
- // TODO: Implement system update
352
+ async function do_u_cmd(args) {
353
+ console.log('=== Windows System Update ===');
354
+ console.log('This will update installed packages.\n');
355
+
356
+ let hasErrors = false;
357
+ let hasUpdaters = false;
358
+
359
+ // Try winget first (built into Windows 10/11)
360
+ if (isCommandAvailable('winget')) {
361
+ hasUpdaters = true;
362
+
363
+ // winget upgrade --all upgrades all packages that have updates available
364
+ const wingetSuccess = runCommand(
365
+ 'winget upgrade --all',
366
+ 'Upgrading packages via Windows Package Manager (winget)'
367
+ );
368
+ if (!wingetSuccess) {
369
+ console.error('Warning: winget upgrade encountered issues.');
370
+ hasErrors = true;
371
+ }
372
+ } else {
373
+ console.log('winget is not available. Skipping winget updates.');
374
+ console.log('winget comes with Windows 10 (1709+) and Windows 11.');
375
+ }
376
+
377
+ // Also try Chocolatey if installed
378
+ if (isCommandAvailable('choco')) {
379
+ hasUpdaters = true;
380
+
381
+ const chocoSuccess = runCommand(
382
+ 'choco upgrade all -y',
383
+ 'Upgrading packages via Chocolatey'
384
+ );
385
+ if (!chocoSuccess) {
386
+ console.error('Warning: choco upgrade encountered issues.');
387
+ hasErrors = true;
388
+ }
389
+ } else {
390
+ console.log('\nChocolatey is not installed. Skipping Chocolatey updates.');
391
+ console.log('To install Chocolatey, visit: https://chocolatey.org/install');
392
+ }
393
+
394
+ if (!hasUpdaters) {
395
+ console.error('\nError: No package manager found.');
396
+ console.error('Install winget (Windows 10/11) or Chocolatey to manage packages.');
397
+ process.exit(1);
398
+ }
399
+
400
+ // Summary
401
+ console.log('\n=== Update Complete ===');
402
+ if (hasErrors) {
403
+ console.log('Some updates encountered issues. Review the output above.');
404
+ } else {
405
+ console.log('All updates completed successfully.');
406
+ }
407
+ }
408
+
409
+ /**
410
+ * Update system on Windows using PowerShell.
411
+ *
412
+ * This function performs the same updates as do_u_cmd, using the same
413
+ * package managers (winget, Chocolatey). PowerShell provides more advanced
414
+ * scripting capabilities, but for simple package updates, the commands are
415
+ * essentially the same.
416
+ *
417
+ * @param {string[]} args - Command line arguments (unused)
418
+ * @returns {Promise<void>}
419
+ */
420
+ async function do_u_powershell(args) {
421
+ // PowerShell uses the same Windows package managers as CMD
422
+ return do_u_cmd(args);
423
+ }
424
+
425
+ /**
426
+ * Update system from Git Bash on Windows.
427
+ *
428
+ * Git Bash runs in the Windows environment, so we use the same Windows
429
+ * package managers (winget, Chocolatey) as CMD and PowerShell.
430
+ *
431
+ * @param {string[]} args - Command line arguments (unused)
432
+ * @returns {Promise<void>}
433
+ */
434
+ async function do_u_gitbash(args) {
435
+ // Git Bash runs on Windows, use the same Windows update logic
436
+ return do_u_cmd(args);
437
+ }
438
+
439
+ /**
440
+ * Main entry point - detects environment and executes appropriate implementation.
441
+ *
442
+ * The "u" (update) command updates the operating system and installed packages.
443
+ * This is a common developer workflow: keep your system and tools up to date.
444
+ *
445
+ * The behavior varies by platform:
446
+ * - macOS: Updates macOS (softwareupdate) and Homebrew packages
447
+ * - Ubuntu/Debian: Updates APT packages
448
+ * - Raspberry Pi OS: Updates APT packages
449
+ * - Amazon Linux: Updates DNF/YUM packages
450
+ * - Windows: Updates winget and/or Chocolatey packages
451
+ *
452
+ * @param {string[]} args - Command line arguments (unused)
453
+ * @returns {Promise<void>}
454
+ */
455
+ async function do_u(args) {
456
+ const platform = os.detect();
457
+
458
+ const handlers = {
459
+ 'macos': do_u_macos,
460
+ 'ubuntu': do_u_ubuntu,
461
+ 'debian': do_u_ubuntu,
462
+ 'raspbian': do_u_raspbian,
463
+ 'amazon_linux': do_u_amazon_linux,
464
+ 'rhel': do_u_amazon_linux,
465
+ 'fedora': do_u_amazon_linux,
466
+ 'linux': do_u_ubuntu,
467
+ 'wsl': do_u_ubuntu,
468
+ 'cmd': do_u_cmd,
469
+ 'windows': do_u_cmd,
470
+ 'powershell': do_u_powershell,
471
+ 'gitbash': do_u_gitbash
472
+ };
473
+
474
+ const handler = handlers[platform.type];
475
+ if (!handler) {
476
+ console.error(`Platform '${platform.type}' is not supported for this command.`);
477
+ console.error('');
478
+ console.error('Supported platforms:');
479
+ console.error(' - macOS (softwareupdate + Homebrew)');
480
+ console.error(' - Ubuntu, Debian (APT)');
481
+ console.error(' - Raspberry Pi OS (APT)');
482
+ console.error(' - Amazon Linux, RHEL, Fedora (DNF/YUM)');
483
+ console.error(' - Windows (winget, Chocolatey)');
484
+ process.exit(1);
485
+ }
486
+
487
+ await handler(args);
17
488
  }
18
489
 
19
- module.exports = { main };
490
+ module.exports = {
491
+ main: do_u,
492
+ do_u,
493
+ do_u_nodejs,
494
+ do_u_macos,
495
+ do_u_ubuntu,
496
+ do_u_raspbian,
497
+ do_u_amazon_linux,
498
+ do_u_cmd,
499
+ do_u_powershell,
500
+ do_u_gitbash
501
+ };
20
502
 
21
503
  if (require.main === module) {
22
- main(process.argv.slice(2));
504
+ do_u(process.argv.slice(2));
23
505
  }