@fredlackey/devutils 0.0.1 → 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. package/README.md +5 -5
  2. package/package.json +1 -1
  3. package/src/commands/install.js +374 -36
  4. package/src/installs/adobe-creative-cloud.js +527 -25
  5. package/src/installs/adobe-creative-cloud.md +605 -0
  6. package/src/installs/appcleaner.js +303 -26
  7. package/src/installs/appcleaner.md +699 -0
  8. package/src/installs/apt-transport-https.js +390 -0
  9. package/src/installs/apt-transport-https.md +678 -0
  10. package/src/installs/atomicparsley.js +624 -26
  11. package/src/installs/atomicparsley.md +795 -0
  12. package/src/installs/aws-cli.js +779 -26
  13. package/src/installs/aws-cli.md +727 -0
  14. package/src/installs/balena-etcher.js +688 -26
  15. package/src/installs/balena-etcher.md +761 -0
  16. package/src/installs/bambu-studio.js +912 -26
  17. package/src/installs/bambu-studio.md +780 -0
  18. package/src/installs/bash-completion.js +554 -23
  19. package/src/installs/bash-completion.md +833 -0
  20. package/src/installs/bash.js +399 -26
  21. package/src/installs/bash.md +993 -0
  22. package/src/installs/beyond-compare.js +585 -26
  23. package/src/installs/beyond-compare.md +813 -0
  24. package/src/installs/build-essential.js +511 -26
  25. package/src/installs/build-essential.md +977 -0
  26. package/src/installs/ca-certificates.js +618 -0
  27. package/src/installs/ca-certificates.md +937 -0
  28. package/src/installs/caffeine.js +490 -26
  29. package/src/installs/caffeine.md +839 -0
  30. package/src/installs/camtasia.js +577 -25
  31. package/src/installs/camtasia.md +762 -0
  32. package/src/installs/chatgpt.js +458 -26
  33. package/src/installs/chatgpt.md +814 -0
  34. package/src/installs/chocolatey.js +447 -0
  35. package/src/installs/chocolatey.md +661 -0
  36. package/src/installs/chrome-canary.js +472 -26
  37. package/src/installs/chrome-canary.md +641 -0
  38. package/src/installs/chromium.js +645 -26
  39. package/src/installs/chromium.md +838 -0
  40. package/src/installs/claude-code.js +558 -26
  41. package/src/installs/claude-code.md +1173 -0
  42. package/src/installs/curl.js +361 -26
  43. package/src/installs/curl.md +714 -0
  44. package/src/installs/cursor.js +561 -26
  45. package/src/installs/cursor.md +970 -0
  46. package/src/installs/dbschema.js +674 -26
  47. package/src/installs/dbschema.md +925 -0
  48. package/src/installs/dependencies.md +435 -0
  49. package/src/installs/development-tools.js +600 -0
  50. package/src/installs/development-tools.md +977 -0
  51. package/src/installs/docker.js +1010 -25
  52. package/src/installs/docker.md +1109 -0
  53. package/src/installs/drawio.js +1001 -26
  54. package/src/installs/drawio.md +795 -0
  55. package/src/installs/elmedia-player.js +328 -25
  56. package/src/installs/elmedia-player.md +556 -0
  57. package/src/installs/ffmpeg.js +870 -25
  58. package/src/installs/ffmpeg.md +852 -0
  59. package/src/installs/file.js +464 -0
  60. package/src/installs/file.md +987 -0
  61. package/src/installs/gemini-cli.js +793 -26
  62. package/src/installs/gemini-cli.md +1153 -0
  63. package/src/installs/git.js +382 -26
  64. package/src/installs/git.md +907 -0
  65. package/src/installs/gitego.js +931 -26
  66. package/src/installs/gitego.md +1172 -0
  67. package/src/installs/go.js +913 -26
  68. package/src/installs/go.md +958 -0
  69. package/src/installs/google-chrome.js +801 -25
  70. package/src/installs/google-chrome.md +862 -0
  71. package/src/installs/gpg.js +412 -73
  72. package/src/installs/gpg.md +1056 -0
  73. package/src/installs/homebrew.js +1015 -26
  74. package/src/installs/homebrew.md +988 -0
  75. package/src/installs/imageoptim.js +950 -26
  76. package/src/installs/imageoptim.md +1119 -0
  77. package/src/installs/installers.json +2297 -0
  78. package/src/installs/jq.js +382 -26
  79. package/src/installs/jq.md +809 -0
  80. package/src/installs/keyboard-maestro.js +701 -26
  81. package/src/installs/keyboard-maestro.md +825 -0
  82. package/src/installs/latex.js +771 -26
  83. package/src/installs/latex.md +1095 -0
  84. package/src/installs/lftp.js +338 -26
  85. package/src/installs/lftp.md +907 -0
  86. package/src/installs/lsb-release.js +346 -0
  87. package/src/installs/lsb-release.md +814 -0
  88. package/src/installs/messenger.js +829 -26
  89. package/src/installs/messenger.md +900 -0
  90. package/src/installs/microsoft-office.js +550 -26
  91. package/src/installs/microsoft-office.md +760 -0
  92. package/src/installs/microsoft-teams.js +782 -25
  93. package/src/installs/microsoft-teams.md +886 -0
  94. package/src/installs/node.js +886 -26
  95. package/src/installs/node.md +1153 -0
  96. package/src/installs/nordpass.js +698 -26
  97. package/src/installs/nordpass.md +921 -0
  98. package/src/installs/nvm.js +977 -26
  99. package/src/installs/nvm.md +1057 -0
  100. package/src/installs/openssh.js +734 -64
  101. package/src/installs/openssh.md +1056 -0
  102. package/src/installs/pandoc.js +644 -26
  103. package/src/installs/pandoc.md +1036 -0
  104. package/src/installs/pinentry.js +492 -26
  105. package/src/installs/pinentry.md +1142 -0
  106. package/src/installs/pngyu.js +851 -26
  107. package/src/installs/pngyu.md +896 -0
  108. package/src/installs/postman.js +781 -26
  109. package/src/installs/postman.md +940 -0
  110. package/src/installs/procps.js +425 -0
  111. package/src/installs/procps.md +851 -0
  112. package/src/installs/safari-tech-preview.js +355 -25
  113. package/src/installs/safari-tech-preview.md +533 -0
  114. package/src/installs/sfnt2woff.js +640 -26
  115. package/src/installs/sfnt2woff.md +795 -0
  116. package/src/installs/shellcheck.js +463 -26
  117. package/src/installs/shellcheck.md +1005 -0
  118. package/src/installs/slack.js +722 -25
  119. package/src/installs/slack.md +865 -0
  120. package/src/installs/snagit.js +566 -25
  121. package/src/installs/snagit.md +844 -0
  122. package/src/installs/software-properties-common.js +372 -0
  123. package/src/installs/software-properties-common.md +805 -0
  124. package/src/installs/spotify.js +858 -25
  125. package/src/installs/spotify.md +901 -0
  126. package/src/installs/studio-3t.js +803 -26
  127. package/src/installs/studio-3t.md +918 -0
  128. package/src/installs/sublime-text.js +780 -25
  129. package/src/installs/sublime-text.md +914 -0
  130. package/src/installs/superwhisper.js +687 -25
  131. package/src/installs/superwhisper.md +630 -0
  132. package/src/installs/tailscale.js +727 -26
  133. package/src/installs/tailscale.md +1100 -0
  134. package/src/installs/tar.js +389 -0
  135. package/src/installs/tar.md +946 -0
  136. package/src/installs/termius.js +780 -26
  137. package/src/installs/termius.md +844 -0
  138. package/src/installs/terraform.js +761 -26
  139. package/src/installs/terraform.md +899 -0
  140. package/src/installs/tidal.js +752 -25
  141. package/src/installs/tidal.md +864 -0
  142. package/src/installs/tmux.js +328 -26
  143. package/src/installs/tmux.md +1030 -0
  144. package/src/installs/tree.js +393 -26
  145. package/src/installs/tree.md +833 -0
  146. package/src/installs/unzip.js +460 -0
  147. package/src/installs/unzip.md +879 -0
  148. package/src/installs/vim.js +403 -26
  149. package/src/installs/vim.md +1040 -0
  150. package/src/installs/vlc.js +803 -26
  151. package/src/installs/vlc.md +927 -0
  152. package/src/installs/vscode.js +825 -26
  153. package/src/installs/vscode.md +1002 -0
  154. package/src/installs/wget.js +415 -0
  155. package/src/installs/wget.md +791 -0
  156. package/src/installs/whatsapp.js +710 -25
  157. package/src/installs/whatsapp.md +854 -0
  158. package/src/installs/winpty.js +352 -0
  159. package/src/installs/winpty.md +620 -0
  160. package/src/installs/woff2.js +535 -26
  161. package/src/installs/woff2.md +977 -0
  162. package/src/installs/wsl.js +572 -0
  163. package/src/installs/wsl.md +699 -0
  164. package/src/installs/xcode-clt.js +520 -0
  165. package/src/installs/xcode-clt.md +351 -0
  166. package/src/installs/xcode.js +542 -26
  167. package/src/installs/xcode.md +573 -0
  168. package/src/installs/yarn.js +806 -26
  169. package/src/installs/yarn.md +1074 -0
  170. package/src/installs/yq.js +636 -26
  171. package/src/installs/yq.md +944 -0
  172. package/src/installs/yt-dlp.js +683 -26
  173. package/src/installs/yt-dlp.md +946 -0
  174. package/src/installs/yum-utils.js +297 -0
  175. package/src/installs/yum-utils.md +648 -0
  176. package/src/installs/zoom.js +740 -25
  177. package/src/installs/zoom.md +884 -0
  178. package/src/scripts/README.md +567 -45
  179. package/src/scripts/STATUS.md +208 -0
  180. package/src/scripts/afk.js +395 -7
  181. package/src/scripts/backup-all.js +731 -9
  182. package/src/scripts/backup-source.js +711 -8
  183. package/src/scripts/brewd.js +373 -7
  184. package/src/scripts/brewi.js +505 -9
  185. package/src/scripts/brewr.js +512 -9
  186. package/src/scripts/brews.js +462 -9
  187. package/src/scripts/brewu.js +488 -7
  188. package/src/scripts/c.js +185 -7
  189. package/src/scripts/ccurl.js +325 -8
  190. package/src/scripts/certbot-crontab-init.js +488 -8
  191. package/src/scripts/certbot-init.js +641 -9
  192. package/src/scripts/ch.js +339 -7
  193. package/src/scripts/claude-danger.js +253 -8
  194. package/src/scripts/clean-dev.js +419 -8
  195. package/src/scripts/clear-dns-cache.js +525 -7
  196. package/src/scripts/clone.js +417 -7
  197. package/src/scripts/code-all.js +420 -7
  198. package/src/scripts/count-files.js +195 -8
  199. package/src/scripts/count-folders.js +195 -8
  200. package/src/scripts/count.js +248 -8
  201. package/src/scripts/d.js +203 -7
  202. package/src/scripts/datauri.js +373 -8
  203. package/src/scripts/delete-files.js +363 -7
  204. package/src/scripts/docker-clean.js +410 -8
  205. package/src/scripts/dp.js +426 -7
  206. package/src/scripts/e.js +375 -9
  207. package/src/scripts/empty-trash.js +497 -7
  208. package/src/scripts/evm.js +428 -9
  209. package/src/scripts/fetch-github-repos.js +441 -10
  210. package/src/scripts/get-channel.js +329 -8
  211. package/src/scripts/get-course.js +384 -11
  212. package/src/scripts/get-dependencies.js +290 -9
  213. package/src/scripts/get-folder.js +783 -10
  214. package/src/scripts/get-tunes.js +411 -10
  215. package/src/scripts/get-video.js +352 -9
  216. package/src/scripts/git-backup.js +561 -9
  217. package/src/scripts/git-clone.js +477 -9
  218. package/src/scripts/git-pup.js +303 -7
  219. package/src/scripts/git-push.js +380 -8
  220. package/src/scripts/h.js +607 -9
  221. package/src/scripts/hide-desktop-icons.js +483 -7
  222. package/src/scripts/hide-hidden-files.js +522 -7
  223. package/src/scripts/install-dependencies-from.js +440 -9
  224. package/src/scripts/ips.js +647 -10
  225. package/src/scripts/iso.js +354 -8
  226. package/src/scripts/killni.js +561 -7
  227. package/src/scripts/ll.js +451 -8
  228. package/src/scripts/local-ip.js +310 -8
  229. package/src/scripts/m.js +508 -8
  230. package/src/scripts/map.js +293 -8
  231. package/src/scripts/mkd.js +287 -7
  232. package/src/scripts/ncu-update-all.js +441 -8
  233. package/src/scripts/nginx-init.js +702 -12
  234. package/src/scripts/npmi.js +366 -7
  235. package/src/scripts/o.js +495 -8
  236. package/src/scripts/org-by-date.js +321 -7
  237. package/src/scripts/p.js +208 -7
  238. package/src/scripts/packages.js +313 -8
  239. package/src/scripts/path.js +209 -7
  240. package/src/scripts/ports.js +582 -8
  241. package/src/scripts/q.js +290 -8
  242. package/src/scripts/refresh-files.js +378 -10
  243. package/src/scripts/remove-smaller-files.js +500 -8
  244. package/src/scripts/rename-files-with-date.js +517 -9
  245. package/src/scripts/resize-image.js +523 -9
  246. package/src/scripts/rm-safe.js +653 -8
  247. package/src/scripts/s.js +525 -9
  248. package/src/scripts/set-git-public.js +349 -7
  249. package/src/scripts/show-desktop-icons.js +459 -7
  250. package/src/scripts/show-hidden-files.js +456 -7
  251. package/src/scripts/tpa.js +265 -8
  252. package/src/scripts/tpo.js +264 -7
  253. package/src/scripts/u.js +489 -7
  254. package/src/scripts/vpush.js +422 -8
  255. package/src/scripts/y.js +267 -7
  256. package/src/utils/common/os.js +94 -2
  257. package/src/utils/ubuntu/apt.js +13 -7
  258. package/src/utils/windows/choco.js +82 -26
  259. package/src/utils/windows/winget.js +89 -27
