@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
@@ -1,44 +1,692 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Install DbSchema.
4
+ * @fileoverview Install DbSchema across supported platforms.
5
+ *
6
+ * DbSchema is a visual database design and management tool that supports schema
7
+ * design, documentation generation, data exploration, and SQL query building.
8
+ * Built with Java and JavaFX, DbSchema works with over 70 databases including
9
+ * PostgreSQL, MySQL, SQL Server, Oracle, SQLite, MongoDB, and many others.
10
+ *
11
+ * DbSchema bundles its own Java runtime (OpenJDK with JavaFX), so no separate
12
+ * Java installation is required.
13
+ *
14
+ * IMPORTANT: DbSchema is commercial software. It offers a free Community Edition
15
+ * and a paid Pro Edition with a 15-day trial included in all downloads.
16
+ *
17
+ * PLATFORM SUPPORT:
18
+ * - macOS: Supported via Homebrew Cask (Intel and Apple Silicon)
19
+ * - Ubuntu/Debian: Supported via official .deb package from DbSchema website
20
+ * - Amazon Linux/RHEL: Supported via official .rpm package from DbSchema website
21
+ * - Windows: Supported via official MSI installer (silent installation)
22
+ * - WSL (Ubuntu): Supported via official .deb package (requires WSLg or X server)
23
+ * - Git Bash: Uses Windows installation
24
+ * - Raspberry Pi OS: Limited support via ARM64 tar.gz (may have compatibility issues)
25
+ *
5
26
  * @module installs/dbschema
6
27
  */
7
28
 
8
29
  const os = require('../utils/common/os');
30
+ const shell = require('../utils/common/shell');
31
+ const brew = require('../utils/macos/brew');
32
+ const macosApps = require('../utils/macos/apps');
33
+ const apt = require('../utils/ubuntu/apt');
34
+ const windowsShell = require('../utils/windows/shell');
35
+
36
+ /**
37
+ * Whether this installer requires a desktop environment to function.
38
+ * DbSchema is a GUI database design and management tool.
39
+ */
40
+ const REQUIRES_DESKTOP = true;
41
+
42
+ /**
43
+ * The current version of DbSchema to install.
44
+ * Update this constant when new versions are released.
45
+ * @constant {string}
46
+ */
47
+ const DBSCHEMA_VERSION = '10.0.2';
48
+
49
+ /**
50
+ * Download URLs for platform-specific packages.
51
+ * These URLs point to the official DbSchema download server.
52
+ * @constant {Object}
53
+ */
54
+ const DOWNLOAD_URLS = {
55
+ // Debian/Ubuntu .deb package for x86_64 architecture
56
+ deb: `https://dbschema.com/download/dbschema_linux_${DBSCHEMA_VERSION.replace(/\./g, '_')}.deb`,
57
+ // RHEL/Amazon Linux .rpm package for x86_64 architecture
58
+ rpm: `https://dbschema.com/download/dbschema_linux_${DBSCHEMA_VERSION.replace(/\./g, '_')}.rpm`,
59
+ // Windows MSI installer for x86_64 architecture
60
+ msi: `https://dbschema.com/download/dbschema_windows_${DBSCHEMA_VERSION.replace(/\./g, '_')}.msi`,
61
+ // Raspberry Pi / ARM64 tar.gz archive
62
+ arm64: `https://dbschema.com/download/dbschema_linux_arm_${DBSCHEMA_VERSION.replace(/\./g, '_')}.tar.gz`
63
+ };
64
+
65
+ /**
66
+ * Installation paths where DbSchema is typically installed.
67
+ * Used for verification after installation.
68
+ * @constant {Object}
69
+ */
70
+ const INSTALL_PATHS = {
71
+ linux: '/opt/DbSchema/DbSchema',
72
+ windows: 'C:\\Program Files\\DbSchema\\DbSchema.exe'
73
+ };
74
+
75
+ /**
76
+ * Install DbSchema on macOS using Homebrew Cask.
77
+ *
78
+ * DbSchema is available as a Homebrew Cask and supports both Apple Silicon
79
+ * (M1/M2/M3/M4) and Intel Macs. The application will be installed to
80
+ * /Applications/DbSchema.app.
81
+ *
82
+ * @returns {Promise<void>}
83
+ */
84
+ async function install_macos() {
85
+ // Verify Homebrew is installed before proceeding
86
+ if (!brew.isInstalled()) {
87
+ console.log('Homebrew is not installed. Please install Homebrew first.');
88
+ console.log('Visit https://brew.sh for installation instructions.');
89
+ return;
90
+ }
91
+
92
+ // Check if DbSchema is already installed by looking for the app bundle
93
+ // This catches installations done outside of Homebrew as well
94
+ const isAppInstalled = macosApps.isAppInstalled('DbSchema');
95
+ if (isAppInstalled) {
96
+ const version = macosApps.getAppVersion('DbSchema');
97
+ console.log(`DbSchema is already installed${version ? ` (version ${version})` : ''}, skipping...`);
98
+ return;
99
+ }
100
+
101
+ // Also check via Homebrew cask list for completeness
102
+ // This handles the case where the app bundle might be in a non-standard location
103
+ const isCaskInstalled = await brew.isCaskInstalled('dbschema');
104
+ if (isCaskInstalled) {
105
+ console.log('DbSchema is already installed via Homebrew, skipping...');
106
+ return;
107
+ }
108
+
109
+ console.log('Installing DbSchema via Homebrew Cask...');
110
+
111
+ // Install DbSchema using Homebrew Cask
112
+ // The --cask flag is implicit in installCask but we use the utility for consistency
113
+ const result = await brew.installCask('dbschema');
114
+
115
+ if (!result.success) {
116
+ console.log('Failed to install DbSchema.');
117
+ console.log(result.output);
118
+ return;
119
+ }
120
+
121
+ // Verify installation succeeded by checking for the app bundle
122
+ const verified = macosApps.isAppInstalled('DbSchema');
123
+ if (!verified) {
124
+ console.log('Installation may have failed: DbSchema.app not found in /Applications.');
125
+ return;
126
+ }
127
+
128
+ console.log('DbSchema installed successfully.');
129
+ console.log('');
130
+ console.log('Launch DbSchema from Spotlight or the Applications folder.');
131
+ console.log('DbSchema includes a 15-day Pro trial; after that, use the free Community Edition or purchase a license.');
132
+ }
9
133
 
