@fredlackey/devutils 0.0.17 → 0.0.19

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 (331) hide show
  1. package/README.md +32 -150
  2. package/package.json +5 -82
  3. package/bin/dev.js +0 -16
  4. package/files/README.md +0 -0
  5. package/files/claude/.claude/commands/setup-context.md +0 -3
  6. package/files/monorepos/_archive/README.md +0 -36
  7. package/files/monorepos/_legacy/README.md +0 -36
  8. package/files/monorepos/ai-docs/README.md +0 -33
  9. package/files/monorepos/apps/README.md +0 -24
  10. package/files/monorepos/docs/README.md +0 -40
  11. package/files/monorepos/packages/README.md +0 -25
  12. package/files/monorepos/research/README.md +0 -29
  13. package/files/monorepos/scripts/README.md +0 -24
  14. package/src/cli.js +0 -72
  15. package/src/commands/README.md +0 -41
  16. package/src/commands/configure.js +0 -199
  17. package/src/commands/identity.js +0 -1630
  18. package/src/commands/ignore.js +0 -247
  19. package/src/commands/install.js +0 -526
  20. package/src/commands/setup.js +0 -246
  21. package/src/commands/status.js +0 -223
  22. package/src/commands/update.js +0 -142
  23. package/src/commands/version.js +0 -100
  24. package/src/completion.js +0 -284
  25. package/src/constants.js +0 -45
  26. package/src/ignore/claude-code.txt +0 -10
  27. package/src/ignore/docker.txt +0 -18
  28. package/src/ignore/linux.txt +0 -23
  29. package/src/ignore/macos.txt +0 -36
  30. package/src/ignore/node.txt +0 -55
  31. package/src/ignore/terraform.txt +0 -37
  32. package/src/ignore/vscode.txt +0 -18
  33. package/src/ignore/windows.txt +0 -35
  34. package/src/index.js +0 -0
  35. package/src/installs/README.md +0 -399
  36. package/src/installs/adobe-creative-cloud.js +0 -546
  37. package/src/installs/adobe-creative-cloud.md +0 -605
  38. package/src/installs/appcleaner.js +0 -321
  39. package/src/installs/appcleaner.md +0 -699
  40. package/src/installs/apt-transport-https.js +0 -390
  41. package/src/installs/apt-transport-https.md +0 -678
  42. package/src/installs/atomicparsley.js +0 -642
  43. package/src/installs/atomicparsley.md +0 -795
  44. package/src/installs/aws-cli.js +0 -797
  45. package/src/installs/aws-cli.md +0 -727
  46. package/src/installs/balena-etcher.js +0 -710
  47. package/src/installs/balena-etcher.md +0 -761
  48. package/src/installs/bambu-studio.js +0 -1143
  49. package/src/installs/bambu-studio.md +0 -780
  50. package/src/installs/bash-completion.js +0 -575
  51. package/src/installs/bash-completion.md +0 -833
  52. package/src/installs/bash.js +0 -417
  53. package/src/installs/bash.md +0 -993
  54. package/src/installs/beyond-compare.js +0 -603
  55. package/src/installs/beyond-compare.md +0 -813
  56. package/src/installs/brave-browser.js +0 -968
  57. package/src/installs/brave-browser.md +0 -650
  58. package/src/installs/build-essential.js +0 -529
  59. package/src/installs/build-essential.md +0 -977
  60. package/src/installs/ca-certificates.js +0 -618
  61. package/src/installs/ca-certificates.md +0 -937
  62. package/src/installs/caffeine.js +0 -508
  63. package/src/installs/caffeine.md +0 -839
  64. package/src/installs/camtasia.js +0 -596
  65. package/src/installs/camtasia.md +0 -762
  66. package/src/installs/chatgpt.js +0 -476
  67. package/src/installs/chatgpt.md +0 -814
  68. package/src/installs/chocolatey.js +0 -456
  69. package/src/installs/chocolatey.md +0 -661
  70. package/src/installs/chrome-canary.js +0 -419
  71. package/src/installs/chrome-canary.md +0 -641
  72. package/src/installs/chromium.js +0 -667
  73. package/src/installs/chromium.md +0 -838
  74. package/src/installs/claude-code.js +0 -576
  75. package/src/installs/claude-code.md +0 -1173
  76. package/src/installs/cloudflare-warp.js +0 -900
  77. package/src/installs/cloudflare-warp.md +0 -1047
  78. package/src/installs/comet-browser.js +0 -588
  79. package/src/installs/comet-browser.md +0 -731
  80. package/src/installs/curl.js +0 -379
  81. package/src/installs/curl.md +0 -714
  82. package/src/installs/cursor.js +0 -579
  83. package/src/installs/cursor.md +0 -970
  84. package/src/installs/dbeaver.js +0 -924
  85. package/src/installs/dbeaver.md +0 -939
  86. package/src/installs/dbschema.js +0 -692
  87. package/src/installs/dbschema.md +0 -925
  88. package/src/installs/dependencies.md +0 -453
  89. package/src/installs/development-tools.js +0 -600
  90. package/src/installs/development-tools.md +0 -977
  91. package/src/installs/docker.js +0 -1029
  92. package/src/installs/docker.md +0 -1109
  93. package/src/installs/drawio.js +0 -1019
  94. package/src/installs/drawio.md +0 -795
  95. package/src/installs/elmedia-player.js +0 -347
  96. package/src/installs/elmedia-player.md +0 -556
  97. package/src/installs/ffmpeg.js +0 -889
  98. package/src/installs/ffmpeg.md +0 -852
  99. package/src/installs/file.js +0 -464
  100. package/src/installs/file.md +0 -987
  101. package/src/installs/gemini-cli.js +0 -811
  102. package/src/installs/gemini-cli.md +0 -1153
  103. package/src/installs/git.js +0 -400
  104. package/src/installs/git.md +0 -907
  105. package/src/installs/gitego.js +0 -949
  106. package/src/installs/gitego.md +0 -1172
  107. package/src/installs/go.js +0 -931
  108. package/src/installs/go.md +0 -958
  109. package/src/installs/google-antigravity.js +0 -913
  110. package/src/installs/google-antigravity.md +0 -1075
  111. package/src/installs/google-chrome.js +0 -833
  112. package/src/installs/google-chrome.md +0 -862
  113. package/src/installs/gpg.js +0 -480
  114. package/src/installs/gpg.md +0 -1056
  115. package/src/installs/homebrew.js +0 -1033
  116. package/src/installs/homebrew.md +0 -988
  117. package/src/installs/imageoptim.js +0 -968
  118. package/src/installs/imageoptim.md +0 -1119
  119. package/src/installs/installers.json +0 -4032
  120. package/src/installs/installers.json.tmp +0 -3953
  121. package/src/installs/jq.js +0 -400
  122. package/src/installs/jq.md +0 -809
  123. package/src/installs/keyboard-maestro.js +0 -719
  124. package/src/installs/keyboard-maestro.md +0 -825
  125. package/src/installs/kiro.js +0 -864
  126. package/src/installs/kiro.md +0 -1015
  127. package/src/installs/latex.js +0 -789
  128. package/src/installs/latex.md +0 -1095
  129. package/src/installs/lftp.js +0 -356
  130. package/src/installs/lftp.md +0 -907
  131. package/src/installs/lsb-release.js +0 -346
  132. package/src/installs/lsb-release.md +0 -814
  133. package/src/installs/messenger.js +0 -847
  134. package/src/installs/messenger.md +0 -900
  135. package/src/installs/microsoft-office.js +0 -568
  136. package/src/installs/microsoft-office.md +0 -760
  137. package/src/installs/microsoft-teams.js +0 -801
  138. package/src/installs/microsoft-teams.md +0 -886
  139. package/src/installs/moom.js +0 -326
  140. package/src/installs/moom.md +0 -570
  141. package/src/installs/node.js +0 -904
  142. package/src/installs/node.md +0 -1153
  143. package/src/installs/nordpass.js +0 -716
  144. package/src/installs/nordpass.md +0 -921
  145. package/src/installs/nordvpn.js +0 -892
  146. package/src/installs/nordvpn.md +0 -1052
  147. package/src/installs/nvm.js +0 -995
  148. package/src/installs/nvm.md +0 -1057
  149. package/src/installs/ohmyzsh.js +0 -529
  150. package/src/installs/ohmyzsh.md +0 -1094
  151. package/src/installs/openssh.js +0 -804
  152. package/src/installs/openssh.md +0 -1056
  153. package/src/installs/pandoc.js +0 -662
  154. package/src/installs/pandoc.md +0 -1036
  155. package/src/installs/parallels-desktop.js +0 -431
  156. package/src/installs/parallels-desktop.md +0 -446
  157. package/src/installs/pinentry.js +0 -510
  158. package/src/installs/pinentry.md +0 -1142
  159. package/src/installs/pngyu.js +0 -869
  160. package/src/installs/pngyu.md +0 -896
  161. package/src/installs/postman.js +0 -799
  162. package/src/installs/postman.md +0 -940
  163. package/src/installs/procps.js +0 -425
  164. package/src/installs/procps.md +0 -851
  165. package/src/installs/safari-tech-preview.js +0 -374
  166. package/src/installs/safari-tech-preview.md +0 -533
  167. package/src/installs/sfnt2woff.js +0 -658
  168. package/src/installs/sfnt2woff.md +0 -795
  169. package/src/installs/shellcheck.js +0 -481
  170. package/src/installs/shellcheck.md +0 -1005
  171. package/src/installs/slack.js +0 -741
  172. package/src/installs/slack.md +0 -865
  173. package/src/installs/snagit.js +0 -585
  174. package/src/installs/snagit.md +0 -844
  175. package/src/installs/software-properties-common.js +0 -372
  176. package/src/installs/software-properties-common.md +0 -805
  177. package/src/installs/spotify.js +0 -877
  178. package/src/installs/spotify.md +0 -901
  179. package/src/installs/studio-3t.js +0 -823
  180. package/src/installs/studio-3t.md +0 -918
  181. package/src/installs/sublime-text.js +0 -804
  182. package/src/installs/sublime-text.md +0 -914
  183. package/src/installs/superwhisper.js +0 -706
  184. package/src/installs/superwhisper.md +0 -630
  185. package/src/installs/tailscale.js +0 -745
  186. package/src/installs/tailscale.md +0 -1100
  187. package/src/installs/tar.js +0 -389
  188. package/src/installs/tar.md +0 -946
  189. package/src/installs/termius.js +0 -798
  190. package/src/installs/termius.md +0 -844
  191. package/src/installs/terraform.js +0 -779
  192. package/src/installs/terraform.md +0 -899
  193. package/src/installs/tfenv.js +0 -778
  194. package/src/installs/tfenv.md +0 -1091
  195. package/src/installs/tidal.js +0 -771
  196. package/src/installs/tidal.md +0 -864
  197. package/src/installs/tmux.js +0 -346
  198. package/src/installs/tmux.md +0 -1030
  199. package/src/installs/tree.js +0 -411
  200. package/src/installs/tree.md +0 -833
  201. package/src/installs/unzip.js +0 -460
  202. package/src/installs/unzip.md +0 -879
  203. package/src/installs/vim.js +0 -421
  204. package/src/installs/vim.md +0 -1040
  205. package/src/installs/vlc.js +0 -821
  206. package/src/installs/vlc.md +0 -927
  207. package/src/installs/vscode.js +0 -843
  208. package/src/installs/vscode.md +0 -1002
  209. package/src/installs/wget.js +0 -420
  210. package/src/installs/wget.md +0 -791
  211. package/src/installs/whatsapp.js +0 -729
  212. package/src/installs/whatsapp.md +0 -854
  213. package/src/installs/winpty.js +0 -352
  214. package/src/installs/winpty.md +0 -620
  215. package/src/installs/woff2.js +0 -553
  216. package/src/installs/woff2.md +0 -977
  217. package/src/installs/wsl.js +0 -572
  218. package/src/installs/wsl.md +0 -699
  219. package/src/installs/xcode-clt.js +0 -520
  220. package/src/installs/xcode-clt.md +0 -351
  221. package/src/installs/xcode.js +0 -560
  222. package/src/installs/xcode.md +0 -573
  223. package/src/installs/yarn.js +0 -824
  224. package/src/installs/yarn.md +0 -1074
  225. package/src/installs/yq.js +0 -654
  226. package/src/installs/yq.md +0 -944
  227. package/src/installs/yt-dlp.js +0 -701
  228. package/src/installs/yt-dlp.md +0 -946
  229. package/src/installs/yum-utils.js +0 -297
  230. package/src/installs/yum-utils.md +0 -648
  231. package/src/installs/zoom.js +0 -759
  232. package/src/installs/zoom.md +0 -884
  233. package/src/installs/zsh.js +0 -455
  234. package/src/installs/zsh.md +0 -1008
  235. package/src/scripts/README.md +0 -617
  236. package/src/scripts/STATUS.md +0 -208
  237. package/src/scripts/afk.js +0 -411
  238. package/src/scripts/backup-all.js +0 -746
  239. package/src/scripts/backup-source.js +0 -727
  240. package/src/scripts/brewd.js +0 -389
  241. package/src/scripts/brewi.js +0 -520
  242. package/src/scripts/brewr.js +0 -527
  243. package/src/scripts/brews.js +0 -477
  244. package/src/scripts/brewu.js +0 -504
  245. package/src/scripts/c.js +0 -201
  246. package/src/scripts/ccurl.js +0 -341
  247. package/src/scripts/certbot-crontab-init.js +0 -504
  248. package/src/scripts/certbot-init.js +0 -657
  249. package/src/scripts/ch.js +0 -355
  250. package/src/scripts/claude-danger.js +0 -268
  251. package/src/scripts/clean-dev.js +0 -435
  252. package/src/scripts/clear-dns-cache.js +0 -541
  253. package/src/scripts/clone.js +0 -435
  254. package/src/scripts/code-all.js +0 -437
  255. package/src/scripts/count-files.js +0 -211
  256. package/src/scripts/count-folders.js +0 -211
  257. package/src/scripts/count.js +0 -264
  258. package/src/scripts/d.js +0 -219
  259. package/src/scripts/datauri.js +0 -389
  260. package/src/scripts/delete-files.js +0 -380
  261. package/src/scripts/docker-clean.js +0 -426
  262. package/src/scripts/dp.js +0 -442
  263. package/src/scripts/e.js +0 -390
  264. package/src/scripts/empty-trash.js +0 -513
  265. package/src/scripts/evm.js +0 -444
  266. package/src/scripts/fetch-github-repos.js +0 -456
  267. package/src/scripts/get-channel.js +0 -345
  268. package/src/scripts/get-course.js +0 -399
  269. package/src/scripts/get-dependencies.js +0 -306
  270. package/src/scripts/get-folder.js +0 -799
  271. package/src/scripts/get-tunes.js +0 -426
  272. package/src/scripts/get-video.js +0 -367
  273. package/src/scripts/git-backup.js +0 -577
  274. package/src/scripts/git-clone.js +0 -493
  275. package/src/scripts/git-pup.js +0 -319
  276. package/src/scripts/git-push.js +0 -396
  277. package/src/scripts/h.js +0 -622
  278. package/src/scripts/hide-desktop-icons.js +0 -499
  279. package/src/scripts/hide-hidden-files.js +0 -538
  280. package/src/scripts/install-dependencies-from.js +0 -456
  281. package/src/scripts/ips.js +0 -663
  282. package/src/scripts/iso.js +0 -370
  283. package/src/scripts/killni.js +0 -577
  284. package/src/scripts/ll.js +0 -467
  285. package/src/scripts/local-ip.js +0 -325
  286. package/src/scripts/m.js +0 -524
  287. package/src/scripts/map.js +0 -309
  288. package/src/scripts/mkd.js +0 -351
  289. package/src/scripts/ncu-update-all.js +0 -457
  290. package/src/scripts/nginx-init.js +0 -718
  291. package/src/scripts/npmi.js +0 -382
  292. package/src/scripts/o.js +0 -511
  293. package/src/scripts/org-by-date.js +0 -338
  294. package/src/scripts/p.js +0 -224
  295. package/src/scripts/packages.js +0 -330
  296. package/src/scripts/path.js +0 -225
  297. package/src/scripts/ports.js +0 -597
  298. package/src/scripts/q.js +0 -305
  299. package/src/scripts/refresh-files.js +0 -394
  300. package/src/scripts/remove-smaller-files.js +0 -516
  301. package/src/scripts/rename-files-with-date.js +0 -533
  302. package/src/scripts/resize-image.js +0 -539
  303. package/src/scripts/rm-safe.js +0 -669
  304. package/src/scripts/s.js +0 -540
  305. package/src/scripts/set-git-public.js +0 -365
  306. package/src/scripts/show-desktop-icons.js +0 -475
  307. package/src/scripts/show-hidden-files.js +0 -472
  308. package/src/scripts/tpa.js +0 -280
  309. package/src/scripts/tpo.js +0 -280
  310. package/src/scripts/u.js +0 -505
  311. package/src/scripts/vpush.js +0 -437
  312. package/src/scripts/y.js +0 -283
  313. package/src/utils/README.md +0 -95
  314. package/src/utils/common/apps.js +0 -143
  315. package/src/utils/common/display.js +0 -157
  316. package/src/utils/common/network.js +0 -185
  317. package/src/utils/common/os.js +0 -294
  318. package/src/utils/common/package-manager.js +0 -301
  319. package/src/utils/common/privileges.js +0 -138
  320. package/src/utils/common/shell.js +0 -216
  321. package/src/utils/macos/apps.js +0 -228
  322. package/src/utils/macos/brew.js +0 -315
  323. package/src/utils/ubuntu/apt.js +0 -307
  324. package/src/utils/ubuntu/desktop.js +0 -292
  325. package/src/utils/ubuntu/snap.js +0 -344
  326. package/src/utils/ubuntu/systemd.js +0 -286
  327. package/src/utils/windows/choco.js +0 -465
  328. package/src/utils/windows/env.js +0 -246
  329. package/src/utils/windows/registry.js +0 -269
  330. package/src/utils/windows/shell.js +0 -240
  331. package/src/utils/windows/winget.js +0 -489