@@ -1,44 +1,716 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Install Nord Pass.
4
+ * @fileoverview Install NordPass password manager.
5
5
  * @module installs/nordpass
6
+ *
7
+ * NordPass is a password manager developed by Nord Security that provides
8
+ * secure storage for passwords, credit card information, secure notes, and
9
+ * other sensitive data. It uses XChaCha20 encryption and operates on a
10
+ * zero-knowledge architecture.
11
+ *
12
+ * IMPORTANT PLATFORM NOTES:
13
+ * - macOS: Installs NordPass Desktop via Homebrew cask
14
+ * - Windows: Installs NordPass Desktop via Chocolatey
15
+ * - Ubuntu/Debian: Installs NordPass Desktop via Snap (x86_64 only)
16
+ * - WSL: Recommends using Windows NordPass or opens web vault
17
+ * - Raspberry Pi OS: NOT SUPPORTED (ARM architecture not supported by NordPass)
18
+ * - Amazon Linux: NOT SUPPORTED (no Snap/Flatpak; browser extension recommended)
19
+ * - Git Bash: Installs NordPass on Windows host via Chocolatey
6
20
  */
7
21
 
8
22
  const os = require('../utils/common/os');
23
+ const shell = require('../utils/common/shell');
24
+ const brew = require('../utils/macos/brew');
25
+ const macosApps = require('../utils/macos/apps');
26
+ const snap = require('../utils/ubuntu/snap');
27
+ const apt = require('../utils/ubuntu/apt');
28
+ const choco = require('../utils/windows/choco');
29
+
30
+ /**
31
+ * Whether this installer requires a desktop environment to function.
32
+ * NordPass is a GUI password manager application.
33
+ */
34
+ const REQUIRES_DESKTOP = true;
35
+
36
+ /**
37
+ * The Homebrew cask name for NordPass on macOS.
38
+ * This installs the full desktop application from Nord Security.
39
+ */
40
+ const HOMEBREW_CASK_NAME = 'nordpass';
41
+
42
+ /**
43
+ * The Chocolatey package name for NordPass on Windows.
44
+ */
45
+ const CHOCO_PACKAGE_NAME = 'nordpass';
46
+
47
+ /**
48
+ * The Snap package name for NordPass on Ubuntu/Debian.
49
+ * This is the official NordPass package maintained by Nord Security.
50
+ */
51
+ const SNAP_PACKAGE_NAME = 'nordpass';
52
+
53
+ /**
54
+ * The macOS application name as it appears in /Applications.
55
+ */
56
+ const MACOS_APP_NAME = 'NordPass';
57
+
58
+ /**
59
+ * The Windows executable path for NordPass.
60
+ */
61
+ const WINDOWS_EXE_PATH = 'C:\\Program Files\\NordPass\\NordPass.exe';
62
+
63
+ /**
64
+ * Check if NordPass is installed on macOS by looking for the app bundle.
65
+ *
66
+ * This function checks both /Applications and ~/Applications for the
67
+ * NordPass.app bundle, which is the standard installation location
68
+ * for Homebrew cask installations.
69
+ *
70
+ * @returns {boolean} True if NordPass.app exists, false otherwise
71
+ */
72
+ function isNordPassInstalledMacOS() {
73
+ return macosApps.isAppInstalled(MACOS_APP_NAME);
74
+ }
75
+
76
+ /**
77
+ * Get the installed version of NordPass on macOS.
78
+ *
79
+ * Reads the version from the app's Info.plist file using the
80
+ * CFBundleShortVersionString key.
81
+ *
82
+ * @returns {string|null} The version string if installed, null otherwise
83
+ */
84
+ function getNordPassVersionMacOS() {
85
+ return macosApps.getAppVersion(MACOS_APP_NAME);
86
+ }
87
+
88
+ /**
89
+ * Check if NordPass is installed via Snap on Linux.
90
+ *
91
+ * Queries the snap list to determine if the nordpass package is installed.
92
+ *
93
+ * @returns {Promise<boolean>} True if NordPass snap is installed
94
+ */
95
+ async function isNordPassInstalledSnap() {
96
+ return await snap.isSnapInstalled(SNAP_PACKAGE_NAME);
97
+ }
9
98
 
