@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.
- package/README.md +5 -5
- package/package.json +1 -1
- package/src/commands/install.js +374 -36
- package/src/installs/adobe-creative-cloud.js +527 -25
- package/src/installs/adobe-creative-cloud.md +605 -0
- package/src/installs/appcleaner.js +303 -26
- package/src/installs/appcleaner.md +699 -0
- package/src/installs/apt-transport-https.js +390 -0
- package/src/installs/apt-transport-https.md +678 -0
- package/src/installs/atomicparsley.js +624 -26
- package/src/installs/atomicparsley.md +795 -0
- package/src/installs/aws-cli.js +779 -26
- package/src/installs/aws-cli.md +727 -0
- package/src/installs/balena-etcher.js +688 -26
- package/src/installs/balena-etcher.md +761 -0
- package/src/installs/bambu-studio.js +912 -26
- package/src/installs/bambu-studio.md +780 -0
- package/src/installs/bash-completion.js +554 -23
- package/src/installs/bash-completion.md +833 -0
- package/src/installs/bash.js +399 -26
- package/src/installs/bash.md +993 -0
- package/src/installs/beyond-compare.js +585 -26
- package/src/installs/beyond-compare.md +813 -0
- package/src/installs/build-essential.js +511 -26
- package/src/installs/build-essential.md +977 -0
- package/src/installs/ca-certificates.js +618 -0
- package/src/installs/ca-certificates.md +937 -0
- package/src/installs/caffeine.js +490 -26
- package/src/installs/caffeine.md +839 -0
- package/src/installs/camtasia.js +577 -25
- package/src/installs/camtasia.md +762 -0
- package/src/installs/chatgpt.js +458 -26
- package/src/installs/chatgpt.md +814 -0
- package/src/installs/chocolatey.js +447 -0
- package/src/installs/chocolatey.md +661 -0
- package/src/installs/chrome-canary.js +472 -26
- package/src/installs/chrome-canary.md +641 -0
- package/src/installs/chromium.js +645 -26
- package/src/installs/chromium.md +838 -0
- package/src/installs/claude-code.js +558 -26
- package/src/installs/claude-code.md +1173 -0
- package/src/installs/curl.js +361 -26
- package/src/installs/curl.md +714 -0
- package/src/installs/cursor.js +561 -26
- package/src/installs/cursor.md +970 -0
- package/src/installs/dbschema.js +674 -26
- package/src/installs/dbschema.md +925 -0
- package/src/installs/dependencies.md +435 -0
- package/src/installs/development-tools.js +600 -0
- package/src/installs/development-tools.md +977 -0
- package/src/installs/docker.js +1010 -25
- package/src/installs/docker.md +1109 -0
- package/src/installs/drawio.js +1001 -26
- package/src/installs/drawio.md +795 -0
- package/src/installs/elmedia-player.js +328 -25
- package/src/installs/elmedia-player.md +556 -0
- package/src/installs/ffmpeg.js +870 -25
- package/src/installs/ffmpeg.md +852 -0
- package/src/installs/file.js +464 -0
- package/src/installs/file.md +987 -0
- package/src/installs/gemini-cli.js +793 -26
- package/src/installs/gemini-cli.md +1153 -0
- package/src/installs/git.js +382 -26
- package/src/installs/git.md +907 -0
- package/src/installs/gitego.js +931 -26
- package/src/installs/gitego.md +1172 -0
- package/src/installs/go.js +913 -26
- package/src/installs/go.md +958 -0
- package/src/installs/google-chrome.js +801 -25
- package/src/installs/google-chrome.md +862 -0
- package/src/installs/gpg.js +412 -73
- package/src/installs/gpg.md +1056 -0
- package/src/installs/homebrew.js +1015 -26
- package/src/installs/homebrew.md +988 -0
- package/src/installs/imageoptim.js +950 -26
- package/src/installs/imageoptim.md +1119 -0
- package/src/installs/installers.json +2297 -0
- package/src/installs/jq.js +382 -26
- package/src/installs/jq.md +809 -0
- package/src/installs/keyboard-maestro.js +701 -26
- package/src/installs/keyboard-maestro.md +825 -0
- package/src/installs/latex.js +771 -26
- package/src/installs/latex.md +1095 -0
- package/src/installs/lftp.js +338 -26
- package/src/installs/lftp.md +907 -0
- package/src/installs/lsb-release.js +346 -0
- package/src/installs/lsb-release.md +814 -0
- package/src/installs/messenger.js +829 -26
- package/src/installs/messenger.md +900 -0
- package/src/installs/microsoft-office.js +550 -26
- package/src/installs/microsoft-office.md +760 -0
- package/src/installs/microsoft-teams.js +782 -25
- package/src/installs/microsoft-teams.md +886 -0
- package/src/installs/node.js +886 -26
- package/src/installs/node.md +1153 -0
- package/src/installs/nordpass.js +698 -26
- package/src/installs/nordpass.md +921 -0
- package/src/installs/nvm.js +977 -26
- package/src/installs/nvm.md +1057 -0
- package/src/installs/openssh.js +734 -64
- package/src/installs/openssh.md +1056 -0
- package/src/installs/pandoc.js +644 -26
- package/src/installs/pandoc.md +1036 -0
- package/src/installs/pinentry.js +492 -26
- package/src/installs/pinentry.md +1142 -0
- package/src/installs/pngyu.js +851 -26
- package/src/installs/pngyu.md +896 -0
- package/src/installs/postman.js +781 -26
- package/src/installs/postman.md +940 -0
- package/src/installs/procps.js +425 -0
- package/src/installs/procps.md +851 -0
- package/src/installs/safari-tech-preview.js +355 -25
- package/src/installs/safari-tech-preview.md +533 -0
- package/src/installs/sfnt2woff.js +640 -26
- package/src/installs/sfnt2woff.md +795 -0
- package/src/installs/shellcheck.js +463 -26
- package/src/installs/shellcheck.md +1005 -0
- package/src/installs/slack.js +722 -25
- package/src/installs/slack.md +865 -0
- package/src/installs/snagit.js +566 -25
- package/src/installs/snagit.md +844 -0
- package/src/installs/software-properties-common.js +372 -0
- package/src/installs/software-properties-common.md +805 -0
- package/src/installs/spotify.js +858 -25
- package/src/installs/spotify.md +901 -0
- package/src/installs/studio-3t.js +803 -26
- package/src/installs/studio-3t.md +918 -0
- package/src/installs/sublime-text.js +780 -25
- package/src/installs/sublime-text.md +914 -0
- package/src/installs/superwhisper.js +687 -25
- package/src/installs/superwhisper.md +630 -0
- package/src/installs/tailscale.js +727 -26
- package/src/installs/tailscale.md +1100 -0
- package/src/installs/tar.js +389 -0
- package/src/installs/tar.md +946 -0
- package/src/installs/termius.js +780 -26
- package/src/installs/termius.md +844 -0
- package/src/installs/terraform.js +761 -26
- package/src/installs/terraform.md +899 -0
- package/src/installs/tidal.js +752 -25
- package/src/installs/tidal.md +864 -0
- package/src/installs/tmux.js +328 -26
- package/src/installs/tmux.md +1030 -0
- package/src/installs/tree.js +393 -26
- package/src/installs/tree.md +833 -0
- package/src/installs/unzip.js +460 -0
- package/src/installs/unzip.md +879 -0
- package/src/installs/vim.js +403 -26
- package/src/installs/vim.md +1040 -0
- package/src/installs/vlc.js +803 -26
- package/src/installs/vlc.md +927 -0
- package/src/installs/vscode.js +825 -26
- package/src/installs/vscode.md +1002 -0
- package/src/installs/wget.js +415 -0
- package/src/installs/wget.md +791 -0
- package/src/installs/whatsapp.js +710 -25
- package/src/installs/whatsapp.md +854 -0
- package/src/installs/winpty.js +352 -0
- package/src/installs/winpty.md +620 -0
- package/src/installs/woff2.js +535 -26
- package/src/installs/woff2.md +977 -0
- package/src/installs/wsl.js +572 -0
- package/src/installs/wsl.md +699 -0
- package/src/installs/xcode-clt.js +520 -0
- package/src/installs/xcode-clt.md +351 -0
- package/src/installs/xcode.js +542 -26
- package/src/installs/xcode.md +573 -0
- package/src/installs/yarn.js +806 -26
- package/src/installs/yarn.md +1074 -0
- package/src/installs/yq.js +636 -26
- package/src/installs/yq.md +944 -0
- package/src/installs/yt-dlp.js +683 -26
- package/src/installs/yt-dlp.md +946 -0
- package/src/installs/yum-utils.js +297 -0
- package/src/installs/yum-utils.md +648 -0
- package/src/installs/zoom.js +740 -25
- package/src/installs/zoom.md +884 -0
- package/src/scripts/README.md +567 -45
- package/src/scripts/STATUS.md +208 -0
- package/src/scripts/afk.js +395 -7
- package/src/scripts/backup-all.js +731 -9
- package/src/scripts/backup-source.js +711 -8
- package/src/scripts/brewd.js +373 -7
- package/src/scripts/brewi.js +505 -9
- package/src/scripts/brewr.js +512 -9
- package/src/scripts/brews.js +462 -9
- package/src/scripts/brewu.js +488 -7
- package/src/scripts/c.js +185 -7
- package/src/scripts/ccurl.js +325 -8
- package/src/scripts/certbot-crontab-init.js +488 -8
- package/src/scripts/certbot-init.js +641 -9
- package/src/scripts/ch.js +339 -7
- package/src/scripts/claude-danger.js +253 -8
- package/src/scripts/clean-dev.js +419 -8
- package/src/scripts/clear-dns-cache.js +525 -7
- package/src/scripts/clone.js +417 -7
- package/src/scripts/code-all.js +420 -7
- package/src/scripts/count-files.js +195 -8
- package/src/scripts/count-folders.js +195 -8
- package/src/scripts/count.js +248 -8
- package/src/scripts/d.js +203 -7
- package/src/scripts/datauri.js +373 -8
- package/src/scripts/delete-files.js +363 -7
- package/src/scripts/docker-clean.js +410 -8
- package/src/scripts/dp.js +426 -7
- package/src/scripts/e.js +375 -9
- package/src/scripts/empty-trash.js +497 -7
- package/src/scripts/evm.js +428 -9
- package/src/scripts/fetch-github-repos.js +441 -10
- package/src/scripts/get-channel.js +329 -8
- package/src/scripts/get-course.js +384 -11
- package/src/scripts/get-dependencies.js +290 -9
- package/src/scripts/get-folder.js +783 -10
- package/src/scripts/get-tunes.js +411 -10
- package/src/scripts/get-video.js +352 -9
- package/src/scripts/git-backup.js +561 -9
- package/src/scripts/git-clone.js +477 -9
- package/src/scripts/git-pup.js +303 -7
- package/src/scripts/git-push.js +380 -8
- package/src/scripts/h.js +607 -9
- package/src/scripts/hide-desktop-icons.js +483 -7
- package/src/scripts/hide-hidden-files.js +522 -7
- package/src/scripts/install-dependencies-from.js +440 -9
- package/src/scripts/ips.js +647 -10
- package/src/scripts/iso.js +354 -8
- package/src/scripts/killni.js +561 -7
- package/src/scripts/ll.js +451 -8
- package/src/scripts/local-ip.js +310 -8
- package/src/scripts/m.js +508 -8
- package/src/scripts/map.js +293 -8
- package/src/scripts/mkd.js +287 -7
- package/src/scripts/ncu-update-all.js +441 -8
- package/src/scripts/nginx-init.js +702 -12
- package/src/scripts/npmi.js +366 -7
- package/src/scripts/o.js +495 -8
- package/src/scripts/org-by-date.js +321 -7
- package/src/scripts/p.js +208 -7
- package/src/scripts/packages.js +313 -8
- package/src/scripts/path.js +209 -7
- package/src/scripts/ports.js +582 -8
- package/src/scripts/q.js +290 -8
- package/src/scripts/refresh-files.js +378 -10
- package/src/scripts/remove-smaller-files.js +500 -8
- package/src/scripts/rename-files-with-date.js +517 -9
- package/src/scripts/resize-image.js +523 -9
- package/src/scripts/rm-safe.js +653 -8
- package/src/scripts/s.js +525 -9
- package/src/scripts/set-git-public.js +349 -7
- package/src/scripts/show-desktop-icons.js +459 -7
- package/src/scripts/show-hidden-files.js +456 -7
- package/src/scripts/tpa.js +265 -8
- package/src/scripts/tpo.js +264 -7
- package/src/scripts/u.js +489 -7
- package/src/scripts/vpush.js +422 -8
- package/src/scripts/y.js +267 -7
- package/src/utils/common/os.js +94 -2
- package/src/utils/ubuntu/apt.js +13 -7
- package/src/utils/windows/choco.js +82 -26
- package/src/utils/windows/winget.js +89 -27
package/src/installs/vlc.js
CHANGED
|
@@ -1,44 +1,821 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
|
-
* @fileoverview Install VLC.
|
|
4
|
+
* @fileoverview Install VLC Media Player.
|
|
5
5
|
* @module installs/vlc
|
|
6
|
+
*
|
|
7
|
+
* VLC is a free and open-source cross-platform multimedia player and framework
|
|
8
|
+
* developed by the VideoLAN project. It plays most multimedia files, DVDs,
|
|
9
|
+
* Audio CDs, VCDs, and various streaming protocols without requiring additional
|
|
10
|
+
* codec packs.
|
|
11
|
+
*
|
|
12
|
+
* This installer provides:
|
|
13
|
+
* - VLC via Homebrew cask for macOS
|
|
14
|
+
* - VLC via APT for Ubuntu/Debian and Raspberry Pi OS
|
|
15
|
+
* - VLC via DNF/YUM with RPM Fusion for Amazon Linux/RHEL
|
|
16
|
+
* - VLC via Chocolatey for Windows
|
|
17
|
+
* - VLC via APT for WSL (Ubuntu)
|
|
18
|
+
* - VLC via Windows installation (Chocolatey) for Git Bash
|
|
19
|
+
*
|
|
20
|
+
* IMPORTANT PLATFORM NOTES:
|
|
21
|
+
* - macOS: Installs VLC.app via Homebrew cask to /Applications
|
|
22
|
+
* - Ubuntu/Debian: Installs from official APT repositories
|
|
23
|
+
* - Raspberry Pi OS: Installs from official APT repositories (ARM compatible)
|
|
24
|
+
* - Amazon Linux/RHEL: Requires EPEL and RPM Fusion repositories
|
|
25
|
+
* - Windows: Installs via Chocolatey package manager
|
|
26
|
+
* - WSL: Installs via APT within WSL environment (requires WSLg for GUI)
|
|
27
|
+
* - Git Bash: Installs on Windows host via Chocolatey through PowerShell
|
|
6
28
|
*/
|
|
7
29
|
|
|
8
30
|
const os = require('../utils/common/os');
|
|
31
|
+
const shell = require('../utils/common/shell');
|
|
32
|
+
const brew = require('../utils/macos/brew');
|
|
33
|
+
const macosApps = require('../utils/macos/apps');
|
|
34
|
+
const apt = require('../utils/ubuntu/apt');
|
|
35
|
+
const choco = require('../utils/windows/choco');
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Indicates whether this installer requires a desktop environment.
|
|
39
|
+
* VLC is a GUI media player and requires a display.
|
|
40
|
+
* @type {boolean}
|
|
41
|
+
*/
|
|
42
|
+
const REQUIRES_DESKTOP = true;
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* The Homebrew cask name for VLC on macOS.
|
|
46
|
+
* This installs the full VLC.app to /Applications.
|
|
47
|
+
*/
|
|
48
|
+
const HOMEBREW_CASK_NAME = 'vlc';
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* The APT package name for VLC on Debian-based systems.
|
|
52
|
+
*/
|
|
53
|
+
const APT_PACKAGE_NAME = 'vlc';
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* The Chocolatey package name for VLC on Windows.
|
|
57
|
+
*/
|
|
58
|
+
const CHOCO_PACKAGE_NAME = 'vlc';
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* The macOS application name for VLC.
|
|
62
|
+
* Used to check if VLC is already installed in /Applications.
|
|
63
|
+
*/
|
|
64
|
+
const MACOS_APP_NAME = 'VLC';
|
|
65
|
+
|
|
66
|
+
/**
|
|
67
|
+
* Check if VLC is installed by verifying the 'vlc' command exists.
|
|
68
|
+
*
|
|
69
|
+
* This check works on Linux and Windows where VLC adds itself to PATH.
|
|
70
|
+
* For macOS, use the macosApps utility to check for VLC.app instead.
|
|
71
|
+
*
|
|
72
|
+
* @returns {boolean} True if the vlc command is available, false otherwise
|
|
73
|
+
*/
|
|
74
|
+
function isVLCCommandAvailable() {
|
|
75
|
+
return shell.commandExists('vlc');
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Check if VLC is installed and get the version.
|
|
80
|
+
*
|
|
81
|
+
* Executes 'vlc --version' to verify VLC is properly installed
|
|
82
|
+
* and operational. Returns the version string if successful.
|
|
83
|
+
*
|
|
84
|
+
* @returns {Promise<string|null>} VLC version string, or null if not installed
|
|
85
|
+
*/
|
|
86
|
+
async function getVLCVersion() {
|
|
87
|
+
// First check if the command exists to avoid unnecessary process spawning
|
|
88
|
+
if (!isVLCCommandAvailable()) {
|
|
89
|
+
return null;
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
// Execute vlc --version to get version information
|
|
93
|
+
// The output format is typically: "VLC media player X.Y.Z Vetinari..."
|
|
94
|
+
const result = await shell.exec('vlc --version');
|
|
95
|
+
if (result.code === 0 && result.stdout) {
|
|
96
|
+
// Parse version from output like: "VLC media player 3.0.21 Vetinari..."
|
|
97
|
+
const match = result.stdout.match(/VLC media player\s+([^\s]+)/);
|
|
98
|
+
return match ? match[1] : result.stdout.split('\n')[0].trim();
|
|
99
|
+
}
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* Install VLC on macOS using Homebrew cask.
|
|
105
|
+
*
|
|
106
|
+
* Prerequisites:
|
|
107
|
+
* - macOS 10.15 (Catalina) or later
|
|
108
|
+
* - Homebrew package manager installed
|
|
109
|
+
* - At least 200 MB free disk space
|
|
110
|
+
*
|
|
111
|
+
* Homebrew installs VLC.app to /Applications. On first launch, macOS may
|
|
112
|
+
* display a Gatekeeper warning that requires right-clicking the app and
|
|
113
|
+
* selecting "Open" to bypass.
|
|
114
|
+
*
|
|
115
|
+
* @returns {Promise<void>}
|
|
116
|
+
* @throws {Error} If Homebrew is not installed or installation fails
|
|
117
|
+
*/
|
|
118
|
+
async function install_macos() {
|
|
119
|
+
console.log('Checking if VLC is already installed...');
|
|
120
|
+
|
|
121
|
+
// Check if VLC.app exists in /Applications
|
|
122
|
+
const isAppInstalled = macosApps.isAppInstalled(MACOS_APP_NAME);
|
|
123
|
+
if (isAppInstalled) {
|
|
124
|
+
const version = macosApps.getAppVersion(MACOS_APP_NAME);
|
|
125
|
+
if (version) {
|
|
126
|
+
console.log(`VLC ${version} is already installed, skipping installation.`);
|
|
127
|
+
} else {
|
|
128
|
+
console.log('VLC is already installed, skipping installation.');
|
|
129
|
+
}
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
// Also check if the cask is installed via Homebrew
|
|
134
|
+
// (VLC may be installed but not detected in Applications for some reason)
|
|
135
|
+
const caskInstalled = await brew.isCaskInstalled(HOMEBREW_CASK_NAME);
|
|
136
|
+
if (caskInstalled) {
|
|
137
|
+
console.log('VLC is already installed via Homebrew, skipping installation.');
|
|
138
|
+
console.log('');
|
|
139
|
+
console.log('NOTE: If VLC is not appearing in Applications, try:');
|
|
140
|
+
console.log(' brew reinstall --cask vlc');
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
// Verify Homebrew is available
|
|
145
|
+
if (!brew.isInstalled()) {
|
|
146
|
+
throw new Error(
|
|
147
|
+
'Homebrew is not installed. Please install Homebrew first using:\n' +
|
|
148
|
+
' dev install homebrew\n' +
|
|
149
|
+
'Then retry installing VLC.'
|
|
150
|
+
);
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
console.log('Installing VLC via Homebrew...');
|
|
154
|
+
|
|
155
|
+
// Install VLC cask with --quiet flag for cleaner output
|
|
156
|
+
const result = await shell.exec('brew install --quiet --cask vlc');
|
|
157
|
+
|
|
158
|
+
if (result.code !== 0) {
|
|
159
|
+
throw new Error(
|
|
160
|
+
`Failed to install VLC via Homebrew.\n` +
|
|
161
|
+
`Output: ${result.stderr || result.stdout}\n\n` +
|
|
162
|
+
`Troubleshooting:\n` +
|
|
163
|
+
` 1. Run 'brew update && brew cleanup' and retry\n` +
|
|
164
|
+
` 2. Check for Homebrew issues: brew doctor\n` +
|
|
165
|
+
` 3. Try manual installation: brew install --cask vlc`
|
|
166
|
+
);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
// Verify installation succeeded by checking for VLC.app
|
|
170
|
+
const verified = macosApps.isAppInstalled(MACOS_APP_NAME);
|
|
171
|
+
if (!verified) {
|
|
172
|
+
throw new Error(
|
|
173
|
+
'Installation appeared to complete but VLC.app was not found.\n\n' +
|
|
174
|
+
'Please try:\n' +
|
|
175
|
+
' 1. Check /Applications/VLC.app exists\n' +
|
|
176
|
+
' 2. Run: brew reinstall --cask vlc'
|
|
177
|
+
);
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
const installedVersion = macosApps.getAppVersion(MACOS_APP_NAME);
|
|
181
|
+
console.log(`VLC ${installedVersion || ''} installed successfully.`);
|
|
182
|
+
console.log('');
|
|
183
|
+
console.log('You can launch VLC from:');
|
|
184
|
+
console.log(' - Applications folder');
|
|
185
|
+
console.log(' - Spotlight (Cmd+Space, type "VLC")');
|
|
186
|
+
console.log(' - Terminal: open -a VLC');
|
|
187
|
+
console.log('');
|
|
188
|
+
console.log('NOTE: On first launch, you may see a Gatekeeper warning.');
|
|
189
|
+
console.log('Right-click VLC in Applications and select "Open" to bypass.');
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* Install VLC on Ubuntu/Debian using APT.
|
|
194
|
+
*
|
|
195
|
+
* Prerequisites:
|
|
196
|
+
* - Ubuntu 20.04 LTS or later, or Debian 11 (Bullseye) or later
|
|
197
|
+
* - sudo privileges
|
|
198
|
+
* - At least 500 MB free disk space (including dependencies)
|
|
199
|
+
*
|
|
200
|
+
* The version available in Ubuntu/Debian repositories may not be the absolute
|
|
201
|
+
* latest. For most use cases, the repository version is sufficient and receives
|
|
202
|
+
* security updates.
|
|
203
|
+
*
|
|
204
|
+
* @returns {Promise<void>}
|
|
205
|
+
* @throws {Error} If installation fails
|
|
206
|
+
*/
|
|
207
|
+
async function install_ubuntu() {
|
|
208
|
+
console.log('Checking if VLC is already installed...');
|
|
209
|
+
|
|
210
|
+
// Check if VLC is already installed via dpkg
|
|
211
|
+
const isInstalled = await apt.isPackageInstalled(APT_PACKAGE_NAME);
|
|
212
|
+
if (isInstalled) {
|
|
213
|
+
const version = await apt.getPackageVersion(APT_PACKAGE_NAME);
|
|
214
|
+
if (version) {
|
|
215
|
+
console.log(`VLC ${version} is already installed, skipping installation.`);
|
|
216
|
+
} else {
|
|
217
|
+
console.log('VLC is already installed, skipping installation.');
|
|
218
|
+
}
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
// Update package index before installing
|
|
223
|
+
console.log('Updating package index...');
|
|
224
|
+
const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
|
|
225
|
+
if (updateResult.code !== 0) {
|
|
226
|
+
console.log('Warning: Could not update package index, continuing anyway...');
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
// Install VLC via APT
|
|
230
|
+
console.log('Installing VLC via APT...');
|
|
231
|
+
const installResult = await shell.exec(
|
|
232
|
+
'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y vlc'
|
|
233
|
+
);
|
|
234
|
+
|
|
235
|
+
if (installResult.code !== 0) {
|
|
236
|
+
throw new Error(
|
|
237
|
+
`Failed to install VLC via APT.\n` +
|
|
238
|
+
`Output: ${installResult.stderr}\n\n` +
|
|
239
|
+
`Troubleshooting:\n` +
|
|
240
|
+
` 1. Run 'sudo apt-get update' and retry\n` +
|
|
241
|
+
` 2. Check available packages: apt-cache search vlc\n` +
|
|
242
|
+
` 3. Try manual installation: sudo apt-get install vlc`
|
|
243
|
+
);
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
// Verify installation succeeded
|
|
247
|
+
const version = await getVLCVersion();
|
|
248
|
+
if (!version) {
|
|
249
|
+
throw new Error(
|
|
250
|
+
'Installation appeared to complete but VLC was not found.\n\n' +
|
|
251
|
+
'Please try:\n' +
|
|
252
|
+
' 1. Restart your terminal session\n' +
|
|
253
|
+
' 2. Run: vlc --version'
|
|
254
|
+
);
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
console.log(`VLC ${version} installed successfully.`);
|
|
258
|
+
console.log('');
|
|
259
|
+
console.log('You can launch VLC from:');
|
|
260
|
+
console.log(' - Applications menu');
|
|
261
|
+
console.log(' - Terminal: vlc');
|
|
262
|
+
console.log(' - Headless/CLI mode: cvlc');
|
|
263
|
+
console.log('');
|
|
264
|
+
console.log('NOTE: The repository version may not be the latest.');
|
|
265
|
+
console.log('For newer versions, consider the VideoLAN PPA.');
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
/**
|
|
269
|
+
* Install VLC on Raspberry Pi OS using APT.
|
|
270
|
+
*
|
|
271
|
+
* Prerequisites:
|
|
272
|
+
* - Raspberry Pi OS (Bookworm or Bullseye), 32-bit or 64-bit
|
|
273
|
+
* - Raspberry Pi 3 or later recommended (earlier models have limited performance)
|
|
274
|
+
* - sudo privileges
|
|
275
|
+
* - At least 500 MB free disk space
|
|
276
|
+
*
|
|
277
|
+
* NOTE: Raspberry Pi OS (full desktop version) typically comes with VLC
|
|
278
|
+
* pre-installed. This installer handles cases where VLC was removed or
|
|
279
|
+
* on Raspberry Pi OS Lite.
|
|
280
|
+
*
|
|
281
|
+
* The Raspberry Pi OS repositories contain VLC builds optimized for ARM
|
|
282
|
+
* processors with hardware acceleration patches for the Raspberry Pi's GPU.
|
|
283
|
+
*
|
|
284
|
+
* @returns {Promise<void>}
|
|
285
|
+
* @throws {Error} If installation fails
|
|
286
|
+
*/
|
|
287
|
+
async function install_raspbian() {
|
|
288
|
+
console.log('Checking if VLC is already installed...');
|
|
289
|
+
|
|
290
|
+
// Check if VLC is already installed via dpkg
|
|
291
|
+
const isInstalled = await apt.isPackageInstalled(APT_PACKAGE_NAME);
|
|
292
|
+
if (isInstalled) {
|
|
293
|
+
const version = await apt.getPackageVersion(APT_PACKAGE_NAME);
|
|
294
|
+
if (version) {
|
|
295
|
+
console.log(`VLC ${version} is already installed, skipping installation.`);
|
|
296
|
+
} else {
|
|
297
|
+
console.log('VLC is already installed, skipping installation.');
|
|
298
|
+
}
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
// Update package index before installing
|
|
303
|
+
console.log('Updating package index...');
|
|
304
|
+
const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
|
|
305
|
+
if (updateResult.code !== 0) {
|
|
306
|
+
console.log('Warning: Could not update package index, continuing anyway...');
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
// Install VLC via APT
|
|
310
|
+
console.log('Installing VLC via APT...');
|
|
311
|
+
const installResult = await shell.exec(
|
|
312
|
+
'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y vlc'
|
|
313
|
+
);
|
|
314
|
+
|
|
315
|
+
if (installResult.code !== 0) {
|
|
316
|
+
throw new Error(
|
|
317
|
+
`Failed to install VLC via APT.\n` +
|
|
318
|
+
`Output: ${installResult.stderr}\n\n` +
|
|
319
|
+
`Troubleshooting:\n` +
|
|
320
|
+
` 1. Run 'sudo apt-get update' and retry\n` +
|
|
321
|
+
` 2. Check available packages: apt-cache search vlc\n` +
|
|
322
|
+
` 3. Try manual installation: sudo apt-get install vlc`
|
|
323
|
+
);
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
// Verify installation succeeded
|
|
327
|
+
const version = await getVLCVersion();
|
|
328
|
+
if (!version) {
|
|
329
|
+
throw new Error(
|
|
330
|
+
'Installation appeared to complete but VLC was not found.\n\n' +
|
|
331
|
+
'Please try:\n' +
|
|
332
|
+
' 1. Restart your terminal session\n' +
|
|
333
|
+
' 2. Run: vlc --version'
|
|
334
|
+
);
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
console.log(`VLC ${version} installed successfully.`);
|
|
338
|
+
console.log('');
|
|
339
|
+
console.log('You can launch VLC from:');
|
|
340
|
+
console.log(' - Desktop menu (under Sound & Video)');
|
|
341
|
+
console.log(' - Terminal: vlc');
|
|
342
|
+
console.log(' - Headless/CLI mode: cvlc');
|
|
343
|
+
console.log('');
|
|
344
|
+
console.log('RASPBERRY PI NOTES:');
|
|
345
|
+
console.log(' - Hardware acceleration is available for better performance');
|
|
346
|
+
console.log(' - Use MMAL codec for H.264: cvlc --codec=mmal_codec video.mp4');
|
|
347
|
+
console.log(' - For headless streaming, install vlc-nox: sudo apt install vlc-nox');
|
|
348
|
+
}
|
|
9
349
|
|
|
10
350
|
/**
|
|
11
|
-
* Install VLC
|
|
351
|
+
* Install VLC on Amazon Linux/RHEL using DNF/YUM with RPM Fusion.
|
|
352
|
+
*
|
|
353
|
+
* Prerequisites:
|
|
354
|
+
* - Amazon Linux 2023 (AL2023), Amazon Linux 2 (AL2), or RHEL 8/9
|
|
355
|
+
* - sudo privileges
|
|
356
|
+
* - At least 500 MB free disk space
|
|
357
|
+
*
|
|
358
|
+
* IMPORTANT: VLC is not available in the standard Amazon Linux or RHEL
|
|
359
|
+
* repositories. This function enables the EPEL (Extra Packages for Enterprise
|
|
360
|
+
* Linux) and RPM Fusion repositories to install VLC.
|
|
361
|
+
*
|
|
362
|
+
* @returns {Promise<void>}
|
|
363
|
+
* @throws {Error} If installation fails
|
|
364
|
+
*/
|
|
365
|
+
async function install_amazon_linux() {
|
|
366
|
+
console.log('Checking if VLC is already installed...');
|
|
367
|
+
|
|
368
|
+
// Check if VLC is already installed
|
|
369
|
+
const existingVersion = await getVLCVersion();
|
|
370
|
+
if (existingVersion) {
|
|
371
|
+
console.log(`VLC ${existingVersion} is already installed, skipping installation.`);
|
|
372
|
+
return;
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
// Detect package manager (dnf for AL2023/RHEL9, yum for AL2/RHEL8)
|
|
376
|
+
const hasDnf = shell.commandExists('dnf');
|
|
377
|
+
const hasYum = shell.commandExists('yum');
|
|
378
|
+
const packageManager = hasDnf ? 'dnf' : (hasYum ? 'yum' : null);
|
|
379
|
+
|
|
380
|
+
if (!packageManager) {
|
|
381
|
+
throw new Error(
|
|
382
|
+
'Neither dnf nor yum package manager found.\n' +
|
|
383
|
+
'This installer supports Amazon Linux 2023 (dnf), Amazon Linux 2 (yum), and RHEL 8/9.'
|
|
384
|
+
);
|
|
385
|
+
}
|
|
386
|
+
|
|
387
|
+
console.log(`Detected package manager: ${packageManager}`);
|
|
388
|
+
|
|
389
|
+
// Determine the RHEL version for repository URLs
|
|
390
|
+
// AL2023 is based on Fedora and compatible with RHEL 9 repos
|
|
391
|
+
// AL2 and RHEL 8 use version 8 repos
|
|
392
|
+
console.log('Detecting system version...');
|
|
393
|
+
const versionResult = await shell.exec('rpm -E %rhel');
|
|
394
|
+
let rhelVersion = versionResult.stdout.trim();
|
|
395
|
+
|
|
396
|
+
// If rpm -E %rhel returns empty or just "%rhel", try to detect from os-release
|
|
397
|
+
if (!rhelVersion || rhelVersion === '%rhel') {
|
|
398
|
+
if (hasDnf) {
|
|
399
|
+
// Amazon Linux 2023 is compatible with RHEL 9
|
|
400
|
+
rhelVersion = '9';
|
|
401
|
+
} else {
|
|
402
|
+
// Amazon Linux 2 is compatible with RHEL 8
|
|
403
|
+
rhelVersion = '8';
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
console.log(`Using RHEL ${rhelVersion} compatible repositories...`);
|
|
408
|
+
|
|
409
|
+
// Install EPEL repository (required dependency for RPM Fusion)
|
|
410
|
+
console.log('Installing EPEL repository...');
|
|
411
|
+
const epelUrl = `https://dl.fedoraproject.org/pub/epel/epel-release-latest-${rhelVersion}.noarch.rpm`;
|
|
412
|
+
const epelResult = await shell.exec(`sudo ${packageManager} install -y ${epelUrl}`);
|
|
413
|
+
if (epelResult.code !== 0) {
|
|
414
|
+
// EPEL might already be installed, continue anyway
|
|
415
|
+
console.log('Note: EPEL may already be installed, continuing...');
|
|
416
|
+
}
|
|
417
|
+
|
|
418
|
+
// Install RPM Fusion Free repository (contains VLC)
|
|
419
|
+
console.log('Installing RPM Fusion Free repository...');
|
|
420
|
+
const rpmfusionUrl = `https://download1.rpmfusion.org/free/el/rpmfusion-free-release-${rhelVersion}.noarch.rpm`;
|
|
421
|
+
const rpmfusionResult = await shell.exec(`sudo ${packageManager} install -y ${rpmfusionUrl}`);
|
|
422
|
+
if (rpmfusionResult.code !== 0) {
|
|
423
|
+
throw new Error(
|
|
424
|
+
`Failed to install RPM Fusion repository.\n` +
|
|
425
|
+
`Output: ${rpmfusionResult.stderr}\n\n` +
|
|
426
|
+
`Troubleshooting:\n` +
|
|
427
|
+
` 1. Check your internet connection\n` +
|
|
428
|
+
` 2. Verify the repository URL is accessible\n` +
|
|
429
|
+
` 3. Try manually: sudo ${packageManager} install -y ${rpmfusionUrl}`
|
|
430
|
+
);
|
|
431
|
+
}
|
|
432
|
+
|
|
433
|
+
// Install VLC
|
|
434
|
+
console.log('Installing VLC...');
|
|
435
|
+
const installResult = await shell.exec(`sudo ${packageManager} install -y vlc`);
|
|
436
|
+
|
|
437
|
+
if (installResult.code !== 0) {
|
|
438
|
+
throw new Error(
|
|
439
|
+
`Failed to install VLC.\n` +
|
|
440
|
+
`Output: ${installResult.stderr}\n\n` +
|
|
441
|
+
`Troubleshooting:\n` +
|
|
442
|
+
` 1. Verify RPM Fusion is enabled: ${packageManager} repolist\n` +
|
|
443
|
+
` 2. Clean package cache: sudo ${packageManager} clean all\n` +
|
|
444
|
+
` 3. Try manual installation: sudo ${packageManager} install vlc`
|
|
445
|
+
);
|
|
446
|
+
}
|
|
447
|
+
|
|
448
|
+
// Verify installation succeeded
|
|
449
|
+
const version = await getVLCVersion();
|
|
450
|
+
if (!version) {
|
|
451
|
+
throw new Error(
|
|
452
|
+
'Installation appeared to complete but VLC was not found.\n\n' +
|
|
453
|
+
'Please try:\n' +
|
|
454
|
+
' 1. Restart your terminal session\n' +
|
|
455
|
+
' 2. Run: vlc --version'
|
|
456
|
+
);
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
console.log(`VLC ${version} installed successfully.`);
|
|
460
|
+
console.log('');
|
|
461
|
+
console.log('You can launch VLC from:');
|
|
462
|
+
console.log(' - Terminal: vlc');
|
|
463
|
+
console.log(' - Headless/CLI mode: cvlc');
|
|
464
|
+
console.log('');
|
|
465
|
+
console.log('NOTE: VLC was installed from RPM Fusion repository.');
|
|
466
|
+
console.log('For headless server use (streaming/transcoding): cvlc --no-video');
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
/**
|
|
470
|
+
* Install VLC on Windows using Chocolatey.
|
|
471
|
+
*
|
|
472
|
+
* Prerequisites:
|
|
473
|
+
* - Windows 10 or later (32-bit or 64-bit), or Windows 11
|
|
474
|
+
* - Administrator PowerShell or Command Prompt
|
|
475
|
+
* - Chocolatey package manager installed
|
|
476
|
+
* - At least 200 MB free disk space
|
|
477
|
+
*
|
|
478
|
+
* Chocolatey downloads VLC from the official VideoLAN servers and handles
|
|
479
|
+
* the installation silently. VLC will be added to the system PATH.
|
|
480
|
+
*
|
|
481
|
+
* @returns {Promise<void>}
|
|
482
|
+
* @throws {Error} If Chocolatey is not installed or installation fails
|
|
483
|
+
*/
|
|
484
|
+
async function install_windows() {
|
|
485
|
+
console.log('Checking if VLC is already installed...');
|
|
486
|
+
|
|
487
|
+
// Check if VLC is already installed
|
|
488
|
+
const existingVersion = await getVLCVersion();
|
|
489
|
+
if (existingVersion) {
|
|
490
|
+
console.log(`VLC ${existingVersion} is already installed, skipping installation.`);
|
|
491
|
+
return;
|
|
492
|
+
}
|
|
493
|
+
|
|
494
|
+
// Check if VLC package is installed via Chocolatey
|
|
495
|
+
const packageInstalled = await choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
|
|
496
|
+
if (packageInstalled) {
|
|
497
|
+
console.log('VLC is already installed via Chocolatey, skipping installation.');
|
|
498
|
+
console.log('');
|
|
499
|
+
console.log('NOTE: If VLC commands are not working, open a new terminal window');
|
|
500
|
+
console.log('to refresh your PATH, or run: refreshenv');
|
|
501
|
+
return;
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
// Verify Chocolatey is available
|
|
505
|
+
if (!choco.isInstalled()) {
|
|
506
|
+
throw new Error(
|
|
507
|
+
'Chocolatey is not installed. Please install Chocolatey first:\n\n' +
|
|
508
|
+
'Run the following in an Administrator PowerShell:\n' +
|
|
509
|
+
' Set-ExecutionPolicy Bypass -Scope Process -Force; ' +
|
|
510
|
+
'[System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; ' +
|
|
511
|
+
'iex ((New-Object System.Net.WebClient).DownloadString(\'https://community.chocolatey.org/install.ps1\'))\n\n' +
|
|
512
|
+
'Then retry installing VLC.'
|
|
513
|
+
);
|
|
514
|
+
}
|
|
515
|
+
|
|
516
|
+
console.log('Installing VLC via Chocolatey...');
|
|
517
|
+
console.log('This may take a few minutes...');
|
|
518
|
+
|
|
519
|
+
// Install VLC using Chocolatey
|
|
520
|
+
const result = await choco.install(CHOCO_PACKAGE_NAME);
|
|
521
|
+
|
|
522
|
+
if (!result.success) {
|
|
523
|
+
throw new Error(
|
|
524
|
+
`Failed to install VLC via Chocolatey.\n` +
|
|
525
|
+
`Output: ${result.output}\n\n` +
|
|
526
|
+
`Troubleshooting:\n` +
|
|
527
|
+
` 1. Ensure you are running as Administrator\n` +
|
|
528
|
+
` 2. Try manual installation: choco install vlc -y\n` +
|
|
529
|
+
` 3. Check Chocolatey logs for details`
|
|
530
|
+
);
|
|
531
|
+
}
|
|
532
|
+
|
|
533
|
+
console.log('VLC installed successfully.');
|
|
534
|
+
console.log('');
|
|
535
|
+
console.log('IMPORTANT: Open a new terminal window to refresh your PATH.');
|
|
536
|
+
console.log('Alternatively, run: refreshenv');
|
|
537
|
+
console.log('');
|
|
538
|
+
console.log('You can launch VLC from:');
|
|
539
|
+
console.log(' - Start Menu');
|
|
540
|
+
console.log(' - Command line: vlc');
|
|
541
|
+
console.log(' - File path: "C:\\Program Files\\VideoLAN\\VLC\\vlc.exe"');
|
|
542
|
+
console.log('');
|
|
543
|
+
console.log('Verify installation with: vlc --version');
|
|
544
|
+
}
|
|
545
|
+
|
|
546
|
+
/**
|
|
547
|
+
* Install VLC on Ubuntu running in WSL (Windows Subsystem for Linux).
|
|
548
|
+
*
|
|
549
|
+
* Prerequisites:
|
|
550
|
+
* - Windows 10 Build 19044 or higher, or Windows 11
|
|
551
|
+
* - WSL 2 enabled with Ubuntu distribution installed
|
|
552
|
+
* - WSLg enabled for GUI application support (Windows 11 or Windows 10 with updates)
|
|
553
|
+
* - sudo privileges within WSL
|
|
554
|
+
*
|
|
555
|
+
* IMPORTANT: VLC is a graphical application. Running VLC in WSL requires
|
|
556
|
+
* GUI support through WSLg (Windows Subsystem for Linux GUI). Windows 11
|
|
557
|
+
* includes WSLg by default. For headless operation, use cvlc or vlc-nox.
|
|
558
|
+
*
|
|
559
|
+
* @returns {Promise<void>}
|
|
560
|
+
* @throws {Error} If installation fails
|
|
561
|
+
*/
|
|
562
|
+
async function install_ubuntu_wsl() {
|
|
563
|
+
console.log('Detected Ubuntu running in WSL (Windows Subsystem for Linux).');
|
|
564
|
+
console.log('');
|
|
565
|
+
console.log('Installing VLC within WSL environment...');
|
|
566
|
+
console.log('');
|
|
567
|
+
|
|
568
|
+
// Check if VLC is already installed
|
|
569
|
+
const isInstalled = await apt.isPackageInstalled(APT_PACKAGE_NAME);
|
|
570
|
+
if (isInstalled) {
|
|
571
|
+
const version = await apt.getPackageVersion(APT_PACKAGE_NAME);
|
|
572
|
+
if (version) {
|
|
573
|
+
console.log(`VLC ${version} is already installed, skipping installation.`);
|
|
574
|
+
} else {
|
|
575
|
+
console.log('VLC is already installed, skipping installation.');
|
|
576
|
+
}
|
|
577
|
+
return;
|
|
578
|
+
}
|
|
579
|
+
|
|
580
|
+
// Update package index before installing
|
|
581
|
+
console.log('Updating package index...');
|
|
582
|
+
const updateResult = await shell.exec('sudo DEBIAN_FRONTEND=noninteractive apt-get update -y');
|
|
583
|
+
if (updateResult.code !== 0) {
|
|
584
|
+
console.log('Warning: Could not update package index, continuing anyway...');
|
|
585
|
+
}
|
|
586
|
+
|
|
587
|
+
// Install VLC via APT
|
|
588
|
+
console.log('Installing VLC via APT...');
|
|
589
|
+
const installResult = await shell.exec(
|
|
590
|
+
'sudo DEBIAN_FRONTEND=noninteractive apt-get install -y vlc'
|
|
591
|
+
);
|
|
592
|
+
|
|
593
|
+
if (installResult.code !== 0) {
|
|
594
|
+
throw new Error(
|
|
595
|
+
`Failed to install VLC via APT.\n` +
|
|
596
|
+
`Output: ${installResult.stderr}\n\n` +
|
|
597
|
+
`Troubleshooting:\n` +
|
|
598
|
+
` 1. If you see DNS errors, try:\n` +
|
|
599
|
+
` echo "nameserver 8.8.8.8" | sudo tee /etc/resolv.conf\n` +
|
|
600
|
+
` 2. Run 'sudo apt-get update' and retry\n` +
|
|
601
|
+
` 3. Try manual installation: sudo apt-get install vlc`
|
|
602
|
+
);
|
|
603
|
+
}
|
|
604
|
+
|
|
605
|
+
// Verify installation succeeded
|
|
606
|
+
const version = await getVLCVersion();
|
|
607
|
+
if (!version) {
|
|
608
|
+
throw new Error(
|
|
609
|
+
'Installation appeared to complete but VLC was not found.\n\n' +
|
|
610
|
+
'Please try:\n' +
|
|
611
|
+
' 1. Restart your WSL session\n' +
|
|
612
|
+
' 2. Run: vlc --version'
|
|
613
|
+
);
|
|
614
|
+
}
|
|
615
|
+
|
|
616
|
+
console.log(`VLC ${version} installed successfully.`);
|
|
617
|
+
console.log('');
|
|
618
|
+
console.log('WSL NOTES:');
|
|
619
|
+
console.log('');
|
|
620
|
+
console.log('1. GUI support requires WSLg:');
|
|
621
|
+
console.log(' - Windows 11: WSLg is included by default');
|
|
622
|
+
console.log(' - Windows 10: Requires specific builds and updates');
|
|
623
|
+
console.log(' - Test with: vlc &');
|
|
624
|
+
console.log('');
|
|
625
|
+
console.log('2. If you see "cannot open display" errors:');
|
|
626
|
+
console.log(' - Restart WSL: wsl --shutdown (from PowerShell)');
|
|
627
|
+
console.log(' - Then reopen your WSL terminal');
|
|
628
|
+
console.log('');
|
|
629
|
+
console.log('3. For headless operation (streaming/transcoding):');
|
|
630
|
+
console.log(' - Use cvlc: cvlc --no-video /path/to/media.mp4');
|
|
631
|
+
console.log('');
|
|
632
|
+
console.log('4. To access Windows files:');
|
|
633
|
+
console.log(' - cvlc /mnt/c/Users/YourName/Videos/movie.mp4');
|
|
634
|
+
}
|
|
635
|
+
|
|
636
|
+
/**
|
|
637
|
+
* Install VLC from Git Bash on Windows.
|
|
638
|
+
*
|
|
639
|
+
* Git Bash runs in a MinGW environment on Windows. This function installs
|
|
640
|
+
* VLC on the Windows host using Chocolatey via PowerShell interop.
|
|
641
|
+
* Once installed, VLC will be accessible from Git Bash through the Windows PATH.
|
|
642
|
+
*
|
|
643
|
+
* Prerequisites:
|
|
644
|
+
* - Windows 10 or later (64-bit)
|
|
645
|
+
* - Git Bash installed (comes with Git for Windows)
|
|
646
|
+
* - Chocolatey package manager installed on Windows
|
|
647
|
+
* - Administrator privileges
|
|
648
|
+
*
|
|
649
|
+
* @returns {Promise<void>}
|
|
650
|
+
* @throws {Error} If installation fails
|
|
651
|
+
*/
|
|
652
|
+
async function install_gitbash() {
|
|
653
|
+
console.log('Detected Git Bash on Windows.');
|
|
654
|
+
console.log('Installing VLC on the Windows host...');
|
|
655
|
+
console.log('');
|
|
656
|
+
|
|
657
|
+
// Check if VLC is already available
|
|
658
|
+
const existingVersion = await getVLCVersion();
|
|
659
|
+
if (existingVersion) {
|
|
660
|
+
console.log(`VLC ${existingVersion} is already installed, skipping installation.`);
|
|
661
|
+
return;
|
|
662
|
+
}
|
|
663
|
+
|
|
664
|
+
// Check if VLC executable exists in common Windows location
|
|
665
|
+
const vlcExistsResult = await shell.exec('ls "/c/Program Files/VideoLAN/VLC/vlc.exe" 2>/dev/null');
|
|
666
|
+
if (vlcExistsResult.code === 0) {
|
|
667
|
+
console.log('VLC is already installed on Windows, skipping installation.');
|
|
668
|
+
console.log('');
|
|
669
|
+
console.log('If VLC is not in your PATH, add it with:');
|
|
670
|
+
console.log(' echo \'export PATH="$PATH:/c/Program Files/VideoLAN/VLC"\' >> ~/.bashrc');
|
|
671
|
+
console.log(' source ~/.bashrc');
|
|
672
|
+
return;
|
|
673
|
+
}
|
|
674
|
+
|
|
675
|
+
// Install via PowerShell using Chocolatey
|
|
676
|
+
console.log('Installing VLC via Chocolatey...');
|
|
677
|
+
console.log('This may take a few minutes...');
|
|
678
|
+
|
|
679
|
+
const installResult = await shell.exec(
|
|
680
|
+
'powershell.exe -NoProfile -Command "choco install vlc -y"'
|
|
681
|
+
);
|
|
682
|
+
|
|
683
|
+
if (installResult.code !== 0) {
|
|
684
|
+
throw new Error(
|
|
685
|
+
`Failed to install VLC.\n` +
|
|
686
|
+
`Output: ${installResult.stdout || installResult.stderr}\n\n` +
|
|
687
|
+
`Troubleshooting:\n` +
|
|
688
|
+
` 1. Ensure Chocolatey is installed on Windows\n` +
|
|
689
|
+
` 2. Run Git Bash as Administrator and retry\n` +
|
|
690
|
+
` 3. Try installing directly from PowerShell:\n` +
|
|
691
|
+
` choco install vlc -y`
|
|
692
|
+
);
|
|
693
|
+
}
|
|
694
|
+
|
|
695
|
+
console.log('VLC installed successfully.');
|
|
696
|
+
console.log('');
|
|
697
|
+
console.log('Git Bash notes:');
|
|
698
|
+
console.log('');
|
|
699
|
+
console.log('1. Restart Git Bash or run: source ~/.bashrc');
|
|
700
|
+
console.log('');
|
|
701
|
+
console.log('2. If vlc is not found, add to PATH:');
|
|
702
|
+
console.log(' echo \'export PATH="$PATH:/c/Program Files/VideoLAN/VLC"\' >> ~/.bashrc');
|
|
703
|
+
console.log(' source ~/.bashrc');
|
|
704
|
+
console.log('');
|
|
705
|
+
console.log('3. To launch VLC:');
|
|
706
|
+
console.log(' vlc &');
|
|
707
|
+
console.log(' # or with full path:');
|
|
708
|
+
console.log(' "/c/Program Files/VideoLAN/VLC/vlc.exe" &');
|
|
709
|
+
console.log('');
|
|
710
|
+
console.log('4. When passing file paths, use Windows-style or double slashes:');
|
|
711
|
+
console.log(' vlc "C:/Users/YourName/Videos/movie.mp4"');
|
|
712
|
+
}
|
|
713
|
+
|
|
714
|
+
/**
|
|
715
|
+
* Check if VLC is installed on the current system.
|
|
716
|
+
* @returns {Promise<boolean>} True if VLC is installed
|
|
717
|
+
*/
|
|
718
|
+
async function isInstalled() {
|
|
719
|
+
const platform = os.detect();
|
|
720
|
+
if (platform.type === 'macos') {
|
|
721
|
+
return brew.isCaskInstalled(HOMEBREW_CASK_NAME);
|
|
722
|
+
}
|
|
723
|
+
if (platform.type === 'windows') {
|
|
724
|
+
return choco.isPackageInstalled(CHOCO_PACKAGE_NAME);
|
|
725
|
+
}
|
|
726
|
+
if (['ubuntu', 'debian', 'raspbian'].includes(platform.type)) {
|
|
727
|
+
return apt.isPackageInstalled(APT_PACKAGE_NAME);
|
|
728
|
+
}
|
|
729
|
+
return isVLCCommandAvailable();
|
|
730
|
+
}
|
|
731
|
+
|
|
732
|
+
/**
|
|
733
|
+
* Check if this installer is supported on the current platform.
|
|
734
|
+
* VLC is supported on all major platforms.
|
|
735
|
+
* @returns {boolean} True if installation is supported on this platform
|
|
736
|
+
*/
|
|
737
|
+
function isEligible() {
|
|
738
|
+
const platform = os.detect();
|
|
739
|
+
|
|
740
|
+
// First check if the platform is supported
|
|
741
|
+
const supportedPlatforms = ['macos', 'ubuntu', 'debian', 'wsl', 'raspbian', 'amazon_linux', 'rhel', 'fedora', 'windows', 'gitbash'];
|
|
742
|
+
if (!supportedPlatforms.includes(platform.type)) {
|
|
743
|
+
return false;
|
|
744
|
+
}
|
|
745
|
+
|
|
746
|
+
// This installer requires a desktop environment
|
|
747
|
+
if (REQUIRES_DESKTOP && !os.isDesktopAvailable()) {
|
|
748
|
+
return false;
|
|
749
|
+
}
|
|
750
|
+
|
|
751
|
+
return true;
|
|
752
|
+
}
|
|
753
|
+
|
|
754
|
+
/**
|
|
755
|
+
* Main installation entry point.
|
|
756
|
+
*
|
|
757
|
+
* Detects the current platform and runs the appropriate installer function.
|
|
758
|
+
* Handles platform-specific mappings to ensure all supported platforms
|
|
759
|
+
* have appropriate installation logic.
|
|
760
|
+
*
|
|
761
|
+
* Supported platforms:
|
|
762
|
+
* - macOS: VLC via Homebrew cask
|
|
763
|
+
* - Ubuntu/Debian: VLC via APT
|
|
764
|
+
* - Raspberry Pi OS: VLC via APT
|
|
765
|
+
* - Amazon Linux/RHEL: VLC via DNF/YUM with RPM Fusion
|
|
766
|
+
* - Windows: VLC via Chocolatey
|
|
767
|
+
* - WSL (Ubuntu): VLC via APT within WSL
|
|
768
|
+
* - Git Bash: VLC on Windows host via Chocolatey
|
|
12
769
|
*
|
|
13
770
|
* @returns {Promise<void>}
|
|
14
771
|
*/
|
|
15
772
|
async function install() {
|
|
16
773
|
const platform = os.detect();
|
|
17
774
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
|
|
775
|
+
// Map platform types to their installer functions
|
|
776
|
+
// This mapping handles aliases (e.g., debian maps to ubuntu installer)
|
|
777
|
+
const installers = {
|
|
778
|
+
'macos': install_macos,
|
|
779
|
+
'ubuntu': install_ubuntu,
|
|
780
|
+
'debian': install_ubuntu,
|
|
781
|
+
'wsl': install_ubuntu_wsl,
|
|
782
|
+
'raspbian': install_raspbian,
|
|
783
|
+
'amazon_linux': install_amazon_linux,
|
|
784
|
+
'rhel': install_amazon_linux,
|
|
785
|
+
'fedora': install_amazon_linux,
|
|
786
|
+
'windows': install_windows,
|
|
787
|
+
'gitbash': install_gitbash
|
|
788
|
+
};
|
|
789
|
+
|
|
790
|
+
const installer = installers[platform.type];
|
|
791
|
+
|
|
792
|
+
if (!installer) {
|
|
793
|
+
console.log(`VLC is not available for ${platform.type}.`);
|
|
794
|
+
return;
|
|
795
|
+
}
|
|
796
|
+
|
|
797
|
+
await installer();
|
|
798
|
+
}
|
|
799
|
+
|
|
800
|
+
// Export all functions for use as a module and for testing
|
|
801
|
+
module.exports = {
|
|
802
|
+
REQUIRES_DESKTOP,
|
|
803
|
+
install,
|
|
804
|
+
isInstalled,
|
|
805
|
+
isEligible,
|
|
806
|
+
install_macos,
|
|
807
|
+
install_ubuntu,
|
|
808
|
+
install_ubuntu_wsl,
|
|
809
|
+
install_raspbian,
|
|
810
|
+
install_amazon_linux,
|
|
811
|
+
install_windows,
|
|
812
|
+
install_gitbash
|
|
813
|
+
};
|
|
41
814
|
|
|
815
|
+
// Allow direct execution: node vlc.js
|
|
42
816
|
if (require.main === module) {
|
|
43
|
-
install()
|
|
817
|
+
install().catch(err => {
|
|
818
|
+
console.error(err.message);
|
|
819
|
+
process.exit(1);
|
|
820
|
+
});
|
|
44
821
|
}
|