@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
@@ -6,70 +6,591 @@ This folder contains **Scripts** — standalone global utilities that replace sh
6
6
 
7
7
  Scripts are single-command utilities that can be invoked directly from the command line after installing the package globally. They provide cross-platform implementations of common shell aliases and functions.
8
8
 
9
- ## Examples
9
+ ## File Structure
10
+
11
+ Each script follows the cross-platform pattern with these exports:
12
+
13
+ ```javascript
14
+ module.exports = {
15
+ main: do_scriptname, // Entry point (alias)
16
+ do_scriptname, // Main dispatcher with platform routing
17
+ do_scriptname_nodejs, // Pure Node.js implementation
18
+ do_scriptname_macos, // macOS implementation
19
+ do_scriptname_ubuntu, // Ubuntu/Debian implementation
20
+ do_scriptname_raspbian, // Raspberry Pi OS implementation
21
+ do_scriptname_amazon_linux, // Amazon Linux/RHEL implementation
22
+ do_scriptname_cmd, // Windows CMD implementation
23
+ do_scriptname_powershell, // Windows PowerShell implementation
24
+ do_scriptname_gitbash // Git Bash implementation
25
+ };
26
+ ```
27
+
28
+ ---
29
+
30
+ ## Categories
10
31
 
32
+ ### Backup & Sync
33
+
34
+ #### `backup-all`
11
35
  ```bash
12
- afk # Lock screen / sleep
13
- clone <url> # Clone repo and install dependencies
14
- ll # Long directory listing
15
- git-push # Add, commit, and push in one command
16
- docker-clean # Remove all containers, images, volumes
36
+ backup-all /path/to/backup/destination
17
37
  ```
38
+ Backs up multiple user directories (Desktop, Documents, Downloads, Source, etc.) to a timestamped destination folder using rsync. Excludes common development artifacts like node_modules, .git, and cache directories.
18
39
 
19
- ## File Structure
40
+ #### `backup-source`
41
+ ```bash
42
+ backup-source /path/to/backup/destination
43
+ ```
44
+ Backs up the ~/Source directory to a timestamped destination folder using rsync or robocopy. Useful for creating snapshots of your code repositories.
20
45
 
21
- Each script follows this pattern:
46
+ #### `git-backup`
47
+ ```bash
48
+ git-backup /path/to/backup [git-url]
49
+ ```
50
+ Creates a timestamped zip backup of a git repository (including all branches and history via mirror clone). Skips backup if no changes since last backup.
22
51
 