10
99
  /**
11
- * Install Nord Pass across supported platforms.
100
+ * Get the installed version of NordPass from Snap.
101
+ *
102
+ * @returns {Promise<string|null>} The version string if installed, null otherwise
103
+ */
104
+ async function getNordPassVersionSnap() {
105
+ return await snap.getSnapVersion(SNAP_PACKAGE_NAME);
106
+ }
107
+
108
+ /**
109
+ * Check if NordPass is installed via Chocolatey on Windows.
110
+ *
111
+ * Queries the Chocolatey local package list to determine if NordPass
112
+ * is installed.
113
+ *
114
+ * @returns {Promise<boolean>} True if NordPass is installed via Chocolatey
115
+ */
116
+ async function isNordPassInstalledChoco() {
117
+ return await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
118
+ }
119
+
120
+ /**
121
+ * Ensure snapd is installed and running on the system.
122
+ *
123
+ * On Ubuntu 16.04+, snapd is pre-installed. On Debian or other systems,
124
+ * this function will attempt to install it via apt-get.
125
+ *
126
+ * @returns {Promise<boolean>} True if snapd is available, false otherwise
127
+ */
128
+ async function ensureSnapdInstalled() {
129
+ // Check if snap command is already available
130
+ if (snap.isInstalled()) {
131
+ return true;
132
+ }
133
+
134
+ console.log('snapd is not installed. Installing snapd...');
135
+
136
+ // Update package lists first
137
+ const updateResult = await shell.exec(
138
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get update -y'
139
+ );
140
+ if (updateResult.code !== 0) {
141
+ console.log('Warning: Failed to update package lists.');
142
+ }
143
+
144
+ // Install snapd
145
+ const installResult = await shell.exec(
146
+ 'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd'
147
+ );
148
+
149
+ if (installResult.code !== 0) {
150
+ console.log('Failed to install snapd.');
151
+ console.log('Output: ' + (installResult.stderr || installResult.stdout));
152
+ return false;
153
+ }
154
+
155
+ console.log('snapd installed. You may need to log out and log back in');
156
+ console.log('for snap paths to be updated correctly.');
157
+
158
+ return true;
159
+ }
160
+
161
+ /**
162
+ * Check if the system architecture supports NordPass Snap package.
163
+ *
164
+ * NordPass Snap only supports amd64 (x86_64) architecture. ARM architectures
165
+ * (aarch64, armv7l) are not supported.
166
+ *
167
+ * @returns {Promise<{ supported: boolean, architecture: string }>}
168
+ */
169
+ async function checkArchitectureSupport() {
170
+ const archResult = await shell.exec('uname -m');
171
+ const architecture = archResult.stdout.trim();
172
+
173
+ // NordPass Snap only supports x86_64/amd64
174
+ const supportedArchitectures = ['x86_64', 'amd64'];
175
+ const supported = supportedArchitectures.includes(architecture);
176
+
177
+ return { supported, architecture };
178
+ }
179
+
180
+ /**
181
+ * Install NordPass on macOS using Homebrew cask.
182
+ *
183
+ * Prerequisites:
184
+ * - macOS 11 (Big Sur) or later
185
+ * - Homebrew package manager installed
186
+ * - Apple Silicon (M1/M2/M3/M4) or Intel processor
187
+ * - At least 200 MB free disk space
188
+ *
189
+ * The installation uses Homebrew's cask system which downloads the official
190
+ * NordPass.dmg from Nord Security and installs it to /Applications.
191
+ *
192
+ * @returns {Promise<void>}
193
+ */
194
+ async function install_macos() {
195
+ console.log('Checking if NordPass is already installed...');
196
+
197
+ // Check if NordPass is already installed by looking for the app
198
+ if (isNordPassInstalledMacOS()) {
199
+ const version = getNordPassVersionMacOS();
200
+ const versionInfo = version ? ` (version ${version})` : '';
201
+ console.log(`NordPass is already installed${versionInfo}, skipping installation.`);
202
+ return;
203
+ }
204
+
205
+ // Also check if the cask is installed via Homebrew
206
+ const caskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
207
+ if (caskInstalled) {
208
+ console.log('NordPass is already installed via Homebrew, skipping installation.');
209
+ console.log('');
210
+ console.log('To launch NordPass, run: open -a NordPass');
211
+ return;
212
+ }
213
+
214
+ // Verify Homebrew is available
215
+ if (!brew.isInstalled()) {
216
+ throw new Error(
217
+ 'Homebrew is not installed. Please install Homebrew first using:\n' +
218
+ ' dev install homebrew\n' +
219
+ 'Then retry installing NordPass.'
220
+ );
221
+ }
222
+
223
+ console.log('Installing NordPass via Homebrew...');
224
+
225
+ // Install NordPass using Homebrew cask
226
+ const result = await brew.installCask(HOMEBREW_CASK_NAME);
227
+
228
+ if (!result.success) {
229
+ throw new Error(
230
+ 'Failed to install NordPass via Homebrew.\n' +
231
+ 'Output: ' + result.output + '\n\n' +
232
+ 'Troubleshooting:\n' +
233
+ ' 1. Run "brew update && brew cleanup" and retry\n' +
234
+ ' 2. Check for cask availability: brew info --cask nordpass\n' +
235
+ ' 3. Try manual download from https://nordpass.com/download/macos/'
236
+ );
237
+ }
238
+
239
+ // Verify installation succeeded
240
+ if (!isNordPassInstalledMacOS()) {
241
+ throw new Error(
242
+ 'Installation appeared to complete but NordPass.app was not found.\n' +
243
+ 'Please check /Applications for NordPass.app'
244
+ );
245
+ }
246
+
247
+ const installedVersion = getNordPassVersionMacOS();
248
+ const versionInfo = installedVersion ? ` (version ${installedVersion})` : '';
249
+
250
+ console.log('NordPass installed successfully' + versionInfo + '.');
251
+ console.log('');
252
+ console.log('To get started:');
253
+ console.log(' 1. Launch NordPass from Applications or run: open -a NordPass');
254
+ console.log(' 2. Sign in with your NordPass account or create a new one');
255
+ console.log(' 3. Install the browser extension for autofill functionality');
256
+ console.log('');
257
+ console.log('Browser extension links:');
258
+ console.log(' Chrome: https://chrome.google.com/webstore/detail/nordpass-password-manager/fooolghllnmhmmndgjiamiiodkpenpbb');
259
+ console.log(' Firefox: https://addons.mozilla.org/en-US/firefox/addon/nordpass-password-manager-b2b/');
260
+ console.log(' Safari: Available in the Mac App Store');
261
+ }
262
+
263
+ /**
264
+ * Install NordPass on Ubuntu/Debian using Snap.
265
+ *
266
+ * Prerequisites:
267
+ * - Ubuntu 18.04+ or Debian 10+ (64-bit x86_64/amd64 only)
268
+ * - snapd service installed and running
269
+ * - sudo privileges
270
+ * - Active internet connection
271
+ *
272
+ * IMPORTANT: NordPass Snap only supports amd64 (x86_64) architecture.
273
+ * ARM-based systems (aarch64, armv7l) are not supported.
274
+ *
275
+ * @returns {Promise<void>}
276
+ */
277
+ async function install_ubuntu() {
278
+ console.log('Checking system architecture...');
279
+
280
+ // Check architecture compatibility - NordPass Snap only supports x86_64
281
+ const { supported, architecture } = await checkArchitectureSupport();
282
+ if (!supported) {
283
+ console.log('NordPass is not available for ' + architecture + ' architecture.');
284
+ console.log('');
285
+ console.log('NordPass Snap only supports x86_64/amd64 systems.');
286
+ console.log('');
287
+ console.log('Alternative options:');
288
+ console.log(' - Use the NordPass browser extension');
289
+ console.log(' - Access the web vault at https://app.nordpass.com');
290
+ return;
291
+ }
292
+
293
+ console.log('Checking if NordPass is already installed...');
294
+
295
+ // Check if NordPass is already installed via Snap
296
+ const isInstalled = await isNordPassInstalledSnap();
297
+ if (isInstalled) {
298
+ const version = await getNordPassVersionSnap();
299
+ const versionInfo = version ? ` (version ${version})` : '';
300
+ console.log('NordPass is already installed' + versionInfo + ', skipping installation.');
301
+ return;
302
+ }
303
+
304
+ // Ensure snapd is installed
305
+ const snapdAvailable = await ensureSnapdInstalled();
306
+ if (!snapdAvailable) {
307
+ throw new Error(
308
+ 'snapd is required but could not be installed.\n\n' +
309
+ 'Please install snapd manually:\n' +
310
+ ' sudo apt-get update\n' +
311
+ ' sudo apt-get install -y snapd\n' +
312
+ 'Then log out and log back in, and retry.'
313
+ );
314
+ }
315
+
316
+ console.log('Installing NordPass via Snap...');
317
+
318
+ // Install NordPass from Snap Store
319
+ const result = await snap.install(SNAP_PACKAGE_NAME);
320
+
321
+ if (!result.success) {
322
+ throw new Error(
323
+ 'Failed to install NordPass via Snap.\n' +
324
+ 'Output: ' + result.output + '\n\n' +
325
+ 'Troubleshooting:\n' +
326
+ ' 1. Ensure snapd service is running: sudo systemctl status snapd\n' +
327
+ ' 2. Try starting the service: sudo systemctl enable --now snapd.socket\n' +
328
+ ' 3. Check your internet connection\n' +
329
+ ' 4. Try manual installation: sudo snap install nordpass'
330
+ );
331
+ }
332
+
333
+ // Verify installation
334
+ const installedVersion = await getNordPassVersionSnap();
335
+ const versionInfo = installedVersion ? ` (version ${installedVersion})` : '';
336
+
337
+ console.log('NordPass installed successfully' + versionInfo + '.');
338
+ console.log('');
339
+ console.log('To get started:');
340
+ console.log(' 1. Launch NordPass from your application menu or run: nordpass');
341
+ console.log(' 2. Sign in with your NordPass account or create a new one');
342
+ console.log(' 3. Install the browser extension for autofill functionality');
343
+ console.log('');
344
+ console.log('Browser extension links:');
345
+ console.log(' Chrome: https://chrome.google.com/webstore/detail/nordpass-password-manager/fooolghllnmhmmndgjiamiiodkpenpbb');
346
+ console.log(' Firefox: https://addons.mozilla.org/en-US/firefox/addon/nordpass-password-manager-b2b/');
347
+ }
348
+
349
+ /**
350
+ * Install NordPass on Raspberry Pi OS.
351
+ *
352
+ * IMPORTANT: NordPass does NOT provide a native desktop application for
353
+ * ARM architecture. The NordPass Snap package only supports amd64 (x86_64).
354
+ *
355
+ * This function gracefully informs the user that NordPass is not available
356
+ * on Raspberry Pi and exits without error.
357
+ *
358
+ * @returns {Promise<void>}
359
+ */
360
+ async function install_raspbian() {
361
+ console.log('NordPass is not available for Raspberry Pi OS.');
362
+ return;
363
+ }
364
+
365
+ /**
366
+ * Install NordPass on Amazon Linux/RHEL.
367
+ *
368
+ * IMPORTANT: NordPass does NOT provide a native desktop application for
369
+ * Amazon Linux. Amazon Linux does not natively support Snap or Flatpak,
370
+ * which are the primary distribution methods for NordPass on Linux.
371
+ *
372
+ * This function gracefully informs the user that NordPass is not available
373
+ * on Amazon Linux and exits without error.
374
+ *
375
+ * @returns {Promise<void>}
376
+ */
377
+ async function install_amazon_linux() {
378
+ console.log('NordPass is not available for Amazon Linux.');
379
+ return;
380
+ }
381
+
382
+ /**
383
+ * Install NordPass on Windows using Chocolatey.
384
+ *
385
+ * Prerequisites:
386
+ * - Windows 10 or later, or Windows Server 2016 or later (64-bit)
387
+ * - Administrator PowerShell or Command Prompt
388
+ * - Chocolatey package manager installed
389
+ * - Active internet connection
390
+ *
391
+ * The installation uses Chocolatey's silent installation mode which
392
+ * downloads and installs NordPass without user interaction.
393
+ *
394
+ * @returns {Promise<void>}
395
+ */
396
+ async function install_windows() {
397
+ console.log('Checking if NordPass is already installed...');
398
+
399
+ // Check if NordPass is installed via Chocolatey
400
+ const chocoInstalled = await isNordPassInstalledChoco();
401
+ if (chocoInstalled) {
402
+ console.log('NordPass is already installed via Chocolatey, skipping installation.');
403
+ console.log('');
404
+ console.log('Launch NordPass from the Start Menu.');
405
+ return;
406
+ }
407
+
408
+ // Also check if the executable exists (may have been installed manually)
409
+ const exeResult = await shell.exec('if exist "' + WINDOWS_EXE_PATH + '" (echo exists)');
410
+ if (exeResult.stdout && exeResult.stdout.includes('exists')) {
411
+ console.log('NordPass is already installed, skipping installation.');
412
+ console.log('');
413
+ console.log('Launch NordPass from the Start Menu.');
414
+ return;
415
+ }
416
+
417
+ // Verify Chocolatey is available
418
+ if (!choco.isInstalled()) {
419
+ throw new Error(
420
+ 'Chocolatey is not installed. Please install Chocolatey first:\n\n' +
421
+ 'Run the following in an Administrator PowerShell:\n' +
422
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
423
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
424
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
425
+ 'Then retry installing NordPass.'
426
+ );
427
+ }
428
+
429
+ console.log('Installing NordPass via Chocolatey...');
430
+ console.log('This may take a few minutes...');
431
+
432
+ // Install NordPass using Chocolatey
433
+ const result = await choco.install(CHOCO_PACKAGE_NAME);
434
+
435
+ if (!result.success) {
436
+ throw new Error(
437
+ 'Failed to install NordPass via Chocolatey.\n' +
438
+ 'Output: ' + result.output + '\n\n' +
439
+ 'Troubleshooting:\n' +
440
+ ' 1. Ensure you are running as Administrator\n' +
441
+ ' 2. Try: choco install nordpass -y --force\n' +
442
+ ' 3. If checksum errors occur: choco install nordpass -y --ignore-checksums\n' +
443
+ ' 4. Try manual download from https://nordpass.com/download/windows/'
444
+ );
445
+ }
446
+
447
+ console.log('NordPass installed successfully.');
448
+ console.log('');
449
+ console.log('To get started:');
450
+ console.log(' 1. Launch NordPass from the Start Menu');
451
+ console.log(' 2. Sign in with your NordPass account or create a new one');
452
+ console.log(' 3. Install the browser extension for autofill functionality');
453
+ console.log('');
454
+ console.log('Browser extension links:');
455
+ console.log(' Chrome: https://chrome.google.com/webstore/detail/nordpass-password-manager/fooolghllnmhmmndgjiamiiodkpenpbb');
456
+ console.log(' Firefox: https://addons.mozilla.org/en-US/firefox/addon/nordpass-password-manager-b2b/');
457
+ console.log(' Edge: https://microsoftedge.microsoft.com/addons/detail/nordpass-password-manage/njgnlkhcjgmjfnfahjgppcefghdkflml');
458
+ }
459
+
460
+ /**
461
+ * Install NordPass on Ubuntu running in WSL (Windows Subsystem for Linux).
462
+ *
463
+ * WSL users have two options:
464
+ * 1. Recommended: Use NordPass installed on the Windows host
465
+ * 2. Alternative: Install via Snap within WSL (requires WSL 2 + systemd + WSLg)
466
+ *
467
+ * This function recommends using the Windows installation and provides
468
+ * instructions for accessing NordPass from within WSL.
469
+ *
470
+ * Prerequisites for Snap installation:
471
+ * - WSL 2 with systemd enabled
472
+ * - WSLg for GUI support (Windows 11) or X server (Windows 10)
473
+ *
474
+ * @returns {Promise<void>}
475
+ */
476
+ async function install_ubuntu_wsl() {
477
+ console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
478
+ console.log('');
479
+
480
+ // Check architecture compatibility first
481
+ const { supported, architecture } = await checkArchitectureSupport();
482
+ if (!supported) {
483
+ console.log('NordPass is not available for ' + architecture + ' architecture in WSL.');
484
+ console.log('');
485
+ console.log('Use the NordPass web vault instead:');
486
+ console.log(' wslview https://app.nordpass.com');
487
+ return;
488
+ }
489
+
490
+ // Check if NordPass is already installed via Snap
491
+ const isInstalled = await isNordPassInstalledSnap();
492
+ if (isInstalled) {
493
+ const version = await getNordPassVersionSnap();
494
+ const versionInfo = version ? ` (version ${version})` : '';
495
+ console.log('NordPass is already installed in WSL' + versionInfo + ', skipping installation.');
496
+ return;
497
+ }
498
+
499
+ console.log('RECOMMENDED: Install NordPass on your Windows host for the best experience.');
500
+ console.log('Then use the NordPass browser extension in your Windows browser.');
501
+ console.log('');
502
+ console.log('To access NordPass web vault from WSL, you can install wslu:');
503
+ console.log(' sudo apt-get update && sudo apt-get install -y wslu');
504
+ console.log(' wslview https://app.nordpass.com');
505
+ console.log('');
506
+ console.log('ALTERNATIVE: To install NordPass directly in WSL (requires WSL 2 + systemd):');
507
+ console.log('');
508
+ console.log('1. Enable systemd in WSL by adding to /etc/wsl.conf:');
509
+ console.log(' [boot]');
510
+ console.log(' systemd=true');
511
+ console.log('');
512
+ console.log('2. Restart WSL from PowerShell: wsl --shutdown');
513
+ console.log('');
514
+ console.log('3. Then install via Snap:');
515
+ console.log(' sudo apt-get update && sudo apt-get install -y snapd');
516
+ console.log(' sudo snap install nordpass');
517
+ console.log('');
518
+ console.log('Note: GUI support requires WSLg (Windows 11) or an X server (Windows 10).');
519
+ return;
520
+ }
521
+
522
+ /**
523
+ * Install NordPass from Git Bash on Windows.
524
+ *
525
+ * Git Bash runs within the Windows environment, so this function installs
526
+ * NordPass on the Windows host using Chocolatey via PowerShell.
527
+ *
528
+ * Prerequisites:
529
+ * - Windows 10 or Windows 11 (64-bit)
530
+ * - Git Bash installed (comes with Git for Windows)
531
+ * - Chocolatey package manager installed on Windows
532
+ * - Administrator privileges
533
+ *
534
+ * @returns {Promise<void>}
535
+ */
536
+ async function install_gitbash() {
537
+ console.log('Detected Git Bash on Windows.');
538
+ console.log('Installing NordPass on the Windows host...');
539
+ console.log('');
540
+
541
+ // Check if NordPass is already installed by checking for the executable
542
+ const checkResult = await shell.exec('powershell.exe -NoProfile -Command "Test-Path \'C:\\Program Files\\NordPass\\NordPass.exe\'"');
543
+ if (checkResult.stdout && checkResult.stdout.trim() === 'True') {
544
+ console.log('NordPass is already installed, skipping installation.');
545
+ console.log('');
546
+ console.log('To launch NordPass:');
547
+ console.log(' start "" "C:\\Program Files\\NordPass\\NordPass.exe"');
548
+ return;
549
+ }
550
+
551
+ // Check if Chocolatey is available
552
+ const chocoCheck = await shell.exec('choco.exe --version 2>/dev/null || powershell.exe -NoProfile -Command "choco --version"');
553
+ if (chocoCheck.code !== 0) {
554
+ throw new Error(
555
+ 'Chocolatey is not installed on Windows.\n\n' +
556
+ 'Please install Chocolatey first by running in an Administrator PowerShell:\n' +
557
+ ' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
558
+ '[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
559
+ 'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
560
+ 'Then retry installing NordPass.'
561
+ );
562
+ }
563
+
564
+ console.log('Installing NordPass via Chocolatey...');
565
+ console.log('This may take a few minutes...');
566
+
567
+ // Install via PowerShell using Chocolatey
568
+ const installResult = await shell.exec(
569
+ 'powershell.exe -NoProfile -Command "choco install nordpass -y"'
570
+ );
571
+
572
+ if (installResult.code !== 0) {
573
+ throw new Error(
574
+ 'Failed to install NordPass.\n' +
575
+ 'Output: ' + (installResult.stdout || installResult.stderr) + '\n\n' +
576
+ 'Troubleshooting:\n' +
577
+ ' 1. Run Git Bash as Administrator and retry\n' +
578
+ ' 2. Try: powershell.exe -Command "choco install nordpass -y --force"\n' +
579
+ ' 3. Try manual download from https://nordpass.com/download/windows/'
580
+ );
581
+ }
582
+
583
+ console.log('NordPass installed successfully.');
584
+ console.log('');
585
+ console.log('To get started:');
586
+ console.log(' 1. Launch NordPass from the Start Menu');
587
+ console.log(' 2. Or from Git Bash: start "" "C:\\Program Files\\NordPass\\NordPass.exe"');
588
+ console.log(' 3. Sign in with your NordPass account or create a new one');
589
+ console.log(' 4. Install the browser extension for autofill functionality');
590
+ console.log('');
591
+ console.log('Web vault access from Git Bash:');
592
+ console.log(' start https://app.nordpass.com');
593
+ }
594
+
595
+ /**
596
+ * Check if NordPass is installed on the current platform.
597
+ *
598
+ * On macOS, checks if NordPass.app exists.
599
+ * On Windows/Git Bash, checks if NordPass is installed via Chocolatey.
600
+ * On Ubuntu/Debian, checks if NordPass is installed via Snap.
601
+ *
602
+ * @returns {Promise<boolean>} True if installed, false otherwise
603
+ */
604
+ async function isInstalled() {
605
+ const platform = os.detect();
606
+
607
+ if (platform.type === 'macos') {
608
+ return brew.isCaskInstalled(HOMEBREW_CASK_NAME);
609
+ }
610
+
611
+ if (platform.type === 'windows' || platform.type === 'gitbash') {
612
+ return choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
613
+ }
614
+
615
+ if (platform.type === 'ubuntu' || platform.type === 'debian') {
616
+ return snap.isSnapInstalled(SNAP_PACKAGE_NAME);
617
+ }
618
+
619
+ // WSL: Check for Snap installation
620
+ if (platform.type === 'wsl') {
621
+ return snap.isSnapInstalled(SNAP_PACKAGE_NAME);
622
+ }
623
+
624
+ // Raspberry Pi and Amazon Linux: NordPass is not available
625
+ return false;
626
+ }
627
+
628
+ /**
629
+ * Check if this installer is supported on the current platform.
630
+ * NordPass is available on macOS, Windows, and Ubuntu/Debian.
631
+ * NOT available on Raspberry Pi, Amazon Linux, or other server distros.
632
+ * @returns {boolean} True if installation is supported on this platform
633
+ */
634
+ function isEligible() {
635
+ const platform = os.detect();
636
+ // NordPass is NOT available for Raspberry Pi or server Linux distributions
637
+ const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'windows', 'gitbash'];
638
+ if (!supportedPlatforms.includes(platform.type)) {
639
+ return false;
640
+ }
641
+ if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
642
+ return false;
643
+ }
644
+ return true;
645
+ }
646
+
647
+ /**
648
+ * Main installation entry point.
649
+ *
650
+ * Detects the current platform and runs the appropriate installer function.
651
+ * Handles platform-specific mappings to ensure all supported platforms
652
+ * have appropriate installation logic.
653
+ *
654
+ * Supported platforms:
655
+ * - macOS: NordPass Desktop via Homebrew cask
656
+ * - Ubuntu/Debian: NordPass Desktop via Snap (x86_64 only)
657
+ * - Windows: NordPass Desktop via Chocolatey
658
+ * - WSL (Ubuntu): Recommends Windows installation or provides Snap instructions
659
+ * - Git Bash: NordPass Desktop on Windows host via Chocolatey
660
+ *
661
+ * Unsupported platforms (graceful exit):
662
+ * - Raspberry Pi OS: ARM architecture not supported
663
+ * - Amazon Linux/RHEL: No Snap/Flatpak support
12
664
  *
13
665
  * @returns {Promise<void>}
14
666
  */
