@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
@@ -0,0 +1,838 @@
1
+ # Installing Chromium
2
+
3
+ ## Overview
4
+
5
+ Chromium is the free and open-source web browser project that forms the foundation for Google Chrome and many other browsers including Microsoft Edge, Opera, and Brave. Unlike Chrome, Chromium does not include proprietary Google components such as automatic updates, crash reporting, or licensed media codecs. Chromium is an excellent choice for developers who need a lightweight, open-source browser for testing, automation, or headless browser operations. It supports the same web standards as Chrome while offering greater transparency into its codebase.
6
+
7
+ ## Prerequisites
8
+
9
+ Before installing Chromium on any platform, ensure:
10
+
11
+ 1. **Internet connectivity** - Required to download the browser package
12
+ 2. **Administrative privileges** - Required on most platforms for system-wide installation
13
+ 3. **Sufficient disk space** - Chromium requires approximately 300-500 MB of disk space
14
+ 4. **64-bit operating system** - Most current Chromium builds require a 64-bit system
15
+
16
+ **Important**: Chromium does not auto-update like Google Chrome. You must manually update or use your package manager to keep it current.
17
+
18
+ ## Dependencies
19
+
20
+ ### macOS (Homebrew)
21
+ - **Required:**
22
+ - Homebrew package manager - Install via `/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"`
23
+ - **Optional:** None
24
+ - **Auto-installed:** None (Chromium cask is self-contained)
25
+
26
+ ### Ubuntu (APT/Snap)
27
+ - **Required:**
28
+ - snapd service - Auto-installed by the installer script if missing via `sudo apt-get install -y snapd`
29
+ - **Optional:** None
30
+ - **Auto-installed:**
31
+ - snapd dependencies (systemd, squashfs-tools, etc.) - Automatically installed by APT when installing snapd
32
+
33
+ ### Raspberry Pi OS (APT)
34
+ - **Required:** None (APT is pre-installed on Raspberry Pi OS)
35
+ - **Optional:**
36
+ - chromium-codecs-ffmpeg-extra - Install via `sudo apt-get install -y chromium-codecs-ffmpeg-extra` (provides additional codec support for video playback)
37
+ - **Auto-installed:**
38
+ - All Chromium runtime dependencies (graphics libraries, font rendering, etc.) - Automatically installed by APT
39
+
40
+ ### Amazon Linux (DNF/YUM)
41
+ - **Required:**
42
+ - **For Amazon Linux 2023 (DNF method):**
43
+ - libXcomposite - Install via `sudo dnf install -y libXcomposite`
44
+ - libXdamage - Install via `sudo dnf install -y libXdamage`
45
+ - libXrandr - Install via `sudo dnf install -y libXrandr`
46
+ - libgbm - Install via `sudo dnf install -y libgbm`
47
+ - libxkbcommon - Install via `sudo dnf install -y libxkbcommon`
48
+ - pango - Install via `sudo dnf install -y pango`
49
+ - alsa-lib - Install via `sudo dnf install -y alsa-lib`
50
+ - atk - Install via `sudo dnf install -y atk`
51
+ - at-spi2-atk - Install via `sudo dnf install -y at-spi2-atk`
52
+ - cups-libs - Install via `sudo dnf install -y cups-libs`
53
+ - libdrm - Install via `sudo dnf install -y libdrm`
54
+ - **For Amazon Linux 2 (YUM method):**
55
+ - EPEL repository - Enable via `sudo amazon-linux-extras install -y epel`
56
+ - **Optional:**
57
+ - xorg-x11-server-Xvfb - Install via `sudo dnf install -y xorg-x11-server-Xvfb` (required for headless operation on EC2 instances without GUI)
58
+ - **Auto-installed:**
59
+ - Additional Chrome/Chromium dependencies - Automatically resolved by DNF/YUM during package installation
60
+
61
+ ### Windows (Chocolatey)
62
+ - **Required:**
63
+ - Chocolatey package manager - Install via PowerShell (Administrator): `Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))`
64
+ - **Optional:** None
65
+ - **Auto-installed:**
66
+ - All runtime dependencies (Visual C++ redistributables, .NET Framework if needed) - Automatically handled by Chocolatey
67
+
68
+ ### Git Bash (Manual/Portable)
69
+ - **Required:**
70
+ - **For portable installation method:**
71
+ - curl - Usually pre-installed with Git for Windows. If missing, install Git for Windows from https://git-scm.com/download/win
72
+ - unzip - Usually pre-installed with Git for Windows. If missing, install via `pacman -S unzip` (if using Git Bash with pacman) or download from http://gnuwin32.sourceforge.net/packages/unzip.htm
73
+ - **For Chocolatey installation method:**
74
+ - Chocolatey package manager - Install as described in Windows section above
75
+ - **Optional:** None
76
+ - **Auto-installed:** None (portable installation is self-contained)
77
+
78
+ ## Platform-Specific Installation
79
+
80
+ ### macOS (Homebrew)
81
+
82
+ #### Prerequisites
83
+
84
+ - macOS 12 (Monterey) or later
85
+ - Homebrew package manager installed
86
+ - Terminal access
87
+
88
+ If Homebrew is not installed, install it first:
89
+
90
+ ```bash
91
+ /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
92
+ ```
93
+
94
+ #### Installation Steps
95
+
96
+ Run the following command to install Chromium:
97
+
98
+ ```bash
99
+ brew install --cask --quiet chromium --no-quarantine
100
+ ```
101
+
102
+ The `--quiet` flag suppresses non-essential output, making the command suitable for automation scripts. The `--no-quarantine` flag prevents macOS Gatekeeper from flagging the unsigned Chromium app, which would otherwise require manual intervention to open.
103
+
104
+ **Note**: The Homebrew Chromium cask is scheduled for deprecation on September 1, 2026. Plan to migrate to an alternative installation method before that date.
105
+
106
+ #### Verification
107
+
108
+ Confirm the installation succeeded:
109
+
110
+ ```bash
111
+ ls /Applications/Chromium.app && echo "Chromium installed successfully"
112
+ ```
113
+
114
+ Launch Chromium from the command line:
115
+
116
+ ```bash
117
+ open -a Chromium
118
+ ```
119
+
120
+ Or verify the version by checking the application bundle:
121
+
122
+ ```bash
123
+ /Applications/Chromium.app/Contents/MacOS/Chromium --version
124
+ ```
125
+
126
+ Expected output (version numbers may vary):
127
+
128
+ ```
129
+ Chromium 143.0.7499.146
130
+ ```
131
+
132
+ #### Troubleshooting
133
+
134
+ **Problem**: "Chromium.app is damaged and can't be opened"
135
+
136
+ **Solution**: This occurs when the quarantine attribute is set. Remove it:
137
+
138
+ ```bash
139
+ xattr -cr /Applications/Chromium.app
140
+ ```
141
+
142
+ **Problem**: `brew: command not found`
143
+
144
+ **Solution**: Homebrew is not in your PATH. Add it:
145
+
146
+ ```bash
147
+ eval "$(/opt/homebrew/bin/brew shellenv)"
148
+ ```
149
+
150
+ For permanent fix, add the above line to your `~/.zshrc` or `~/.bash_profile`.
151
+
152
+ **Problem**: Chromium crashes on launch with GPU errors
153
+
154
+ **Solution**: Launch with GPU acceleration disabled:
155
+
156
+ ```bash
157
+ /Applications/Chromium.app/Contents/MacOS/Chromium --disable-gpu
158
+ ```
159
+
160
+ ---
161
+
162
+ ### Ubuntu/Debian (Snap)
163
+
164
+ #### Prerequisites
165
+
166
+ - Ubuntu 18.04 or later, or Debian 10 or later (64-bit)
167
+ - snapd service installed and running (pre-installed on Ubuntu 16.04+)
168
+ - sudo privileges
169
+
170
+ **Important**: Since Ubuntu 20.04, the `chromium-browser` APT package is a transitional package that installs the Snap version. Use Snap directly for consistent behavior across Ubuntu and Debian systems.
171
+
172
+ #### Installation Steps
173
+
174
+ Run the following command to install Chromium:
175
+
176
+ ```bash
177
+ sudo snap install chromium
178
+ ```
179
+
180
+ Snap does not require confirmation flags as it is non-interactive by default.
181
+
182
+ **Note**: After installation, you may need to log out and log back in, or restart your terminal, for the application to appear in your desktop environment's application menu.
183
+
184
+ #### Verification
185
+
186
+ Confirm the installation succeeded:
187
+
188
+ ```bash
189
+ chromium --version
190
+ ```
191
+
192
+ Expected output (version numbers may vary):
193
+
194
+ ```
195
+ Chromium 143.0.7499.146 snap
196
+ ```
197
+
198
+ Launch Chromium:
199
+
200
+ ```bash
201
+ chromium &
202
+ ```
203
+
204
+ #### Troubleshooting
205
+
206
+ **Problem**: `snap: command not found`
207
+
208
+ **Solution**: Install snapd first:
209
+
210
+ ```bash
211
+ sudo DEBIAN_FRONTEND=noninteractive apt-get update -y && sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd
212
+ ```
213
+
214
+ **Problem**: `chromium: command not found` after installation
215
+
216
+ **Solution**: The snap bin directory may not be in your PATH. Add it:
217
+
218
+ ```bash
219
+ export PATH=$PATH:/snap/bin
220
+ ```
221
+
222
+ For permanent fix, add the above line to your `~/.bashrc` or `~/.profile`.
223
+
224
+ **Problem**: Chromium fails to start with sandbox errors
225
+
226
+ **Solution**: Snap provides its own sandboxing. If you encounter issues, ensure your kernel supports user namespaces:
227
+
228
+ ```bash
229
+ sysctl kernel.unprivileged_userns_clone
230
+ ```
231
+
232
+ If it returns 0, enable it:
233
+
234
+ ```bash
235
+ sudo sysctl -w kernel.unprivileged_userns_clone=1
236
+ ```
237
+
238
+ **Problem**: Cannot access local files or external drives
239
+
240
+ **Solution**: Snap apps have limited filesystem access by default. Grant removable-media access:
241
+
242
+ ```bash
243
+ sudo snap connect chromium:removable-media
244
+ ```
245
+
246
+ ---
247
+
248
+ ### Raspberry Pi OS (APT)
249
+
250
+ #### Prerequisites
251
+
252
+ - Raspberry Pi OS (32-bit or 64-bit)
253
+ - Raspberry Pi 3 or later recommended
254
+ - sudo privileges
255
+
256
+ **Note**: Raspberry Pi OS includes Chromium in its official repositories with ARM-specific optimizations. Use APT for the best performance on Raspberry Pi hardware.
257
+
258
+ #### Installation Steps
259
+
260
+ Run the following commands to install Chromium:
261
+
262
+ ```bash
263
+ sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
264
+ sudo DEBIAN_FRONTEND=noninteractive apt-get install -y chromium-browser
265
+ ```
266
+
267
+ The `DEBIAN_FRONTEND=noninteractive` environment variable ensures the installation proceeds without prompts, making it suitable for automation scripts.
268
+
269
+ #### Verification
270
+
271
+ Confirm the installation succeeded:
272
+
273
+ ```bash
274
+ chromium-browser --version
275
+ ```
276
+
277
+ Expected output (version numbers may vary):
278
+
279
+ ```
280
+ Chromium 120.0.6099.216 Built on Raspberry Pi OS/Debian
281
+ ```
282
+
283
+ Launch Chromium:
284
+
285
+ ```bash
286
+ chromium-browser &
287
+ ```
288
+
289
+ #### Troubleshooting
290
+
291
+ **Problem**: Chromium is slow or crashes on Raspberry Pi
292
+
293
+ **Solution**: Limit memory usage and disable GPU acceleration for better stability:
294
+
295
+ ```bash
296
+ chromium-browser --disable-gpu --disable-software-rasterizer --memory-pressure-off
297
+ ```
298
+
299
+ **Problem**: Video playback issues
300
+
301
+ **Solution**: Hardware video decoding may not be available for all codecs. Install additional codec support:
302
+
303
+ ```bash
304
+ sudo DEBIAN_FRONTEND=noninteractive apt-get install -y chromium-codecs-ffmpeg-extra
305
+ ```
306
+
307
+ **Problem**: Out of memory errors on Raspberry Pi with 1GB RAM
308
+
309
+ **Solution**: Create a swap file to provide additional virtual memory:
310
+
311
+ ```bash
312
+ sudo fallocate -l 1G /swapfile
313
+ sudo chmod 600 /swapfile
314
+ sudo mkswap /swapfile
315
+ sudo swapon /swapfile
316
+ ```
317
+
318
+ **Problem**: `chromium-browser: command not found`
319
+
320
+ **Solution**: On newer Raspberry Pi OS versions, the command may be `chromium` instead:
321
+
322
+ ```bash
323
+ chromium --version
324
+ ```
325
+
326
+ ---
327
+
328
+ ### Amazon Linux (DNF/YUM)
329
+
330
+ #### Prerequisites
331
+
332
+ - Amazon Linux 2023 (AL2023) or Amazon Linux 2 (AL2)
333
+ - sudo privileges
334
+ - x86_64 architecture (ARM/Graviton requires alternative approach)
335
+
336
+ **Important**: Chromium is not available in the default Amazon Linux repositories. On Amazon Linux 2023, install Google Chrome (which is based on Chromium) using the direct RPM download. On Amazon Linux 2, use the EPEL repository.
337
+
338
+ #### Installation Steps
339
+
340
+ **For Amazon Linux 2023:**
341
+
342
+ ```bash
343
+ sudo dnf install -y https://dl.google.com/linux/direct/google-chrome-stable_current_x86_64.rpm
344
+ ```
345
+
346
+ If you specifically need the `chromium` command name for compatibility with scripts or tools, create a symbolic link:
347
+
348
+ ```bash
349
+ sudo ln -sf /usr/bin/google-chrome-stable /usr/bin/chromium
350
+ ```
351
+
352
+ **For Amazon Linux 2:**
353
+
354
+ First, enable the EPEL repository, then install Chromium:
355
+
356
+ ```bash
357
+ sudo amazon-linux-extras install -y epel
358
+ sudo yum install -y chromium
359
+ ```
360
+
361
+ **Note**: Amazon Linux 2 reached end of standard support on June 30, 2025. Chromium packages in EPEL for AL2 are no longer updated. Migrate to Amazon Linux 2023 for continued security updates.
362
+
363
+ #### Verification
364
+
365
+ Confirm the installation succeeded:
366
+
367
+ **For Amazon Linux 2023:**
368
+
369
+ ```bash
370
+ google-chrome-stable --version
371
+ ```
372
+
373
+ Expected output (version numbers may vary):
374
+
375
+ ```
376
+ Google Chrome 131.0.6778.108
377
+ ```
378
+
379
+ **For Amazon Linux 2:**
380
+
381
+ ```bash
382
+ chromium-browser --version
383
+ ```
384
+
385
+ #### Troubleshooting
386
+
387
+ **Problem**: Missing dependencies when installing Chrome RPM
388
+
389
+ **Solution**: Install required dependencies first:
390
+
391
+ ```bash
392
+ sudo dnf install -y libXcomposite libXdamage libXrandr libgbm libxkbcommon pango alsa-lib atk at-spi2-atk cups-libs libdrm
393
+ ```
394
+
395
+ **Problem**: Chrome/Chromium crashes with "no usable sandbox" error
396
+
397
+ **Solution**: The sandbox requires specific kernel capabilities. Run with sandbox disabled (not recommended for production):
398
+
399
+ ```bash
400
+ google-chrome-stable --no-sandbox
401
+ ```
402
+
403
+ Or configure the sandbox properly:
404
+
405
+ ```bash
406
+ sudo sysctl -w kernel.unprivileged_userns_clone=1
407
+ ```
408
+
409
+ **Problem**: Headless mode fails on EC2 instances
410
+
411
+ **Solution**: Install virtual framebuffer for headless operation:
412
+
413
+ ```bash
414
+ sudo dnf install -y xorg-x11-server-Xvfb
415
+ xvfb-run google-chrome-stable --headless --dump-dom https://example.com
416
+ ```
417
+
418
+ **Problem**: `amazon-linux-extras: command not found` (on AL2023)
419
+
420
+ **Solution**: Amazon Linux 2023 does not support amazon-linux-extras. Use the dnf direct RPM installation method shown above.
421
+
422
+ ---
423
+
424
+ ### Windows (Chocolatey)
425
+
426
+ #### Prerequisites
427
+
428
+ - Windows 10 or Windows 11 (64-bit)
429
+ - Chocolatey package manager installed
430
+ - Administrator PowerShell or Command Prompt
431
+
432
+ If Chocolatey is not installed, install it first by running this command in an Administrator PowerShell:
433
+
434
+ ```powershell
435
+ Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))
436
+ ```
437
+
438
+ #### Installation Steps
439
+
440
+ Run the following command in an Administrator PowerShell or Command Prompt:
441
+
442
+ ```powershell
443
+ choco install chromium -y
444
+ ```
445
+
446
+ The `-y` flag automatically confirms all prompts, enabling fully non-interactive installation.
447
+
448
+ **Note**: The Chocolatey `chromium` package installs development snapshot builds, which may be less stable than official releases. For a stable Chromium-based browser, consider using the `ungoogled-chromium` package instead:
449
+
450
+ ```powershell
451
+ choco install ungoogled-chromium -y
452
+ ```
453
+
454
+ #### Verification
455
+
456
+ Open a new Command Prompt or PowerShell window (required for PATH to update), then run:
457
+
458
+ ```powershell
459
+ chromium --version
460
+ ```
461
+
462
+ Expected output (version numbers may vary):
463
+
464
+ ```
465
+ Chromium 145.0.7575.0
466
+ ```
467
+
468
+ #### Troubleshooting
469
+
470
+ **Problem**: `chromium: The term 'chromium' is not recognized`
471
+
472
+ **Solution**: Open a new terminal window. The PATH is updated during installation but existing windows do not reflect this. Alternatively, refresh the environment:
473
+
474
+ ```powershell
475
+ refreshenv
476
+ ```
477
+
478
+ **Problem**: Installation fails with access denied
479
+
480
+ **Solution**: Ensure you are running PowerShell or Command Prompt as Administrator. Right-click and select "Run as administrator".
481
+
482
+ **Problem**: Windows Defender SmartScreen blocks Chromium
483
+
484
+ **Solution**: Chromium is not signed by Google, so SmartScreen may flag it. Click "More info" then "Run anyway" to proceed. For automated deployment, you may need to add an exclusion.
485
+
486
+ **Problem**: Chocolatey command not found
487
+
488
+ **Solution**: Chocolatey may not be in PATH. Close all terminal windows, open a new Administrator PowerShell, and try again.
489
+
490
+ ---
491
+
492
+ ### WSL (Ubuntu)
493
+
494
+ #### Prerequisites
495
+
496
+ - Windows Subsystem for Linux with Ubuntu installed
497
+ - WSL 2 recommended for best performance
498
+ - sudo privileges within WSL
499
+
500
+ **Note**: Running Chromium with a GUI in WSL requires WSLg (available in Windows 11 and Windows 10 21H2+) or an X server on Windows.
501
+
502
+ #### Installation Steps
503
+
504
+ Install Chromium using Snap:
505
+
506
+ ```bash
507
+ sudo snap install chromium
508
+ ```
509
+
510
+ If Snap is not available or you encounter issues with Snap in WSL, use the APT transitional package:
511
+
512
+ ```bash
513
+ sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
514
+ sudo DEBIAN_FRONTEND=noninteractive apt-get install -y chromium-browser
515
+ ```
516
+
517
+ #### Verification
518
+
519
+ Confirm the installation succeeded:
520
+
521
+ ```bash
522
+ chromium --version
523
+ ```
524
+
525
+ Or:
526
+
527
+ ```bash
528
+ chromium-browser --version
529
+ ```
530
+
531
+ Expected output (version numbers may vary):
532
+
533
+ ```
534
+ Chromium 143.0.7499.146
535
+ ```
536
+
537
+ #### Troubleshooting
538
+
539
+ **Problem**: `cannot open display` error when launching Chromium
540
+
541
+ **Solution**: WSLg should handle display automatically in Windows 11. If using Windows 10 or an older WSL version, install an X server on Windows (such as VcXsrv) and set the DISPLAY variable:
542
+
543
+ ```bash
544
+ export DISPLAY=$(cat /etc/resolv.conf | grep nameserver | awk '{print $2}'):0
545
+ ```
546
+
547
+ **Problem**: Chromium crashes with sandbox errors in WSL
548
+
549
+ **Solution**: WSL has limitations with user namespaces. Run Chromium with sandbox disabled:
550
+
551
+ ```bash
552
+ chromium --no-sandbox
553
+ ```
554
+
555
+ **Note**: Disabling the sandbox reduces security. Use only for development and testing.
556
+
557
+ **Problem**: Snap commands fail with systemd errors
558
+
559
+ **Solution**: Enable systemd in WSL by adding this to `/etc/wsl.conf`:
560
+
561
+ ```ini
562
+ [boot]
563
+ systemd=true
564
+ ```
565
+
566
+ Then restart WSL from PowerShell:
567
+
568
+ ```powershell
569
+ wsl --shutdown
570
+ ```
571
+
572
+ **Problem**: Extremely slow performance or high CPU usage
573
+
574
+ **Solution**: Running a GUI browser in WSL has overhead. For headless operations, use:
575
+
576
+ ```bash
577
+ chromium --headless --disable-gpu --dump-dom https://example.com
578
+ ```
579
+
580
+ ---
581
+
582
+ ### Git Bash (Windows Portable Installation)
583
+
584
+ #### Prerequisites
585
+
586
+ - Windows 10 or Windows 11 (64-bit)
587
+ - Git Bash installed (comes with Git for Windows)
588
+ - Approximately 500 MB of disk space for the portable installation
589
+
590
+ **Note**: Git Bash runs in a Windows environment, so you can use Chromium installed via Chocolatey or winget. This section covers the portable installation method for environments where package managers are not available.
591
+
592
+ #### Installation Steps
593
+
594
+ Download and extract the portable Chromium package using curl and PowerShell (called from Git Bash):
595
+
596
+ ```bash
597
+ # Create installation directory
598
+ mkdir -p "$HOME/Applications/Chromium"
599
+
600
+ # Download the portable launcher (chrlauncher) which auto-downloads Chromium
601
+ curl -L -o "$HOME/Applications/Chromium/chrlauncher.zip" \
602
+ "https://github.com/niclaslson/niclaslson.github.io/raw/refs/heads/main/files/chrlauncher_v3.4.7_64.zip"
603
+
604
+ # Extract the launcher
605
+ unzip -o -q "$HOME/Applications/Chromium/chrlauncher.zip" -d "$HOME/Applications/Chromium"
606
+
607
+ # Clean up
608
+ rm "$HOME/Applications/Chromium/chrlauncher.zip"
609
+
610
+ # Run the launcher to download Chromium (first run downloads the browser)
611
+ "$HOME/Applications/Chromium/chrlauncher.exe"
612
+ ```
613
+
614
+ Alternatively, if Chocolatey is available on your Windows system, install from Git Bash:
615
+
616
+ ```bash
617
+ /c/ProgramData/chocolatey/bin/choco.exe install chromium -y
618
+ ```
619
+
620
+ Add the Chromium portable installation to your PATH by adding this to `~/.bashrc`:
621
+
622
+ ```bash
623
+ export PATH="$HOME/Applications/Chromium:$PATH"
624
+ ```
625
+
626
+ #### Verification
627
+
628
+ Confirm Chromium is accessible from Git Bash:
629
+
630
+ ```bash
631
+ "$HOME/Applications/Chromium/chromium.exe" --version
632
+ ```
633
+
634
+ Or if installed via Chocolatey:
635
+
636
+ ```bash
637
+ chromium --version
638
+ ```
639
+
640
+ Expected output (version numbers may vary):
641
+
642
+ ```
643
+ Chromium 143.0.7499.146
644
+ ```
645
+
646
+ #### Troubleshooting
647
+
648
+ **Problem**: `chromium: command not found` in Git Bash
649
+
650
+ **Solution**: The PATH may not include the Chromium directory. Add it explicitly to `~/.bashrc`:
651
+
652
+ ```bash
653
+ export PATH="$HOME/Applications/Chromium:$PATH"
654
+ ```
655
+
656
+ Then reload your shell:
657
+
658
+ ```bash
659
+ source ~/.bashrc
660
+ ```
661
+
662
+ **Problem**: chrlauncher cannot download Chromium (network error)
663
+
664
+ **Solution**: Your network may block the download. Download Chromium manually from https://download-chromium.appspot.com/ and extract to `$HOME/Applications/Chromium`.
665
+
666
+ **Problem**: Windows Security blocks the portable executable
667
+
668
+ **Solution**: Add an exclusion in Windows Security for the Chromium directory:
669
+
670
+ 1. Open Windows Security
671
+ 2. Go to Virus & threat protection > Manage settings
672
+ 3. Scroll to Exclusions and add the folder path
673
+
674
+ **Problem**: Chromium settings not persisted between sessions
675
+
676
+ **Solution**: The portable version stores profile data in its installation directory. Ensure you always launch from the same location.
677
+
678
+ ---
679
+
680
+ ## Post-Installation Configuration
681
+
682
+ After installing Chromium on any platform, you may want to configure it for development or testing purposes.
683
+
684
+ ### Set Chromium as Default Browser
685
+
686
+ **macOS:**
687
+
688
+ ```bash
689
+ open -a Chromium
690
+ # Then go to Chromium Settings > Default browser > Make default
691
+ ```
692
+
693
+ **Ubuntu/Debian:**
694
+
695
+ ```bash
696
+ sudo update-alternatives --set x-www-browser /snap/bin/chromium
697
+ ```
698
+
699
+ **Windows:**
700
+
701
+ ```powershell
702
+ # Open Settings > Apps > Default apps > Web browser
703
+ start ms-settings:defaultapps
704
+ ```
705
+
706
+ ### Enable Developer Tools by Default
707
+
708
+ Launch Chromium with DevTools open:
709
+
710
+ ```bash
711
+ chromium --auto-open-devtools-for-tabs
712
+ ```
713
+
714
+ ### Configure for Headless Testing
715
+
716
+ For automated testing and CI/CD pipelines, use these flags:
717
+
718
+ ```bash
719
+ chromium --headless --disable-gpu --no-sandbox --disable-dev-shm-usage
720
+ ```
721
+
722
+ **Flag explanations:**
723
+ - `--headless`: Run without a GUI
724
+ - `--disable-gpu`: Disable GPU hardware acceleration (required in many server environments)
725
+ - `--no-sandbox`: Disable the sandbox (use only in trusted environments)
726
+ - `--disable-dev-shm-usage`: Use /tmp instead of /dev/shm (helps in Docker containers)
727
+
728
+ ### Set Up User Data Directory
729
+
730
+ Store Chromium profiles in a custom location for isolated testing:
731
+
732
+ ```bash
733
+ chromium --user-data-dir=/path/to/custom/profile
734
+ ```
735
+
736
+ ---
737
+
738
+ ## Common Issues
739
+
740
+ ### Issue: Chromium Does Not Auto-Update
741
+
742
+ **Symptoms**: Chromium version remains old, security vulnerabilities not patched.
743
+
744
+ **Solution**: Unlike Google Chrome, Chromium does not auto-update. Update manually using your package manager:
745
+
746
+ ```bash
747
+ # macOS
748
+ brew upgrade --cask chromium
749
+
750
+ # Ubuntu/Debian (Snap)
751
+ sudo snap refresh chromium
752
+
753
+ # Raspberry Pi OS
754
+ sudo apt-get update && sudo apt-get upgrade -y chromium-browser
755
+
756
+ # Amazon Linux 2
757
+ sudo yum update -y chromium
758
+
759
+ # Windows (Chocolatey)
760
+ choco upgrade chromium -y
761
+ ```
762
+
763
+ ### Issue: Media Playback Not Working (No Audio/Video Codecs)
764
+
765
+ **Symptoms**: Websites report "This browser does not support video playback" or audio fails to play.
766
+
767
+ **Solution**: Chromium does not include proprietary codecs by default due to licensing restrictions. Options:
768
+
769
+ 1. **Ubuntu/Debian**: Install the extra codecs package:
770
+ ```bash
771
+ sudo DEBIAN_FRONTEND=noninteractive apt-get install -y chromium-codecs-ffmpeg-extra
772
+ ```
773
+
774
+ 2. **Use Google Chrome instead**: If you need full codec support, Google Chrome includes all licensed codecs.
775
+
776
+ 3. **Use Ungoogled Chromium with codecs**: Some third-party builds include additional codecs.
777
+
778
+ ### Issue: High Memory Usage
779
+
780
+ **Symptoms**: System becomes slow, Chromium uses excessive RAM.
781
+
782
+ **Solution**: Limit memory usage with command-line flags:
783
+
784
+ ```bash
785
+ chromium --memory-pressure-off --max_old_space_size=2048
786
+ ```
787
+
788
+ Or use the built-in task manager (Shift+Esc) to identify and close memory-heavy tabs.
789
+
790
+ ### Issue: Extensions Cannot Be Installed from Chrome Web Store
791
+
792
+ **Symptoms**: Extensions fail to install or are blocked.
793
+
794
+ **Solution**: Chromium supports Chrome Web Store extensions. If you encounter issues:
795
+
796
+ 1. Ensure you are using a recent Chromium version
797
+ 2. Try installing extensions manually by downloading the .crx file and dragging it to `chrome://extensions`
798
+
799
+ ### Issue: Certificate Errors on Internal Sites
800
+
801
+ **Symptoms**: `NET::ERR_CERT_AUTHORITY_INVALID` errors on internal or self-signed certificates.
802
+
803
+ **Solution**: Import your organization's CA certificate:
804
+
805
+ ```bash
806
+ # Linux - add to system certificates
807
+ sudo cp your-ca.crt /usr/local/share/ca-certificates/
808
+ sudo update-ca-certificates
809
+
810
+ # Or bypass certificate errors for development (not recommended for production)
811
+ chromium --ignore-certificate-errors
812
+ ```
813
+
814
+ ### Issue: Cannot Print (Printing Blank Pages)
815
+
816
+ **Symptoms**: Print dialog shows blank preview or prints empty pages.
817
+
818
+ **Solution**: Ensure CUPS printing service is running (Linux):
819
+
820
+ ```bash
821
+ sudo systemctl start cups
822
+ sudo systemctl enable cups
823
+ ```
824
+
825
+ ---
826
+
827
+ ## References
828
+
829
+ - [Chromium Project Official Website](https://www.chromium.org/Home/)
830
+ - [Chromium Official Download Page](https://www.chromium.org/getting-involved/download-chromium/)
831
+ - [Chromium Homebrew Cask](https://formulae.brew.sh/cask/chromium)
832
+ - [Chromium Snap Package](https://snapcraft.io/chromium)
833
+ - [Chromium Chocolatey Package](https://community.chocolatey.org/packages/chromium)
834
+ - [Ungoogled Chromium Project](https://github.com/ungoogled-software/ungoogled-chromium)
835
+ - [Chromium Command Line Switches](https://peter.sh/experiments/chromium-command-line-switches/)
836
+ - [Chromium on Raspberry Pi Documentation](https://pimylifeup.com/raspberry-pi-chromium-browser/)
837
+ - [Chrome for Testing (Headless Browser Testing)](https://googlechromelabs.github.io/chrome-for-testing/)
838
+ - [Chromium Continuous Build Archive](https://commondatastorage.googleapis.com/chromium-browser-snapshots/index.html)