10
134
  /**
11
- * Install DbSchema across supported platforms.
135
+ * Install DbSchema on Ubuntu/Debian using the official .deb package.
136
+ *
137
+ * DbSchema is not available in the official Ubuntu/Debian APT repositories,
138
+ * so this function downloads the .deb package directly from DbSchema's website
139
+ * and installs it using apt-get. The application will be installed to /opt/DbSchema/.
140
+ *
141
+ * @returns {Promise<void>}
142
+ */
143
+ async function install_ubuntu() {
144
+ // Check if DbSchema is already installed by looking for the executable
145
+ const isInstalled = await checkLinuxInstallation();
146
+ if (isInstalled) {
147
+ console.log('DbSchema is already installed, skipping...');
148
+ return;
149
+ }
150
+
151
+ // Ensure curl is available for downloading the package
152
+ // curl is preferred over wget as it's more commonly pre-installed
153
+ if (!shell.commandExists('curl')) {
154
+ console.log('curl is not available. Installing curl first...');
155
+ const curlResult = await apt.install('curl');
156
+ if (!curlResult.success) {
157
+ console.log('Failed to install curl. Cannot proceed with DbSchema installation.');
158
+ return;
159
+ }
160
+ }
161
+
162
+ console.log('Installing DbSchema...');
163
+
164
+ // Download the .deb package to a temporary location
165
+ // Using -fsSL for: fail silently on errors, silent mode, follow redirects
166
+ console.log('Downloading DbSchema package...');
167
+ const downloadResult = await shell.exec(
168
+ `curl -fsSL "${DOWNLOAD_URLS.deb}" -o /tmp/dbschema.deb`
169
+ );
170
+
171
+ if (downloadResult.code !== 0) {
172
+ console.log('Failed to download DbSchema package.');
173
+ console.log(downloadResult.stderr);
174
+ return;
175
+ }
176
+
177
+ // Install the downloaded .deb package using apt-get
178
+ // DEBIAN_FRONTEND=noninteractive prevents any interactive prompts
179
+ console.log('Installing DbSchema package...');
180
+ const installResult = await shell.exec(
181
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y /tmp/dbschema.deb'
182
+ );
183
+
184
+ // Clean up the downloaded package file regardless of installation result
185
+ await shell.exec('rm -f /tmp/dbschema.deb');
186
+
187
+ if (installResult.code !== 0) {
188
+ console.log('Failed to install DbSchema.');
189
+ console.log(installResult.stderr);
190
+ return;
191
+ }
192
+
193
+ // Verify installation by checking for the executable
194
+ const verified = await checkLinuxInstallation();
195
+ if (!verified) {
196
+ console.log('Installation may have failed: DbSchema executable not found at /opt/DbSchema/DbSchema.');
197
+ return;
198
+ }
199
+
200
+ console.log('DbSchema installed successfully.');
201
+ console.log('');
202
+ console.log('Launch DbSchema from your application menu or by running:');
203
+ console.log(' /opt/DbSchema/DbSchema &');
204
+ }
205
+
206
+ /**
207
+ * Install DbSchema on Ubuntu running in WSL (Windows Subsystem for Linux).
208
+ *
209
+ * WSL Ubuntu follows the same installation process as native Ubuntu.
210
+ * DbSchema runs as a Linux application within WSL. For GUI support:
211
+ * - Windows 11 with WSL 2: WSLg provides built-in GUI support
212
+ * - Windows 10: Requires an X server (e.g., VcXsrv) on Windows
213
+ *
214
+ * @returns {Promise<void>}
215
+ */
216
+ async function install_ubuntu_wsl() {
217
+ // WSL Ubuntu uses the same installation as native Ubuntu
218
+ // The .deb package works identically in both environments
219
+ await install_ubuntu();
220
+
221
+ // Provide additional guidance for WSL-specific setup
222
+ // Users need to understand the GUI requirements for DbSchema
223
+ console.log('');
224
+ console.log('Note: DbSchema is a graphical application and requires display support.');
225
+ console.log(' - Windows 11 with WSL 2: WSLg provides built-in GUI support.');
226
+ console.log(' - Windows 10: Install an X server (e.g., VcXsrv) and configure DISPLAY.');
227
+ console.log('');
228
+ console.log('If you experience display issues, try:');
229
+ console.log(' export DISPLAY=$(cat /etc/resolv.conf | grep nameserver | awk \'{print $2}\'):0');
230
+ }
231
+
232
+ /**
233
+ * Install DbSchema on Raspberry Pi OS using the ARM64 tar.gz package.
234
+ *
235
+ * IMPORTANT: DbSchema's ARM64 support for Raspberry Pi is limited. While DbSchema
236
+ * provides an ARM64 Linux build, it is primarily designed for x86_64 emulation
237
+ * scenarios. Users may experience compatibility issues due to JavaFX dependencies.
238
+ *
239
+ * This function downloads and extracts the ARM64 tar.gz package to /opt/DbSchema/
240
+ * and creates a desktop launcher for easy access.
241
+ *
242
+ * @returns {Promise<void>}
243
+ */
244
+ async function install_raspbian() {
245
+ // Check if DbSchema is already installed
246
+ const isInstalled = await checkLinuxInstallation();
247
+ if (isInstalled) {
248
+ console.log('DbSchema is already installed, skipping...');
249
+ return;
250
+ }
251
+
252
+ // Verify we're on 64-bit ARM architecture
253
+ // DbSchema ARM build requires aarch64; armv7l (32-bit) is not supported
254
+ const archResult = await shell.exec('uname -m');
255
+ const architecture = archResult.stdout.trim();
256
+
257
+ if (architecture !== 'aarch64') {
258
+ console.log('DbSchema requires 64-bit Raspberry Pi OS (aarch64).');
259
+ console.log(`Your system is running: ${architecture}`);
260
+ console.log('Please install 64-bit Raspberry Pi OS to use DbSchema.');
261
+ return;
262
+ }
263
+
264
+ // Ensure curl is available for downloading the package
265
+ if (!shell.commandExists('curl')) {
266
+ console.log('curl is not available. Installing curl first...');
267
+ const curlResult = await apt.install('curl');
268
+ if (!curlResult.success) {
269
+ console.log('Failed to install curl. Cannot proceed with DbSchema installation.');
270
+ return;
271
+ }
272
+ }
273
+
274
+ console.log('Installing DbSchema for Raspberry Pi (ARM64)...');
275
+ console.log('');
276
+ console.log('Note: DbSchema ARM64 support may have limited compatibility with Raspberry Pi.');
277
+ console.log('If you experience issues, consider using x86 emulation via Box64.');
278
+ console.log('');
279
+
280
+ // Download the ARM64 tar.gz package
281
+ console.log('Downloading DbSchema ARM64 package...');
282
+ const downloadResult = await shell.exec(
283
+ `curl -fsSL "${DOWNLOAD_URLS.arm64}" -o /tmp/dbschema.tar.gz`
284
+ );
285
+
286
+ if (downloadResult.code !== 0) {
287
+ console.log('Failed to download DbSchema package.');
288
+ console.log(downloadResult.stderr);
289
+ return;
290
+ }
291
+
292
+ // Create the installation directory and extract the package
293
+ // --strip-components=1 removes the top-level directory from the archive
294
+ console.log('Extracting DbSchema to /opt/DbSchema...');
295
+ const extractResult = await shell.exec(
296
+ 'sudo mkdir -p /opt/DbSchema && sudo tar -xzf /tmp/dbschema.tar.gz -C /opt/DbSchema --strip-components=1'
297
+ );
298
+
299
+ // Clean up the downloaded archive
300
+ await shell.exec('rm -f /tmp/dbschema.tar.gz');
301
+
302
+ if (extractResult.code !== 0) {
303
+ console.log('Failed to extract DbSchema package.');
304
+ console.log(extractResult.stderr);
305
+ return;
306
+ }
307
+
308
+ // Create a desktop launcher for easy access from the application menu
309
+ console.log('Creating desktop launcher...');
310
+ const desktopEntry = `[Desktop Entry]
311
+ Name=DbSchema
312
+ Comment=Database Design Tool
313
+ Exec=/opt/DbSchema/DbSchema
314
+ Icon=/opt/DbSchema/.install4j/DbSchema.png
315
+ Terminal=false
316
+ Type=Application
317
+ Categories=Development;Database;`;
318
+
319
+ // Ensure the local applications directory exists
320
+ await shell.exec('mkdir -p ~/.local/share/applications');
321
+
322
+ // Write the desktop entry file
323
+ const writeResult = await shell.exec(
324
+ `echo '${desktopEntry}' > ~/.local/share/applications/dbschema.desktop`
325
+ );
326
+
327
+ if (writeResult.code !== 0) {
328
+ console.log('Warning: Failed to create desktop launcher. You can still launch DbSchema from the terminal.');
329
+ }
330
+
331
+ // Update the desktop database so the launcher appears in menus
332
+ await shell.exec('update-desktop-database ~/.local/share/applications 2>/dev/null');
333
+
334
+ // Verify installation
335
+ const verified = await checkLinuxInstallation();
336
+ if (!verified) {
337
+ console.log('Installation may have failed: DbSchema executable not found at /opt/DbSchema/DbSchema.');
338
+ return;
339
+ }
340
+
341
+ console.log('DbSchema installed successfully.');
342
+ console.log('');
343
+ console.log('Launch DbSchema from your application menu or by running:');
344
+ console.log(' /opt/DbSchema/DbSchema &');
345
+ }
346
+
347
+ /**
348
+ * Install DbSchema on Amazon Linux or RHEL using the official .rpm package.
349
+ *
350
+ * DbSchema is not available in the default Amazon Linux, RHEL, or Fedora
351
+ * repositories. This function downloads the .rpm package directly from
352
+ * DbSchema's website and installs it using dnf or yum.
353
+ *
354
+ * @returns {Promise<void>}
355
+ */
356
+ async function install_amazon_linux() {
357
+ // Check if DbSchema is already installed
358
+ const isInstalled = await checkLinuxInstallation();
359
+ if (isInstalled) {
360
+ console.log('DbSchema is already installed, skipping...');
361
+ return;
362
+ }
363
+
364
+ // Determine which package manager to use
365
+ // dnf is preferred (Amazon Linux 2023, RHEL 8+, Fedora)
366
+ // yum is used on older systems (Amazon Linux 2, CentOS 7)
367
+ const hasDnf = shell.commandExists('dnf');
368
+ const hasYum = shell.commandExists('yum');
369
+ const packageManager = hasDnf ? 'dnf' : hasYum ? 'yum' : null;
370
+
371
+ if (!packageManager) {
372
+ console.log('Neither dnf nor yum package manager found. Cannot install DbSchema.');
373
+ return;
374
+ }
375
+
376
+ // Ensure curl is available for downloading the package
377
+ if (!shell.commandExists('curl')) {
378
+ console.log('curl is not available. Installing curl first...');
379
+ const curlResult = await shell.exec(`sudo ${packageManager} install -y curl`);
380
+ if (curlResult.code !== 0) {
381
+ console.log('Failed to install curl. Cannot proceed with DbSchema installation.');
382
+ return;
383
+ }
384
+ }
385
+
386
+ console.log('Installing DbSchema...');
387
+
388
+ // Download the .rpm package to a temporary location
389
+ console.log('Downloading DbSchema package...');
390
+ const downloadResult = await shell.exec(
391
+ `curl -fsSL "${DOWNLOAD_URLS.rpm}" -o /tmp/dbschema.rpm`
392
+ );
393
+
394
+ if (downloadResult.code !== 0) {
395
+ console.log('Failed to download DbSchema package.');
396
+ console.log(downloadResult.stderr);
397
+ return;
398
+ }
399
+
400
+ // Install the downloaded .rpm package
401
+ // The -y flag automatically confirms the installation
402
+ console.log('Installing DbSchema package...');
403
+ const installResult = await shell.exec(
404
+ `sudo ${packageManager} install -y /tmp/dbschema.rpm`
405
+ );
406
+
407
+ // Clean up the downloaded package file
408
+ await shell.exec('rm -f /tmp/dbschema.rpm');
409
+
410
+ if (installResult.code !== 0) {
411
+ console.log('Failed to install DbSchema.');
412
+ console.log(installResult.stderr);
413
+ return;
414
+ }
415
+
416
+ // Verify installation
417
+ const verified = await checkLinuxInstallation();
418
+ if (!verified) {
419
+ console.log('Installation may have failed: DbSchema executable not found at /opt/DbSchema/DbSchema.');
420
+ return;
421
+ }
422
+
423
+ console.log('DbSchema installed successfully.');
424
+ console.log('');
425
+ console.log('Note: DbSchema is a graphical application and requires a desktop environment.');
426
+ console.log('Launch DbSchema from your application menu or by running:');
427
+ console.log(' /opt/DbSchema/DbSchema &');
428
+ }
429
+
430
+ /**
431
+ * Install DbSchema on Windows using the official MSI installer.
432
+ *
433
+ * DbSchema is not available in Chocolatey or winget repositories, so this
434
+ * function downloads the MSI installer directly from DbSchema's website and
435
+ * runs it with silent installation flags.
436
+ *
437
+ * The installation is performed via PowerShell to handle the download and
438
+ * MSI execution properly on Windows systems.
439
+ *
440
+ * @returns {Promise<void>}
441
+ */
442
+ async function install_windows() {
443
+ // Check if DbSchema is already installed by looking for the executable
444
+ const isInstalled = await checkWindowsInstallation();
445
+ if (isInstalled) {
446
+ console.log('DbSchema is already installed, skipping...');
447
+ return;
448
+ }
449
+
450
+ // Ensure PowerShell is available for the installation process
451
+ if (!windowsShell.hasWindowsPowerShell() && !windowsShell.hasPowerShellCore()) {
452
+ console.log('PowerShell is not available. Cannot install DbSchema.');
453
+ return;
454
+ }
455
+
456
+ console.log('Installing DbSchema...');
457
+ console.log('This may take a few minutes as the installer is approximately 200 MB.');
458
+
459
+ // Build the PowerShell command to download and install DbSchema
460
+ // The command:
461
+ // 1. Downloads the MSI to the temp directory using Invoke-WebRequest
462
+ // 2. Runs msiexec with /qn (quiet, no UI) and /norestart flags
463
+ // 3. Waits for the installation to complete
464
+ // 4. Removes the downloaded MSI file
465
+ const downloadUrl = DOWNLOAD_URLS.msi;
466
+ const installCommand = `
467
+ $ErrorActionPreference = 'Stop';
468
+ Write-Host 'Downloading DbSchema installer...';
469
+ Invoke-WebRequest -Uri '${downloadUrl}' -OutFile "$env:TEMP\\dbschema.msi";
470
+ Write-Host 'Installing DbSchema...';
471
+ Start-Process msiexec.exe -ArgumentList '/i', "$env:TEMP\\dbschema.msi", '/qn', '/norestart' -Wait;
472
+ Remove-Item "$env:TEMP\\dbschema.msi" -ErrorAction SilentlyContinue;
473
+ Write-Host 'Installation complete.';
474
+ `;
475
+
476
+ // Execute the PowerShell command
477
+ const result = await windowsShell.execPowerShell(installCommand);
478
+
479
+ if (!result.success) {
480
+ console.log('Failed to install DbSchema.');
481
+ console.log(result.stderr || result.stdout);
482
+ console.log('');
483
+ console.log('If the installation failed, try running PowerShell as Administrator.');
484
+ return;
485
+ }
486
+
487
+ // Verify installation
488
+ const verified = await checkWindowsInstallation();
489
+ if (!verified) {
490
+ console.log('Installation may have failed: DbSchema.exe not found at expected location.');
491
+ console.log('Check if DbSchema appears in the Start Menu.');
492
+ return;
493
+ }
494
+
495
+ console.log('DbSchema installed successfully.');
496
+ console.log('');
497
+ console.log('Launch DbSchema from the Start Menu or by running:');
498
+ console.log(' "C:\\Program Files\\DbSchema\\DbSchema.exe"');
499
+ }
500
+
501
+ /**
502
+ * Install DbSchema on Git Bash (Windows).
503
+ *
504
+ * Git Bash on Windows inherits the Windows PATH. Since DbSchema is a Windows
505
+ * application, this function installs it on Windows using the MSI installer,
506
+ * making it available from Git Bash as well.
507
+ *
508
+ * @returns {Promise<void>}
509
+ */
510
+ async function install_gitbash() {
511
+ console.log('Git Bash uses the Windows installation of DbSchema.');
512
+ console.log('');
513
+
514
+ // Check if DbSchema is already available via the Windows PATH
515
+ const isAvailable = await checkWindowsInstallation();
516
+ if (isAvailable) {
517
+ console.log('DbSchema is already installed on Windows and available from Git Bash, skipping...');
518
+ return;
519
+ }
520
+
521
+ // Install via the Windows installer
522
+ await install_windows();
523
+
524
+ console.log('');
525
+ console.log('Close and reopen Git Bash to ensure the application is accessible.');
526
+ console.log('Launch DbSchema from Git Bash by running:');
527
+ console.log(' "/c/Program Files/DbSchema/DbSchema.exe" &');
528
+ }
529
+
530
+ /**
531
+ * Helper function to check if DbSchema is installed on Linux systems.
532
+ *
533
+ * Checks for the DbSchema executable at the standard installation path
534
+ * (/opt/DbSchema/DbSchema). Also checks if the dbschema package is
535
+ * registered with dpkg on Debian-based systems.
536
+ *
537
+ * @returns {Promise<boolean>} True if DbSchema is installed, false otherwise
538
+ */
539
+ async function checkLinuxInstallation() {
540
+ // Check for the executable at the standard installation path
541
+ const executableResult = await shell.exec(`test -f "${INSTALL_PATHS.linux}" && echo "exists"`);
542
+ if (executableResult.stdout.trim() === 'exists') {
543
+ return true;
544
+ }
545
+
546
+ // Also check if the package is installed via dpkg (Debian-based systems)
547
+ const dpkgResult = await shell.exec('dpkg -l dbschema 2>/dev/null | grep -q "^ii"');
548
+ if (dpkgResult.code === 0) {
549
+ return true;
550
+ }
551
+
552
+ // Check if installed via rpm (RHEL-based systems)
553
+ const rpmResult = await shell.exec('rpm -qa dbschema 2>/dev/null | grep -q dbschema');
554
+ if (rpmResult.code === 0) {
555
+ return true;
556
+ }
557
+
558
+ return false;
559
+ }
560
+
561
+ /**
562
+ * Helper function to check if DbSchema is installed on Windows systems.
563
+ *
564
+ * Checks for the DbSchema executable at the standard installation path
565
+ * (C:\Program Files\DbSchema\DbSchema.exe).
566
+ *
567
+ * @returns {Promise<boolean>} True if DbSchema is installed, false otherwise
568
+ */
569
+ async function checkWindowsInstallation() {
570
+ // Use PowerShell to check if the executable exists
571
+ const result = await windowsShell.execPowerShell(
572
+ `Test-Path "${INSTALL_PATHS.windows}"`
573
+ );
574
+
575
+ // PowerShell Test-Path returns "True" or "False" as string
576
+ return result.success && result.stdout.trim().toLowerCase() === 'true';
577
+ }
578
+
579
+ /**
580
+ * Check if DbSchema is currently installed on the system.
581
+ *
582
+ * This function checks for DbSchema installation across all supported platforms:
583
+ * - macOS: Checks for DbSchema.app via Homebrew cask or application bundle
584
+ * - Windows: Checks for DbSchema.exe at the standard installation path
585
+ * - Linux: Checks for the DbSchema executable at /opt/DbSchema/DbSchema
586
+ *
587
+ * @returns {Promise<boolean>} True if DbSchema is installed, false otherwise
588
+ */
589
+ async function isInstalled() {
590
+ const platform = os.detect();
591
+
592
+ if (platform.type === 'macos') {
593
+ // Check if DbSchema app bundle exists
594
+ if (macosApps.isAppInstalled('DbSchema')) {
595
+ return true;
596
+ }
597
+ // Also check via Homebrew cask
598
+ return await brew.isCaskInstalled('dbschema');
599
+ }
600
+
601
+ if (platform.type === 'windows' || platform.type === 'gitbash') {
602
+ return await checkWindowsInstallation();
603
+ }
604
+
605
+ // Linux platforms (ubuntu, debian, wsl, raspbian, amazon_linux, rhel, fedora)
606
+ return await checkLinuxInstallation();
607
+ }
608
+
609
+ /**
610
+ * Check if this installer is supported on the current platform.
611
+ *
612
+ * DbSchema can be installed on:
613
+ * - macOS (via Homebrew cask)
614
+ * - Ubuntu/Debian (via official .deb package)
615
+ * - Raspberry Pi OS (via ARM64 tar.gz package)
616
+ * - Amazon Linux/RHEL/Fedora (via official .rpm package)
617
+ * - Windows (via official MSI installer)
618
+ * - WSL (via official .deb package, requires WSLg or X server)
619
+ * - Git Bash (uses Windows installation)
620
+ *
621
+ * @returns {boolean} True if installation is supported on this platform
622
+ */
623
+ function isEligible() {
624
+ const platform = os.detect();
625
+ const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'rhel', 'fedora', 'windows', 'gitbash'];
626
+ if (!supportedPlatforms.includes(platform.type)) {
627
+ return false;
628
+ }
629
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
630
+ return false;
631
+ }
632
+ return true;
633
+ }
634
+
635
+ /**
636
+ * Main installation entry point - detects platform and runs appropriate installer.
637
+ *
638
+ * This function detects the current operating system and delegates to the
639
+ * appropriate platform-specific installer. On unsupported platforms, it
640
+ * displays a friendly message and returns gracefully without throwing an error.
12
641
  *
13
642
  * @returns {Promise<void>}
14
643
  */