23
- ```javascript
24
- #!/usr/bin/env node
25
-
26
- /**
27
- * @fileoverview Brief description of the script.
28
- * @module scripts/script-name
29
- */
30
-
31
- /**
32
- * Detailed description of what the script does.
33
- *
34
- * @param {string[]} args - Command line arguments
35
- * @returns {Promise<void>}
36
- */
37
- async function main(args) {
38
- // Implementation
39
- }
52
+ #### `get-folder`
53
+ ```bash
54
+ get-folder /source/folder [/destination/folder]
55
+ ```
56
+ Copies files from source to destination, skipping files that already exist with the same size. Uses rsync on Unix or robocopy on Windows.
57
+
58
+ #### `refresh-files`
59
+ ```bash
60
+ refresh-files /source/folder [/target/folder]
61
+ ```
62
+ Updates files in the target directory from the source directory, but only for files that already exist in both locations. Does not add or remove files.
40
63
 
41
- module.exports = { main };
64
+ ---
42
65
 
43
- if (require.main === module) {
44
- main(process.argv.slice(2));
45
- }
66
+ ### Directory Navigation
67
+
68
+ #### `d`
69
+ ```bash
70
+ cd $(d)
46
71
  ```
72
+ Outputs the path to the Desktop folder (~\/Desktop). Use with `cd $(d)` to navigate there.
47
73
 
48
- ## Categories
74
+ #### `p`
75
+ ```bash
76
+ cd $(p)
77
+ ```
78
+ Outputs the path to the projects folder (~\/projects). Use with `cd $(p)` to navigate there.
49
79
 
50
- ### Git
51
- `clone`, `git-clone`, `git-pup`, `git-push`, `git-backup`, `vpush`, `fetch-github-repos`
80
+ #### `mkd`
81
+ ```bash
82
+ mkd new-folder/nested/path
83
+ ```
84
+ Creates a directory (including parent directories) and outputs the path. Equivalent to `mkdir -p`.
85
+
86
+ ---
52
87
 
53
88
  ### Docker
54
- `dp`, `docker-clean`
55
89
 
56
- ### Node/npm
57
- `npmi`, `clean-dev`, `ncu-update-all`, `get-dependencies`, `install-dependencies-from`
90
+ #### `dp`
91
+ ```bash
92
+ dp
93
+ ```
94
+ Lists running Docker containers in a formatted table showing container ID, name, and port mappings. Equivalent to `docker ps --format`.
95
+
96
+ #### `docker-clean`
97
+ ```bash
98
+ docker-clean
99
+ docker-clean --force
100
+ ```
101
+ Removes ALL Docker containers, images, and volumes after prompting for confirmation. Use `--force` to skip the confirmation prompt.
102
+
103
+ ---
58
104
 
59
- ### File Management
60
- `mkd`, `ll`, `delete-files`, `refresh-files`, `get-folder`, `org-by-date`, `rm-safe`
105
+ ### File Listing & Information
61
106
 
62
- ### macOS
63
- `afk`, `o`, `u`, `brewd`, `brewi`, `brewr`, `brews`, `brewu`, `empty-trash`
107
+ #### `ll`
108
+ ```bash
109
+ ll
110
+ ll /path/to/directory
111
+ ```
112
+ Displays a detailed directory listing showing permissions, size, modification date, and names. Equivalent to `ls -l`.
64
113
 
65
- ### Search
66
- `h`, `s`
114
+ #### `count`
115
+ ```bash
116
+ count
117
+ count /path/to/directory
118
+ ```
119
+ Displays the count of files and folders in the current or specified directory.
120
+
121
+ #### `count-files`
122
+ ```bash
123
+ count-files
124
+ count-files /path/to/directory
125
+ ```
126
+ Counts and displays the number of files (not directories) in the current or specified directory.
127
+
128
+ #### `count-folders`
129
+ ```bash
130
+ count-folders
131
+ count-folders /path/to/directory
132
+ ```
133
+ Counts and displays the number of subdirectories in the current or specified directory.
134
+
135
+ #### `packages`
136
+ ```bash
137
+ packages
138
+ packages /path/to/search
139
+ ```
140
+ Finds all package.json files recursively and lists them sorted by modification date (oldest first). Excludes node_modules directories.
141
+
142
+ ---
143
+
144
+ ### File Operations
145
+
146
+ #### `delete-files`
147
+ ```bash
148
+ delete-files
149
+ delete-files "*.log"
150
+ delete-files "*.tmp"
151
+ ```
152
+ Recursively deletes files matching a pattern. Defaults to `*.DS_Store` if no pattern specified. Shows files being deleted and total space freed.
153
+
154
+ #### `org-by-date`
155
+ ```bash
156
+ org-by-date
157
+ org-by-date /path/to/directory
158
+ ```
159
+ Organizes files with dates in their names (YYYY-MM-DD format) into a nested folder structure (YYYY/MM/DD/).
160
+
161
+ #### `rename-files-with-date`
162
+ ```bash
163
+ rename-files-with-date
164
+ rename-files-with-date /path/to/directory
165
+ ```
166
+ Renames files that have embedded dates and times in their names to a standardized format (YYYY-MM-DD HH.MM.SS.ext).
167
+
168
+ #### `remove-smaller-files`
169
+ ```bash
170
+ remove-smaller-files /comparison/directory
171
+ ```
172
+ Compares files between the current directory and a comparison directory. For files that exist in both, removes the smaller version.
173
+
174
+ #### `rm-safe`
175
+ ```bash
176
+ rm-safe file.txt
177
+ rm-safe -rf directory/
178
+ ```
179
+ A safer wrapper around rm that blocks dangerous operations like deleting root directories or system folders.
180
+
181
+ #### `clean-dev`
182
+ ```bash
183
+ clean-dev
184
+ clean-dev /path/to/search
185
+ ```
186
+ Recursively finds and removes `node_modules` and `bower_components` directories to free disk space.
187
+
188
+ ---
189
+
190
+ ### Git
191
+
192
+ #### `clone`
193
+ ```bash
194
+ clone https://github.com/user/repo.git
195
+ clone git@github.com:user/repo.git my-folder
196
+ ```
197
+ Clones a git repository and automatically installs dependencies if package.json is found. Detects yarn, pnpm, or npm based on lock files.
198
+
199
+ #### `git-clone`
200
+ ```bash
201
+ git-clone /source/repo [/destination]
202
+ ```
203
+ Copies files from a source directory (typically a repo) to destination, excluding .git, README.md, LICENSE, and node_modules. Useful for using repos as templates.
204
+
205
+ #### `git-push`
206
+ ```bash
207
+ git-push "commit message"
208
+ ```
209
+ Stages all changes, commits with the provided message, and pushes to the current branch. A one-liner for the common add/commit/push workflow.
210
+
211
+ #### `git-pup`
212
+ ```bash
213
+ git-pup
214
+ ```
215
+ Pulls the latest changes and updates all git submodules. Equivalent to `git pull && git submodule init && git submodule update`.
216
+
217
+ #### `vpush`
218
+ ```bash
219
+ vpush
220
+ vpush --sign
221
+ ```
222
+ Commits with the version from package.json as the commit message and pushes. Use `--sign` for GPG-signed commits.
223
+
224
+ #### `fetch-github-repos`
225
+ ```bash
226
+ fetch-github-repos organization-name
227
+ fetch-github-repos organization-name /target/directory
228
+ ```
229
+ Clones all repositories from a GitHub organization into the specified directory. Skips repos that already exist.
230
+
231
+ #### `set-git-public`
232
+ ```bash
233
+ set-git-public
234
+ ```
235
+ Sets the git user.email and user.name for the current repository to your "public" identity from ~/.devutils config.
236
+
237
+ ---
238
+
239
+ ### Media & Downloads
240
+
241
+ #### `get-video`
242
+ ```bash
243
+ get-video https://youtube.com/watch?v=VIDEO_ID
244
+ ```
245
+ Downloads a video from YouTube or other supported sites using yt-dlp in MP4 format.
246
+
247
+ #### `get-tunes`
248
+ ```bash
249
+ get-tunes https://youtube.com/watch?v=VIDEO_ID
250
+ get-tunes https://youtube.com/watch?v=VIDEO_ID audio-only
251
+ get-tunes https://youtube.com/watch?v=VIDEO_ID video-only
252
+ ```
253
+ Downloads audio and/or video from a URL using yt-dlp. Supports audio-only (MP3) or video-only (MP4) modes.
254
+
255
+ #### `get-channel`
256
+ ```bash
257
+ get-channel channel-name
258
+ get-channel @HandleName
259
+ ```
260
+ Downloads all videos from a YouTube channel using yt-dlp with date-prefixed filenames.
261
+
262
+ #### `get-course`
263
+ ```bash
264
+ get-course course-name username password
265
+ ```
266
+ Downloads a Pluralsight course using yt-dlp with authentication and rate limiting.
267
+
268
+ #### `resize-image`
269
+ ```bash
270
+ resize-image photo.jpg
271
+ resize-image photo.jpg 30%
272
+ resize-image photo.jpg 800x600
273
+ ```
274
+ Resizes an image using ImageMagick with high-quality settings. Outputs to a file prefixed with underscore.
275
+
276
+ #### `datauri`
277
+ ```bash
278
+ datauri image.png
279
+ datauri document.pdf
280
+ ```
281
+ Converts a file to a base64 data URI string suitable for embedding in HTML/CSS.
282
+
283
+ ---
67
284
 
68
285
  ### Network
69
- `ips`, `ccurl`, `local-ip`, `ports`
70
286
 
71
- ### Media
72
- `get-tunes`, `get-video`, `get-channel`, `get-course`, `datauri`, `resize-image`
287
+ #### `local-ip`
288
+ ```bash
289
+ local-ip
290
+ local-ip --all
291
+ ```
292
+ Displays the primary local/private IP address. Use `--all` to show all network interfaces.
293
+
294
+ #### `ips`
295
+ ```bash
296
+ ips
297
+ ips 192.168.0.0 24
298
+ ips --ip-only
299
+ ```
300
+ Scans the local network for active IP addresses using nmap. Configurable network range and output format.
301
+
302
+ #### `ports`
303
+ ```bash
304
+ ports
305
+ ports 3000
306
+ ports --listening
307
+ ports --tcp
308
+ ```
309
+ Lists open network ports and the processes using them. Can filter by port number or protocol.
310
+
311
+ #### `ccurl`
312
+ ```bash
313
+ ccurl https://api.example.com/endpoint
314
+ ```
315
+ Fetches a URL with Accept: application/json header and pretty-prints the JSON response. No curl or jq required.
316
+
317
+ #### `clear-dns-cache`
318
+ ```bash
319
+ clear-dns-cache
320
+ ```
321
+ Flushes the DNS cache on the current system. Works across macOS, Linux, and Windows.
322
+
323
+ ---
324
+
325
+ ### Node.js & npm
326
+
327
+ #### `npmi`
328
+ ```bash
329
+ npmi
330
+ ```
331
+ Removes node_modules and reinstalls dependencies. Detects yarn, pnpm, or npm from lock files.
332
+
333
+ #### `ncu-update-all`
334
+ ```bash
335
+ ncu-update-all
336
+ ncu-update-all /path/to/search
337
+ ```
338
+ Finds all package.json files recursively and updates their dependencies to latest versions using npm-check-updates.
339
+
340
+ #### `get-dependencies`
341
+ ```bash
342
+ get-dependencies package.json
343
+ get-dependencies package.json dev
344
+ get-dependencies package.json peer
345
+ ```
346
+ Lists dependency names from a package.json file. Supports dependencies, devDependencies, peerDependencies, etc.
347
+
348
+ #### `install-dependencies-from`
349
+ ```bash
350
+ install-dependencies-from /path/to/package.json
351
+ install-dependencies-from /path/to/package.json dev
352
+ ```
353
+ Installs dependencies from another package.json into the current project at their latest versions.
354
+
355
+ #### `y`
356
+ ```bash
357
+ y
358
+ y add package-name
359
+ y install
360
+ ```
361
+ Shortcut for the yarn package manager. Passes all arguments through to yarn.
362
+
363
+ ---
364
+
365
+ ### Package Managers (Homebrew)
366
+
367
+ #### `brewi`
368
+ ```bash
369
+ brewi package-name
370
+ brewi wget curl jq
371
+ ```
372
+ Cross-platform package install. Uses brew on macOS, apt on Ubuntu, dnf/yum on Amazon Linux, choco on Windows.
373
+
374
+ #### `brewr`
375
+ ```bash
376
+ brewr package-name
377
+ ```
378
+ Cross-platform package uninstall. Uses the appropriate package manager for each platform.
379
+
380
+ #### `brews`
381
+ ```bash
382
+ brews search-term
383
+ ```
384
+ Cross-platform package search. Searches the appropriate package manager for each platform.
385
+
386
+ #### `brewu`
387
+ ```bash
388
+ brewu
389
+ ```
390
+ Updates Homebrew and upgrades all installed packages. On macOS: `brew update && brew upgrade && brew cleanup`.
391
+
392
+ #### `brewd`
393
+ ```bash
394
+ brewd
395
+ ```
396
+ Runs Homebrew diagnostics (`brew doctor`). On non-Homebrew platforms, provides equivalent diagnostic commands.
397
+
398
+ ---
399
+
400
+ ### Search
401
+
402
+ #### `s`
403
+ ```bash
404
+ s "search pattern"
405
+ s function_name
406
+ s "async.*await"
407
+ ```
408
+ Recursively searches for text in the current directory using grep. Excludes .git, node_modules, and other common directories. Case-insensitive.
409
+
410
+ #### `h`
411
+ ```bash
412
+ h "search term"
413
+ h git
414
+ ```
415
+ Searches your shell history for commands matching the pattern. Searches ~/.bash_history or ~/.zsh_history.
416
+
417
+ ---
418
+
419
+ ### Server & DevOps
420
+
421
+ #### `certbot-init`
422
+ ```bash
423
+ certbot-init -d example.com -e admin@example.com
424
+ certbot-init -d example.com -d www.example.com -e admin@example.com
425
+ ```
426
+ Installs SSL certificates using certbot for nginx. Handles certbot installation and nginx integration.
427
+
428
+ #### `certbot-crontab-init`
429
+ ```bash
430
+ certbot-crontab-init
431
+ ```
432
+ Sets up a cron job for automatic SSL certificate renewal (runs daily at noon).
433
+
434
+ #### `nginx-init`
435
+ ```bash
436
+ nginx-init -d example.com -h http://localhost:3000 -f myapp.conf
437
+ nginx-init -d example.com -h http://localhost:3000 -f myapp.conf --api --link
438
+ ```
439
+ Creates nginx reverse proxy configuration files from templates. Supports API mode with CORS headers.
440
+
441
+ #### `tpo`
442
+ ```bash
443
+ tpo
444
+ tpo -var="key=value"
445
+ ```
446
+ Runs `terraform plan -out="tfplan"` to create a Terraform execution plan.
447
+
448
+ #### `tpa`
449
+ ```bash
450
+ tpa
451
+ tpa -auto-approve
452
+ ```
453
+ Runs `terraform apply "tfplan"` to apply a previously created Terraform plan.
454
+
455
+ ---
456
+
457
+ ### System
458
+
459
+ #### `afk`
460
+ ```bash
461
+ afk
462
+ ```
463
+ Locks the screen or puts the system to sleep. Uses the appropriate method for each platform (osascript on macOS, loginctl on Linux, rundll32 on Windows).
464
+
465
+ #### `u`
466
+ ```bash
467
+ u
468
+ ```
469
+ Updates the operating system and all installed packages. Runs softwareupdate + brew on macOS, apt update/upgrade on Ubuntu, etc.
470
+
471
+ #### `c`
472
+ ```bash
473
+ c
474
+ ```
475
+ Clears the terminal screen. Works on all platforms using ANSI escape sequences.
476
+
477
+ #### `q`
478
+ ```bash
479
+ q
480
+ ```
481
+ Displays instructions for creating an `exit` alias since Node.js scripts cannot exit the parent shell.
482
+
483
+ #### `e`
484
+ ```bash
485
+ e filename.txt
486
+ ```
487
+ Opens a file in vim. Shortcut for `vim --`.
488
+
489
+ #### `m`
490
+ ```bash
491
+ m command-name
492
+ ```
493
+ Displays the manual page for a command. Shortcut for `man`.
494
+
495
+ #### `o`
496
+ ```bash
497
+ o
498
+ o file.pdf
499
+ o /path/to/folder
500
+ ```
501
+ Opens a file or folder with the default application. Uses `open` on macOS, `xdg-open` on Linux, `start` on Windows.
502
+
503
+ #### `path`
504
+ ```bash
505
+ path
506
+ ```
507
+ Displays each directory in the PATH environment variable on a separate line.
508
+
509
+ #### `iso`
510
+ ```bash
511
+ iso
512
+ iso UTC
513
+ iso America/New_York
514
+ ```
515
+ Outputs the current date/time in ISO 8601 format with timezone. Defaults to America/Los_Angeles.
516
+
517
+ #### `empty-trash`
518
+ ```bash
519
+ empty-trash
520
+ empty-trash --verbose
521
+ ```
522
+ Empties the trash/recycle bin and clears system logs to free disk space.
523
+
524
+ #### `ch`
525
+ ```bash
526
+ ch
527
+ ```
528
+ Clears shell history files (~/.bash_history, ~/.zsh_history, etc.).
529
+
530
+ ---
531
+
532
+ ### System Preferences
533
+
534
+ #### `show-hidden-files`
535
+ ```bash
536
+ show-hidden-files
537
+ ```
538
+ Configures the file manager to show hidden files (dotfiles).
539
+
540
+ #### `hide-hidden-files`
541
+ ```bash
542
+ hide-hidden-files
543
+ ```
544
+ Configures the file manager to hide hidden files (dotfiles).
545
+
546
+ #### `show-desktop-icons`
547
+ ```bash
548
+ show-desktop-icons
549
+ ```
550
+ Enables desktop icons in the file manager/desktop environment.
551
+
552
+ #### `hide-desktop-icons`
553
+ ```bash
554
+ hide-desktop-icons
555
+ ```
556
+ Hides desktop icons for a cleaner desktop appearance.
557
+
558
+ ---
559
+
560
+ ### Text Processing
561
+
562
+ #### `map`
563
+ ```bash
564
+ echo -e "file1.txt\nfile2.txt" | map cat
565
+ ls *.js | map wc -l
566
+ ```
567
+ Executes a command for each line of input (like xargs -n1). Reads from stdin and runs the specified command with each line as an argument.
568
+
569
+ #### `evm`
570
+ ```bash
571
+ evm file.txt
572
+ evm file1.txt file2.txt 3
573
+ ```
574
+ Executes a vim macro (from register q) on one or more files. Optional count parameter runs the macro multiple times.
575
+
576
+ ---
577
+
578
+ ### Utilities
579
+
580
+ #### `killni`
581
+ ```bash
582
+ killni
583
+ ```
584
+ Kills all Node.js processes running with debug flags (--inspect, --inspect-brk, --debug, --debug-brk).
585
+
586
+ #### `claude-danger`
587
+ ```bash
588
+ claude-danger
589
+ claude-danger "prompt text"
590
+ ```
591
+ Launches Claude CLI with the `--dangerously-skip-permissions` flag for automated workflows.
592
+
593
+ ---
73
594
 
74
595
  ## Registration
75
596
 
@@ -89,7 +610,8 @@ Scripts are registered as global commands in `package.json`:
89
610
 
90
611
  - **Commands** (`../commands/`) — Multi-word CLI operations (`dev configure`, etc.)
91
612
  - **Utils** (`../utils/`) — Internal shared utilities
613
+ - **STATUS.md** — Migration status for all scripts
92
614
 
93
615
  ## Documentation
94
616
 
95
- See [ai-docs/LOCAL_EXAMPLE_ENVIRONMENT.md](../../ai-docs/LOCAL_EXAMPLE_ENVIRONMENT.md) for the complete script reference.
617
+ See [ai-docs/LOCAL_EXAMPLE_ENVIRONMENT.md](../../ai-docs/LOCAL_EXAMPLE_ENVIRONMENT.md) for additional reference.