@@ -1,718 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * nginx-init - Create nginx configuration from template
5
- *
6
- * Migrated from legacy dotfiles function.
7
- * Original:
8
- * nginx-init() {
9
- * # Initialize nginx configuration from template files.
10
- * # Usage: nginx-init -d example.com -h http://127.0.0.1:3000 -f example.conf
11
- * # Copies template, replaces %DOMAINS% and %HOST_URL% tokens,
12
- * # writes to /etc/nginx/sites-available, optionally creates symlink
13
- * }
14
- *
15
- * This script creates nginx site configuration files from templates,
16
- * replacing placeholder tokens with actual domain names and upstream URLs.
17
- * It supports:
18
- * - Multiple domains per configuration (-d can be used multiple times)
19
- * - Standard and API templates (with CORS preflight handling)
20
- * - Automatic symlink creation in sites-enabled
21
- *
22
- * @module scripts/nginx-init
23
- */
24
-
25
- const os = require('../utils/common/os');
26
- const fs = require('fs');
27
- const path = require('path');
28
- const { execSync, spawnSync } = require('child_process');
29
-
30
- // Define the nginx template content directly in the script
31
- // This ensures the script works regardless of where it's installed
32
-
33
- /**
34
- * Standard nginx template for proxying requests to a backend service.
35
- * Uses %DOMAINS% and %HOST_URL% as placeholder tokens.
36
- */
37
- const TEMPLATE_STANDARD = `server {
38
-
39
- server_name %DOMAINS%;
40
- listen 80;
41
-
42
- # Allow GET requests to root path
43
- location / {
44
- proxy_pass %HOST_URL%;
45
- proxy_set_header Host $host;
46
- proxy_set_header X-Real-IP $remote_addr;
47
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
48
- proxy_set_header X-Forwarded-Proto $scheme;
49
- }
50
-
51
- }
52
- `;
53
-
54
- /**
55
- * API nginx template with CORS preflight handling.
56
- * Includes OPTIONS request handling for cross-origin API requests.
57
- * Uses %DOMAINS% and %HOST_URL% as placeholder tokens.
58
- */
59
- const TEMPLATE_API = `server {
60
-
61
- server_name %DOMAINS%;
62
- listen 80;
63
-
64
- # Allow GET requests to root path
65
- location / {
66
- proxy_pass %HOST_URL%;
67
- proxy_http_version 1.1;
68
- proxy_set_header Host $host;
69
- proxy_set_header X-Real-IP $remote_addr;
70
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
71
- proxy_set_header X-Forwarded-Proto $scheme;
72
-
73
- # Preflight CORS requests
74
- if ($request_method = OPTIONS ) {
75
- add_header Access-Control-Allow-Origin *;
76
- add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
77
- add_header Access-Control-Allow-Headers "Content-Type";
78
- add_header Content-Length 0;
79
- add_header Content-Type text/plain;
80
- return 204;
81
- }
82
- }
83
-
84
- }
85
- `;
86
-
87
- /**
88
- * Display usage information and examples.
89
- * Shows all available options and how to use them correctly.
90
- */
91
- function showUsage() {
92
- console.log(`nginx-init - Create nginx configuration from template
93
-
94
- USAGE:
95
- nginx-init [OPTIONS]
96
-
97
- OPTIONS:
98
- -a, --api Use API template with CORS preflight handling
99
- -d, --domain Domain name for server_name directive (can be used multiple times) (required)
100
- -h, --host Upstream URL for proxy_pass directive (required)
101
- -f, --file Output filename in /etc/nginx/sites-available (must end with .conf) (required)
102
- -l, --link Create symbolic link in /etc/nginx/sites-enabled
103
- --help Show this help message
104
-
105
- EXAMPLES:
106
- nginx-init -d example.com -h http://127.0.0.1:3000 -f example.conf
107
- nginx-init -d example.com -d www.example.com -h http://127.0.0.1:3000 -f example.conf
108
- nginx-init --api -d api.example.com -h http://127.0.0.1:8080 -f api.conf --link
109
-
110
- NOTE:
111
- This command requires sudo access to write to /etc/nginx/
112
- The output file will be created in /etc/nginx/sites-available/
113
- Use --link to also create a symlink in /etc/nginx/sites-enabled/`);
114
- }
115
-
116
- /**
117
- * Parse command line arguments into structured options.
118
- * Handles -a/--api, -d/--domain (multiple allowed), -h/--host, -f/--file, -l/--link flags.
119
- *
120
- * @param {string[]} args - Raw command line arguments
121
- * @returns {{ useApi: boolean, domains: string[], host: string, filename: string, createLink: boolean, help: boolean, error: string|null }}
122
- */
123
- function parseArgs(args) {
124
- const result = {
125
- useApi: false,
126
- domains: [],
127
- host: '',
128
- filename: '',
129
- createLink: false,
130
- help: false,
131
- error: null
132
- };
133
-
134
- let i = 0;
135
- while (i < args.length) {
136
- const arg = args[i];
137
-
138
- if (arg === '--help') {
139
- result.help = true;
140
- return result;
141
- }
142
-
143
- if (arg === '-a' || arg === '--api') {
144
- result.useApi = true;
145
- i += 1;
146
- continue;
147
- }
148
-
149
- if (arg === '-l' || arg === '--link') {
150
- result.createLink = true;
151
- i += 1;
152
- continue;
153
- }
154
-
155
- if (arg === '-d' || arg === '--domain') {
156
- // Check if next argument exists and is not another flag
157
- if (i + 1 >= args.length || args[i + 1].startsWith('-')) {
158
- result.error = 'Domain value required after -d/--domain';
159
- return result;
160
- }
161
- result.domains.push(args[i + 1]);
162
- i += 2;
163
- continue;
164
- }
165
-
166
- if (arg === '-h' || arg === '--host') {
167
- // Check if next argument exists and is not another flag
168
- if (i + 1 >= args.length || args[i + 1].startsWith('-')) {
169
- result.error = 'Host URL value required after -h/--host';
170
- return result;
171
- }
172
- result.host = args[i + 1];
173
- i += 2;
174
- continue;
175
- }
176
-
177
- if (arg === '-f' || arg === '--file') {
178
- // Check if next argument exists and is not another flag
179
- if (i + 1 >= args.length || args[i + 1].startsWith('-')) {
180
- result.error = 'Filename value required after -f/--file';
181
- return result;
182
- }
183
- result.filename = args[i + 1];
184
- i += 2;
185
- continue;
186
- }
187
-
188
- // Unknown option
189
- result.error = `Unknown option: ${arg}`;
190
- return result;
191
- }
192
-
193
- return result;
194
- }
195
-
196
- /**
197
- * Check if a command exists on the system.
198
- * Uses 'which' on Unix-like systems to locate executables.
199
- *
200
- * @param {string} cmd - The command name to check
201
- * @returns {boolean} True if the command exists in PATH
202
- */
203
- function isCommandAvailable(cmd) {
204
- try {
205
- const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
206
- execSync(checkCmd, { stdio: 'ignore' });
207
- return true;
208
- } catch {
209
- return false;
210
- }
211
- }
212
-
213
- /**
214
- * Check if the current user has sudo access.
215
- * First tries passwordless sudo, then validates sudo credentials.
216
- *
217
- * @returns {boolean} True if sudo access is available
218
- */
219
- function checkSudoAccess() {
220
- try {
221
- // Try passwordless sudo first
222
- execSync('sudo -n true', { stdio: 'ignore' });
223
- console.log('Using passwordless sudo');
224
- return true;
225
- } catch {
226
- // Fall back to regular sudo (will prompt for password if needed)
227
- console.log('Authenticating with sudo...');
228
- try {
229
- // sudo -v validates the user's credentials and extends the timeout
230
- const result = spawnSync('sudo', ['-v'], { stdio: 'inherit' });
231
- return result.status === 0;
232
- } catch {
233
- return false;
234
- }
235
- }
236
- }
237
-
238
- /**
239
- * Pure Node.js implementation - NOT APPLICABLE for this script.
240
- *
241
- * Writing to /etc/nginx/ requires sudo access which cannot be done
242
- * in pure Node.js. Each platform function handles the sudo elevation
243
- * using OS-specific commands.
244
- *
245
- * @param {string[]} args - Command line arguments
246
- * @returns {Promise<void>}
247
- * @throws {Error} Always throws - this function should not be called directly
248
- */
249
- async function do_nginx_init_nodejs(args) {
250
- throw new Error(
251
- 'do_nginx_init_nodejs should not be called directly. ' +
252
- 'Writing to /etc/nginx/ requires sudo access which is OS-specific.'
253
- );
254
- }
255
-
256
- /**
257
- * Core implementation for creating nginx configuration.
258
- * This function contains the shared logic for all Unix-like platforms.
259
- * It handles argument parsing, validation, template processing, and file writing.
260
- *
261
- * @param {string[]} args - Command line arguments
262
- * @param {string} sitesAvailable - Path to nginx sites-available directory
263
- * @param {string} sitesEnabled - Path to nginx sites-enabled directory
264
- * @returns {Promise<void>}
265
- */
266
- async function createNginxConfig(args, sitesAvailable, sitesEnabled) {
267
- // Parse and validate arguments
268
- const options = parseArgs(args);
269
-
270
- if (options.help) {
271
- showUsage();
272
- return;
273
- }
274
-
275
- if (options.error) {
276
- console.error(`Error: ${options.error}`);
277
- showUsage();
278
- process.exit(1);
279
- }
280
-
281
- // Show usage if no arguments provided
282
- if (args.length === 0) {
283
- showUsage();
284
- return;
285
- }
286
-
287
- // Validate required arguments
288
- if (options.domains.length === 0) {
289
- console.error('Error: At least one domain is required (-d or --domain)');
290
- showUsage();
291
- process.exit(1);
292
- }
293
-
294
- if (!options.host) {
295
- console.error('Error: Host URL is required (-h or --host)');
296
- showUsage();
297
- process.exit(1);
298
- }
299
-
300
- if (!options.filename) {
301
- console.error('Error: Filename is required (-f or --file)');
302
- showUsage();
303
- process.exit(1);
304
- }
305
-
306
- // Validate filename ends with .conf
307
- if (!options.filename.endsWith('.conf')) {
308
- console.error('Error: Filename must end with .conf');
309
- process.exit(1);
310
- }
311
-
312
- // Check if sites-available directory exists
313
- if (!fs.existsSync(sitesAvailable)) {
314
- console.error(`Error: Directory ${sitesAvailable} does not exist`);
315
- console.error('');
316
- console.error('Make sure nginx is installed:');
317
- console.error(' Ubuntu/Debian: sudo apt install nginx');
318
- console.error(' macOS: brew install nginx');
319
- console.error(' Amazon Linux: sudo dnf install nginx');
320
- process.exit(1);
321
- }
322
-
323
- // Check sudo access
324
- console.log('This command requires sudo access to write to /etc/nginx/');
325
- if (!checkSudoAccess()) {
326
- console.error('Error: sudo authentication failed');
327
- process.exit(1);
328
- }
329
-
330
- // Select template
331
- const templateContent = options.useApi ? TEMPLATE_API : TEMPLATE_STANDARD;
332
- const templateName = options.useApi ? 'API template (with CORS)' : 'Standard template';
333
-
334
- // Join domains into a single string for server_name directive
335
- const domainString = options.domains.join(' ');
336
-
337
- // Perform token replacement
338
- const configContent = templateContent
339
- .replace(/%DOMAINS%/g, domainString)
340
- .replace(/%HOST_URL%/g, options.host);
341
-
342
- // Create output file path
343
- const outputFile = path.join(sitesAvailable, options.filename);
344
-
345
- // Check if output file already exists
346
- if (fs.existsSync(outputFile)) {
347
- console.log(`Warning: File ${outputFile} already exists and will be overwritten`);
348
- }
349
-
350
- // Display what we're about to do
351
- console.log('');
352
- console.log('Creating nginx configuration...');
353
- console.log(` Template: ${templateName}`);
354
- console.log(` Domains: ${domainString}`);
355
- console.log(` Host: ${options.host}`);
356
- console.log(` Output: ${outputFile}`);
357
- console.log('');
358
-
359
- // Write configuration file using sudo tee
360
- // We use a temporary file and sudo mv because direct sudo write is tricky in Node.js
361
- try {
362
- // Create a temporary file with the config content
363
- const tmpFile = path.join('/tmp', `nginx-config-${Date.now()}.conf`);
364
- fs.writeFileSync(tmpFile, configContent, 'utf8');
365
-
366
- // Use sudo to copy the file to the destination
367
- execSync(`sudo cp "${tmpFile}" "${outputFile}"`, { stdio: 'inherit' });
368
-
369
- // Clean up temporary file
370
- fs.unlinkSync(tmpFile);
371
-
372
- console.log('Configuration file created successfully');
373
- } catch (error) {
374
- console.error('Failed to create configuration file');
375
- console.error(error.message);
376
- process.exit(1);
377
- }
378
-
379
- // Create symbolic link if requested
380
- if (options.createLink) {
381
- // Check if sites-enabled directory exists
382
- if (!fs.existsSync(sitesEnabled)) {
383
- console.error(`Error: Directory ${sitesEnabled} does not exist`);
384
- process.exit(1);
385
- }
386
-
387
- const linkPath = path.join(sitesEnabled, options.filename);
388
-
389
- // Remove existing link if it exists
390
- try {
391
- const linkStats = fs.lstatSync(linkPath);
392
- if (linkStats.isSymbolicLink()) {
393
- execSync(`sudo rm "${linkPath}"`, { stdio: 'inherit' });
394
- console.log('Removed existing symbolic link');
395
- }
396
- } catch {
397
- // Link doesn't exist, which is fine
398
- }
399
-
400
- // Create new symbolic link
401
- try {
402
- execSync(`sudo ln -s "${outputFile}" "${linkPath}"`, { stdio: 'inherit' });
403
- console.log(`Symbolic link created: ${linkPath}`);
404
- } catch (error) {
405
- console.error('Failed to create symbolic link');
406
- console.error(error.message);
407
- process.exit(1);
408
- }
409
- }
410
-
411
- console.log('');
412
- console.log('Done!');
413
- console.log('');
414
- console.log('Next steps:');
415
- console.log(' 1. Test nginx configuration: sudo nginx -t');
416
- console.log(' 2. Reload nginx: sudo systemctl reload nginx');
417
- if (!options.createLink) {
418
- console.log(` 3. Enable site (if not using --link): sudo ln -s ${outputFile} ${sitesEnabled}/${options.filename}`);
419
- }
420
- console.log(' 4. Set up SSL (optional): certbot-init -d ' + options.domains[0] + ' -e admin@' + options.domains[0]);
421
- }
422
-
423
- /**
424
- * Create nginx configuration on macOS.
425
- *
426
- * macOS with Homebrew installs nginx to different paths than Linux.
427
- * The sites-available and sites-enabled directories may need to be created
428
- * or the configuration may go directly into /usr/local/etc/nginx/servers/.
429
- *
430
- * @param {string[]} args - Command line arguments
431
- * @returns {Promise<void>}
432
- */
433
- async function do_nginx_init_macos(args) {
434
- // Check for help flag first (before nginx check)
435
- const options = parseArgs(args);
436
- if (options.help || args.length === 0) {
437
- showUsage();
438
- return;
439
- }
440
-
441
- // Check if nginx is installed
442
- if (!isCommandAvailable('nginx')) {
443
- console.error('Error: nginx is not installed.');
444
- console.error('Install it with: brew install nginx');
445
- process.exit(1);
446
- }
447
-
448
- // macOS Homebrew nginx paths
449
- // Modern Homebrew (Apple Silicon): /opt/homebrew/etc/nginx/
450
- // Older Homebrew (Intel): /usr/local/etc/nginx/
451
- let nginxBase = '/usr/local/etc/nginx';
452
- if (fs.existsSync('/opt/homebrew/etc/nginx')) {
453
- nginxBase = '/opt/homebrew/etc/nginx';
454
- }
455
-
456
- // Homebrew nginx uses 'servers' directory instead of sites-available/sites-enabled
457
- // But we can create the standard directories for compatibility
458
- const sitesAvailable = path.join(nginxBase, 'sites-available');
459
- const sitesEnabled = path.join(nginxBase, 'sites-enabled');
460
-
461
- // Create directories if they don't exist
462
- if (!fs.existsSync(sitesAvailable)) {
463
- console.log(`Creating ${sitesAvailable} directory...`);
464
- try {
465
- execSync(`sudo mkdir -p "${sitesAvailable}"`, { stdio: 'inherit' });
466
- } catch (error) {
467
- console.error(`Failed to create ${sitesAvailable}`);
468
- process.exit(1);
469
- }
470
- }
471
-
472
- if (!fs.existsSync(sitesEnabled)) {
473
- console.log(`Creating ${sitesEnabled} directory...`);
474
- try {
475
- execSync(`sudo mkdir -p "${sitesEnabled}"`, { stdio: 'inherit' });
476
- } catch (error) {
477
- console.error(`Failed to create ${sitesEnabled}`);
478
- process.exit(1);
479
- }
480
- }
481
-
482
- console.log('');
483
- console.log('Note: macOS nginx configuration');
484
- console.log(` Base path: ${nginxBase}`);
485
- console.log(' You may need to include sites-enabled in your nginx.conf:');
486
- console.log(` include ${sitesEnabled}/*;`);
487
- console.log('');
488
-
489
- await createNginxConfig(args, sitesAvailable, sitesEnabled);
490
- }
491
-
492
- /**
493
- * Create nginx configuration on Ubuntu.
494
- *
495
- * Ubuntu uses the standard /etc/nginx/sites-available and sites-enabled
496
- * directories that Debian established for nginx configuration management.
497
- *
498
- * @param {string[]} args - Command line arguments
499
- * @returns {Promise<void>}
500
- */
501
- async function do_nginx_init_ubuntu(args) {
502
- // Check for help flag first (before nginx check)
503
- const options = parseArgs(args);
504
- if (options.help || args.length === 0) {
505
- showUsage();
506
- return;
507
- }
508
-
509
- // Check if nginx is installed
510
- if (!isCommandAvailable('nginx')) {
511
- console.error('Error: nginx is not installed.');
512
- console.error('Install it with: sudo apt install nginx');
513
- process.exit(1);
514
- }
515
-
516
- // Standard Debian/Ubuntu nginx paths
517
- const sitesAvailable = '/etc/nginx/sites-available';
518
- const sitesEnabled = '/etc/nginx/sites-enabled';
519
-
520
- await createNginxConfig(args, sitesAvailable, sitesEnabled);
521
- }
522
-
523
- /**
524
- * Create nginx configuration on Raspberry Pi OS.
525
- *
526
- * Raspberry Pi OS is Debian-based and uses the same nginx paths as Ubuntu.
527
- *
528
- * @param {string[]} args - Command line arguments
529
- * @returns {Promise<void>}
530
- */
531
- async function do_nginx_init_raspbian(args) {
532
- // Check for help flag first (before nginx check)
533
- const options = parseArgs(args);
534
- if (options.help || args.length === 0) {
535
- showUsage();
536
- return;
537
- }
538
-
539
- // Check if nginx is installed
540
- if (!isCommandAvailable('nginx')) {
541
- console.error('Error: nginx is not installed.');
542
- console.error('Install it with: sudo apt install nginx');
543
- process.exit(1);
544
- }
545
-
546
- // Same paths as Ubuntu (Debian-based)
547
- const sitesAvailable = '/etc/nginx/sites-available';
548
- const sitesEnabled = '/etc/nginx/sites-enabled';
549
-
550
- await createNginxConfig(args, sitesAvailable, sitesEnabled);
551
- }
552
-
553
- /**
554
- * Create nginx configuration on Amazon Linux.
555
- *
556
- * Amazon Linux (and other RHEL-based systems) use /etc/nginx/conf.d/
557
- * instead of the Debian-style sites-available/sites-enabled structure.
558
- * Configuration files placed in conf.d are automatically included.
559
- *
560
- * @param {string[]} args - Command line arguments
561
- * @returns {Promise<void>}
562
- */
563
- async function do_nginx_init_amazon_linux(args) {
564
- // Check for help flag first (before nginx check)
565
- const options = parseArgs(args);
566
- if (options.help || args.length === 0) {
567
- showUsage();
568
- return;
569
- }
570
-
571
- // Check if nginx is installed
572
- if (!isCommandAvailable('nginx')) {
573
- console.error('Error: nginx is not installed.');
574
- console.error('Install it with: sudo dnf install nginx');
575
- console.error(' or: sudo yum install nginx');
576
- process.exit(1);
577
- }
578
-
579
- // RHEL-based systems use conf.d instead of sites-available/sites-enabled
580
- // Files in conf.d are automatically included by the main nginx.conf
581
- const confDir = '/etc/nginx/conf.d';
582
-
583
- // For RHEL systems, we use conf.d for both "available" and "enabled"
584
- // since all configs in conf.d are automatically loaded
585
- // We still support the --link flag but it's not strictly necessary
586
- console.log('');
587
- console.log('Note: Amazon Linux/RHEL nginx configuration');
588
- console.log(' Configuration files in /etc/nginx/conf.d/ are automatically included.');
589
- console.log(' The --link option is not required on RHEL-based systems.');
590
- console.log('');
591
-
592
- await createNginxConfig(args, confDir, confDir);
593
- }
594
-
595
- /**
596
- * nginx configuration on Windows Command Prompt.
597
- *
598
- * nginx on Windows is less common and has a different directory structure.
599
- * This command is primarily designed for Linux servers.
600
- *
601
- * @param {string[]} args - Command line arguments
602
- * @returns {Promise<void>}
603
- */
604
- async function do_nginx_init_cmd(args) {
605
- console.log('nginx-init is not fully supported on Windows.');
606
- console.log('');
607
- console.log('This command is designed for Linux servers running nginx.');
608
- console.log('');
609
- console.log('For Windows environments, consider:');
610
- console.log(' - Using WSL (Windows Subsystem for Linux) for a Linux-like experience');
611
- console.log(' - Manually editing nginx configuration files');
612
- console.log(' - Using IIS as the web server instead');
613
- console.log('');
614
- console.log('If nginx is installed on Windows:');
615
- console.log(' 1. Locate your nginx installation directory');
616
- console.log(' 2. Create configuration files in the conf/ subdirectory');
617
- console.log(' 3. Include them in nginx.conf');
618
- process.exit(1);
619
- }
620
-
621
- /**
622
- * nginx configuration on Windows PowerShell.
623
- *
624
- * Same limitations as CMD - nginx on Windows is not the primary target.
625
- *
626
- * @param {string[]} args - Command line arguments
627
- * @returns {Promise<void>}
628
- */
629
- async function do_nginx_init_powershell(args) {
630
- // Same behavior as CMD
631
- return do_nginx_init_cmd(args);
632
- }
633
-
634
- /**
635
- * nginx configuration from Git Bash on Windows.
636
- *
637
- * Git Bash runs on Windows, so it has the same limitations as CMD.
638
- *
639
- * @param {string[]} args - Command line arguments
640
- * @returns {Promise<void>}
641
- */
642
- async function do_nginx_init_gitbash(args) {
643
- // Same behavior as CMD
644
- return do_nginx_init_cmd(args);
645
- }
646
-
647
- /**
648
- * Main entry point - detects environment and executes appropriate implementation.
649
- *
650
- * The nginx-init command creates nginx site configuration files from templates.
651
- * It automates the common task of setting up a reverse proxy configuration
652
- * for web applications running on local ports.
653
- *
654
- * Features:
655
- * - Multiple domain support (server_name directive)
656
- * - Standard and API templates (CORS preflight handling)
657
- * - Automatic symlink creation in sites-enabled
658
- * - Cross-platform support (Linux variants, macOS)
659
- *
660
- * This command requires:
661
- * - nginx installed on the system
662
- * - sudo access for writing to /etc/nginx/
663
- *
664
- * @param {string[]} args - Command line arguments
665
- * @returns {Promise<void>}
666
- */
667
- async function do_nginx_init(args) {
668
- const platform = os.detect();
669
-
670
- const handlers = {
671
- 'macos': do_nginx_init_macos,
672
- 'ubuntu': do_nginx_init_ubuntu,
673
- 'debian': do_nginx_init_ubuntu,
674
- 'raspbian': do_nginx_init_raspbian,
675
- 'amazon_linux': do_nginx_init_amazon_linux,
676
- 'rhel': do_nginx_init_amazon_linux,
677
- 'fedora': do_nginx_init_amazon_linux,
678
- 'linux': do_nginx_init_ubuntu,
679
- 'wsl': do_nginx_init_ubuntu,
680
- 'cmd': do_nginx_init_cmd,
681
- 'windows': do_nginx_init_cmd,
682
- 'powershell': do_nginx_init_powershell,
683
- 'gitbash': do_nginx_init_gitbash
684
- };
685
-
686
- const handler = handlers[platform.type];
687
- if (!handler) {
688
- console.error(`Platform '${platform.type}' is not supported for this command.`);
689
- console.error('');
690
- console.error('Supported platforms:');
691
- console.error(' - macOS (with Homebrew nginx)');
692
- console.error(' - Ubuntu, Debian (with APT)');
693
- console.error(' - Raspberry Pi OS (with APT)');
694
- console.error(' - Amazon Linux, RHEL, Fedora (with DNF/YUM)');
695
- console.error('');
696
- console.error('Windows is not fully supported - use WSL for a Linux environment.');
697
- process.exit(1);
698
- }
699
-
700
- await handler(args);
701
- }
702
-
703
- module.exports = {
704
- main: do_nginx_init,
705
- do_nginx_init,
706
- do_nginx_init_nodejs,
707
- do_nginx_init_macos,
708
- do_nginx_init_ubuntu,
709
- do_nginx_init_raspbian,
710
- do_nginx_init_amazon_linux,
711
- do_nginx_init_cmd,
712
- do_nginx_init_powershell,
713
- do_nginx_init_gitbash
714
- };
715
-
716
- if (require.main === module) {
717
- do_nginx_init(process.argv.slice(2));
718
- }