15
644
  async function install() {
16
645
  const platform = os.detect();
17
646
 
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 };
647
+ // Map platform types to their installer functions
648
+ // Multiple platform types may use the same installer function
649
+ const installers = {
650
+ 'macos': install_macos,
651
+ 'ubuntu': install_ubuntu,
652
+ 'debian': install_ubuntu,
653
+ 'wsl': install_ubuntu_wsl,
654
+ 'raspbian': install_raspbian,
655
+ 'amazon_linux': install_amazon_linux,
656
+ 'rhel': install_amazon_linux,
657
+ 'fedora': install_amazon_linux,
658
+ 'windows': install_windows
659
+ };
660
+
661
+ const installer = installers[platform.type];
662
+
663
+ if (!installer) {
664
+ // Handle unsupported platforms gracefully without throwing an error
665
+ // Per project requirements: never throw errors for unsupported platforms
666
+ console.log(`DbSchema is not available for ${platform.type}.`);
667
+ return;
668
+ }
669
+
670
+ await installer();
671
+ }
672
+
673
+ module.exports = {
674
+ REQUIRES_DESKTOP,
675
+ install,
676
+ isInstalled,
677
+ isEligible,
678
+ install_macos,
679
+ install_ubuntu,
680
+ install_ubuntu_wsl,
681
+ install_raspbian,
682
+ install_amazon_linux,
683
+ install_windows,
684
+ install_gitbash
685
+ };
41
686
 
42
687
  if (require.main === module) {
43
- install();
688
+ install().catch(err => {
689
+ console.error(err.message);
690
+ process.exit(1);
691
+ });
44
692
  }