15
667
  async function install() {
16
668
  const platform = os.detect();
17
669
 
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 };
670
+ // Map platform types to their installer functions
671
+ // This mapping handles aliases and ensures all detected platforms have handlers
672
+ const installers = {
673
+ 'macos': install_macos,
674
+ 'ubuntu': install_ubuntu,
675
+ 'debian': install_ubuntu,
676
+ 'wsl': install_ubuntu_wsl,
677
+ 'raspbian': install_raspbian,
678
+ 'amazon_linux': install_amazon_linux,
679
+ 'rhel': install_amazon_linux,
680
+ 'fedora': install_amazon_linux,
681
+ 'windows': install_windows,
682
+ 'gitbash': install_gitbash
683
+ };
684
+
685
+ const installer = installers[platform.type];
686
+
687
+ if (!installer) {
688
+ console.log('NordPass is not available for ' + platform.type + '.');
689
+ return;
690
+ }
691
+
692
+ await installer();
693
+ }
694
+
695
+ // Export all functions for use as a module and for testing
696
+ module.exports = {
697
+ REQUIRES_DESKTOP,
698
+ install,
699
+ isInstalled,
700
+ isEligible,
701
+ install_macos,
702
+ install_ubuntu,
703
+ install_ubuntu_wsl,
704
+ install_raspbian,
705
+ install_amazon_linux,
706
+ install_windows,
707
+ install_gitbash
708
+ };
41
709
 
710
+ // Allow direct execution: node nordpass.js
42
711
  if (require.main === module) {
43
- install();
712
+ install().catch(err => {
713
+ console.error(err.message);
714
+ process.exit(1);
715
+ });
44
716
  }