@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
@@ -0,0 +1,372 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * @fileoverview Install software-properties-common - repository management utilities for Debian/Ubuntu.
5
+ *
6
+ * software-properties-common provides utilities for managing software repositories on
7
+ * Debian-based Linux distributions. The most important utility it provides is
8
+ * `add-apt-repository`, which simplifies adding PPAs (Personal Package Archives) and
9
+ * third-party repositories to your system.
10
+ *
11
+ * Key functionality:
12
+ * - add-apt-repository: Command to add PPAs and custom APT repositories
13
+ * - D-Bus backend: System service for managing software sources programmatically
14
+ * - Repository management scripts: Python utilities for modifying sources.list
15
+ *
16
+ * Platform availability:
17
+ * - Ubuntu/Debian/Raspbian: Full support via APT
18
+ * - Ubuntu on WSL: Full support via APT (same as native Ubuntu)
19
+ * - macOS: Not available (Homebrew uses 'brew tap' for equivalent functionality)
20
+ * - Amazon Linux: Not available (use 'dnf config-manager' from dnf-plugins-core)
21
+ * - Windows: Not available (use Chocolatey 'choco source' or winget 'winget source')
22
+ * - Git Bash: Not available (terminal emulator, no Linux package management)
23
+ *
24
+ * @module installs/software-properties-common
25
+ */
26
+
27
+ const os = require('../utils/common/os');
28
+ const shell = require('../utils/common/shell');
29
+ const apt = require('../utils/ubuntu/apt');
30
+
31
+ // -----------------------------------------------------------------------------
32
+ // Helper Functions
33
+ // -----------------------------------------------------------------------------
34
+
35
+ /**
36
+ * Checks if add-apt-repository command is available in the system PATH.
37
+ * This is the primary indicator that software-properties-common is installed.
38
+ *
39
+ * @returns {boolean} - True if add-apt-repository command exists
40
+ */
41
+ function isAddAptRepositoryInstalled() {
42
+ return shell.commandExists('add-apt-repository');
43
+ }
44
+
45
+ // -----------------------------------------------------------------------------
46
+ // Platform-Specific Installation Functions
47
+ // -----------------------------------------------------------------------------
48
+
49
+ /**
50
+ * Install software-properties-common on macOS.
51
+ *
52
+ * software-properties-common is a Debian/Ubuntu-specific package and is not
53
+ * available on macOS. Homebrew provides equivalent repository management
54
+ * functionality through its built-in 'brew tap' command.
55
+ *
56
+ * @returns {Promise<void>}
57
+ */
58
+ async function install_macos() {
59
+ // software-properties-common is a Debian/Ubuntu-specific package
60
+ // macOS uses Homebrew's 'brew tap' for equivalent functionality
61
+ console.log('software-properties-common is not available for macOS.');
62
+ return;
63
+ }
64
+
65
+ /**
66
+ * Install software-properties-common on Ubuntu/Debian using APT.
67
+ *
68
+ * software-properties-common is a meta-package that installs:
69
+ * - add-apt-repository: Command-line tool for adding PPAs and repositories
70
+ * - python3-software-properties: Python bindings for software-properties
71
+ * - Related D-Bus services and management utilities
72
+ *
73
+ * This is commonly needed before adding third-party repositories or PPAs to
74
+ * an Ubuntu/Debian system.
75
+ *
76
+ * @returns {Promise<void>}
77
+ */
78
+ async function install_ubuntu() {
79
+ // Check if software-properties-common is already installed by verifying
80
+ // the add-apt-repository command exists
81
+ if (isAddAptRepositoryInstalled()) {
82
+ // Double-check by querying dpkg for the package to be thorough
83
+ const packageInstalled = await apt.isPackageInstalled('software-properties-common');
84
+ if (packageInstalled) {
85
+ console.log('software-properties-common is already installed, skipping...');
86
+ return;
87
+ }
88
+ }
89
+
90
+ console.log('Installing software-properties-common via APT...');
91
+
92
+ // Update package lists first to ensure we have the latest package information
93
+ // This is important because the package may not be in the local cache
94
+ console.log('Updating package lists...');
95
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
96
+ if (updateResult.code !== 0) {
97
+ throw new Error(`Failed to update package lists: ${updateResult.stderr}`);
98
+ }
99
+
100
+ // Install software-properties-common with non-interactive mode and auto-confirm
101
+ // DEBIAN_FRONTEND=noninteractive prevents any interactive prompts
102
+ console.log('Installing software-properties-common package...');
103
+ const installResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get install -y software-properties-common');
104
+ if (installResult.code !== 0) {
105
+ throw new Error(`Failed to install software-properties-common: ${installResult.stderr}`);
106
+ }
107
+
108
+ // Verify installation succeeded by checking if add-apt-repository is now available
109
+ if (!isAddAptRepositoryInstalled()) {
110
+ throw new Error('Installation completed but add-apt-repository not found in PATH.');
111
+ }
112
+
113
+ console.log('software-properties-common installed successfully.');
114
+ }
115
+
116
+ /**
117
+ * Install software-properties-common on Ubuntu running in WSL.
118
+ *
119
+ * WSL Ubuntu installations follow the same process as native Ubuntu using APT.
120
+ * The package provides full functionality within the WSL environment.
121
+ *
122
+ * @returns {Promise<void>}
123
+ */
124
+ async function install_ubuntu_wsl() {
125
+ // WSL Ubuntu uses the same APT-based installation as native Ubuntu
126
+ // Check if software-properties-common is already installed by verifying
127
+ // the add-apt-repository command exists
128
+ if (isAddAptRepositoryInstalled()) {
129
+ // Double-check by querying dpkg for the package to be thorough
130
+ const packageInstalled = await apt.isPackageInstalled('software-properties-common');
131
+ if (packageInstalled) {
132
+ console.log('software-properties-common is already installed, skipping...');
133
+ return;
134
+ }
135
+ }
136
+
137
+ console.log('Installing software-properties-common via APT (WSL)...');
138
+
139
+ // Update package lists first to ensure we have the latest package information
140
+ console.log('Updating package lists...');
141
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
142
+ if (updateResult.code !== 0) {
143
+ throw new Error(`Failed to update package lists: ${updateResult.stderr}`);
144
+ }
145
+
146
+ // Install software-properties-common with non-interactive mode and auto-confirm
147
+ console.log('Installing software-properties-common package...');
148
+ const installResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get install -y software-properties-common');
149
+ if (installResult.code !== 0) {
150
+ throw new Error(`Failed to install software-properties-common: ${installResult.stderr}`);
151
+ }
152
+
153
+ // Verify installation succeeded by checking if add-apt-repository is now available
154
+ if (!isAddAptRepositoryInstalled()) {
155
+ throw new Error('Installation completed but add-apt-repository not found in PATH.');
156
+ }
157
+
158
+ console.log('software-properties-common installed successfully.');
159
+ }
160
+
161
+ /**
162
+ * Install software-properties-common on Raspberry Pi OS using APT.
163
+ *
164
+ * Raspberry Pi OS is based on Debian, so software-properties-common installation
165
+ * follows the same process as Ubuntu/Debian. However, note that Ubuntu PPAs may
166
+ * not work on Raspberry Pi OS since PPAs are specifically built for Ubuntu.
167
+ *
168
+ * Note: Installation may take longer on Raspberry Pi due to slower I/O and
169
+ * processor speeds (2-5 minutes on older Pi models).
170
+ *
171
+ * @returns {Promise<void>}
172
+ */
173
+ async function install_raspbian() {
174
+ // Check if software-properties-common is already installed by verifying
175
+ // the add-apt-repository command exists
176
+ if (isAddAptRepositoryInstalled()) {
177
+ // Double-check by querying dpkg for the package to be thorough
178
+ const packageInstalled = await apt.isPackageInstalled('software-properties-common');
179
+ if (packageInstalled) {
180
+ console.log('software-properties-common is already installed, skipping...');
181
+ return;
182
+ }
183
+ }
184
+
185
+ console.log('Installing software-properties-common via APT...');
186
+ console.log('Note: Installation may take 2-5 minutes on Raspberry Pi.');
187
+
188
+ // Update package lists first to ensure we have the latest package information
189
+ console.log('Updating package lists...');
190
+ const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
191
+ if (updateResult.code !== 0) {
192
+ throw new Error(`Failed to update package lists: ${updateResult.stderr}`);
193
+ }
194
+
195
+ // Install software-properties-common with non-interactive mode and auto-confirm
196
+ console.log('Installing software-properties-common package...');
197
+ const installResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get install -y software-properties-common');
198
+ if (installResult.code !== 0) {
199
+ throw new Error(`Failed to install software-properties-common: ${installResult.stderr}`);
200
+ }
201
+
202
+ // Verify installation succeeded by checking if add-apt-repository is now available
203
+ if (!isAddAptRepositoryInstalled()) {
204
+ throw new Error('Installation completed but add-apt-repository not found in PATH.');
205
+ }
206
+
207
+ console.log('software-properties-common installed successfully.');
208
+ console.log('');
209
+ console.log('Note: Ubuntu PPAs may not work on Raspberry Pi OS since PPAs are');
210
+ console.log('built for Ubuntu. Consider using Raspberry Pi OS-specific repositories');
211
+ console.log('or official Debian packages instead.');
212
+ }
213
+
214
+ /**
215
+ * Install software-properties-common on Amazon Linux/RHEL.
216
+ *
217
+ * software-properties-common is a Debian/Ubuntu-specific package and is not
218
+ * available on Amazon Linux or RHEL. Amazon Linux uses dnf-plugins-core which
219
+ * provides 'dnf config-manager' for equivalent repository management functionality.
220
+ *
221
+ * @returns {Promise<void>}
222
+ */
223
+ async function install_amazon_linux() {
224
+ // software-properties-common is a Debian/Ubuntu-specific package
225
+ // Amazon Linux uses 'dnf config-manager' from dnf-plugins-core for equivalent functionality
226
+ console.log('software-properties-common is not available for Amazon Linux.');
227
+ return;
228
+ }
229
+
230
+ /**
231
+ * Install software-properties-common on Windows.
232
+ *
233
+ * software-properties-common is a Debian/Ubuntu-specific package and is not
234
+ * available on Windows. Windows uses Chocolatey ('choco source') or winget
235
+ * ('winget source') for equivalent repository management functionality.
236
+ *
237
+ * @returns {Promise<void>}
238
+ */
239
+ async function install_windows() {
240
+ // software-properties-common is a Debian/Ubuntu-specific package
241
+ // Windows uses 'choco source' or 'winget source' for equivalent functionality
242
+ console.log('software-properties-common is not available for Windows.');
243
+ return;
244
+ }
245
+
246
+ /**
247
+ * Install software-properties-common on Git Bash.
248
+ *
249
+ * Git Bash is a terminal emulator on Windows that does not support Debian
250
+ * package management. software-properties-common cannot be installed in Git Bash.
251
+ *
252
+ * @returns {Promise<void>}
253
+ */
254
+ async function install_gitbash() {
255
+ // Git Bash is a terminal emulator that does not include Linux package management
256
+ console.log('software-properties-common is not available for Git Bash.');
257
+ return;
258
+ }
259
+
260
+ // -----------------------------------------------------------------------------
261
+ // Eligibility Check
262
+ // -----------------------------------------------------------------------------
263
+
264
+ /**
265
+ * Check if software-properties-common is installed on the current platform.
266
+ *
267
+ * This function checks if the add-apt-repository command is available,
268
+ * which indicates software-properties-common is installed.
269
+ *
270
+ * @returns {Promise<boolean>} True if software-properties-common is installed, false otherwise
271
+ */
272
+ async function isInstalled() {
273
+ const platform = os.detect();
274
+
275
+ // software-properties-common is only available on Debian-based systems
276
+ if (!['ubuntu', 'debian', 'wsl', 'raspbian'].includes(platform.type)) {
277
+ return false;
278
+ }
279
+
280
+ return isAddAptRepositoryInstalled();
281
+ }
282
+
283
+ /**
284
+ * Check if this installer is supported on the current platform.
285
+ * software-properties-common is only available on Debian-based Linux distributions.
286
+ * @returns {boolean} True if installation is supported on this platform
287
+ */
288
+ function isEligible() {
289
+ const platform = os.detect();
290
+ return ['ubuntu', 'debian', 'wsl', 'raspbian'].includes(platform.type);
291
+ }
292
+
293
+ // -----------------------------------------------------------------------------
294
+ // Main Installation Entry Point
295
+ // -----------------------------------------------------------------------------
296
+
297
+ /**
298
+ * Main installation entry point - detects platform and runs appropriate installer.
299
+ *
300
+ * This function automatically detects the current platform using the os.detect()
301
+ * utility and dispatches to the appropriate platform-specific installation function.
302
+ *
303
+ * Supported platforms:
304
+ * - ubuntu/debian: Full support via APT
305
+ * - raspbian: Full support via APT (with PPA compatibility notes)
306
+ * - wsl: Full support via APT (same as native Ubuntu)
307
+ *
308
+ * Unsupported platforms (graceful message, no error):
309
+ * - macos: Not available (use 'brew tap' for equivalent functionality)
310
+ * - amazon_linux/rhel/fedora: Not available (use 'dnf config-manager')
311
+ * - windows: Not available (use 'choco source' or 'winget source')
312
+ * - gitbash: Not available (terminal emulator only)
313
+ *
314
+ * @returns {Promise<void>}
315
+ */
316
+ async function install() {
317
+ const platform = os.detect();
318
+
319
+ // Map platform types to their installation functions
320
+ const installers = {
321
+ 'macos': install_macos,
322
+ 'ubuntu': install_ubuntu,
323
+ 'debian': install_ubuntu,
324
+ 'wsl': install_ubuntu_wsl,
325
+ 'raspbian': install_raspbian,
326
+ 'amazon_linux': install_amazon_linux,
327
+ 'rhel': install_amazon_linux,
328
+ 'fedora': install_amazon_linux,
329
+ 'windows': install_windows,
330
+ 'gitbash': install_gitbash,
331
+ };
332
+
333
+ // Find the appropriate installer for this platform
334
+ const installer = installers[platform.type];
335
+
336
+ // Handle truly unknown platforms gracefully (no error, just a message)
337
+ if (!installer) {
338
+ console.log(`software-properties-common is not available for ${platform.type}.`);
339
+ return;
340
+ }
341
+
342
+ // Run the platform-specific installer
343
+ await installer();
344
+ }
345
+
346
+ // -----------------------------------------------------------------------------
347
+ // Module Exports
348
+ // -----------------------------------------------------------------------------
349
+
350
+ module.exports = {
351
+ install,
352
+ isInstalled,
353
+ isEligible,
354
+ install_macos,
355
+ install_ubuntu,
356
+ install_ubuntu_wsl,
357
+ install_raspbian,
358
+ install_amazon_linux,
359
+ install_windows,
360
+ install_gitbash,
361
+ };
362
+
363
+ // -----------------------------------------------------------------------------
364
+ // Direct Execution Handler
365
+ // -----------------------------------------------------------------------------
366
+
367
+ if (require.main === module) {
368
+ install().catch(err => {
369
+ console.error(err.message);
370
+ process.exit(1);
371
+ });
372
+ }