Compare commits

..

6 Commits

Author SHA1 Message Date
Ld-Hagen
58be0f5c1c Readme update, dnf hook fix 2021-10-26 21:57:14 +03:00
Ld-Hagen
52954635c8 Hook for RedHat based systems (using dnf package manager). Untested. 2021-10-26 20:59:59 +03:00
Ld-Hagen
8c64261203 No hardcoded Opera directory in apt hook. Some text messages and readme changes 2021-10-14 18:42:27 +03:00
Ld-Hagen
f73a02813b First run after install. Some fixes 2021-10-06 20:15:57 +03:00
Ld-Hagen
78c9762d17 Dependencies in Arch hhook 2021-09-26 19:56:31 +03:00
Ld-Hagen
c9b8eb396e Dependency check on install. Messages about hook creation. 2021-09-26 19:37:52 +03:00
6 changed files with 81 additions and 28 deletions

View File

@@ -1,35 +1,44 @@
# Fix Opera Linux ffmpeg & WidevineCdm # Fix Opera Linux libffmpeg & WidevineCdm
* Fix Opera html5 media content including DRM-protected one. * Fixes Opera html5 media content including DRM-protected one.
* It script must be execute all times opera will fails on showing html5 media content. * This script must be executed all times opera fails on showing html5 media content.
* On Debian-based and Arch-based distros it may be started automatically after Opera update. * On Debian-based, RedHat-based and Arch-based distributions it could be started automatically after Opera each update or reinstall.
## Requirements ## Requirements
1. **wget** (Is needed for downloading the ffmpeg lib and Chrome) 1. **wget** (Is needed for downloading the ffmpeg lib and widevine)
```sudo apt install wget```
2. **unzip** (Is needed for unpacking the downloaded file) **unzip** (Is needed for unpacking the downloaded file)
```sudo apt install unzip```
**git** (Is needed for fetching this script)
For Debian-based systems: `sudo apt install wget unzip git`
For Arch-based systems: `sudo pacman -S wget unzip git`
For RedHat-based systems: `sudo dnf install wget unzip git`
2. (*Optional*) **python3-dnf-plugin-post-transaction-actions** (Is needed for autoupdate in RedHat-based systems)
`dnf install python3-dnf-plugin-post-transaction-actions`
## Usage ## Usage
1. Clone this repo and 1. Clone this repo
```git clone https://github.com/Ld-Hagen/fix-opera-linux-ffmpeg-widevine.git``` `git clone https://github.com/Ld-Hagen/fix-opera-linux-ffmpeg-widevine.git`
2. Go to the repo root folder 2. Go to the repo root folder
```cd ./fix-opera-linux-ffmpeg-widevine``` `cd ./fix-opera-linux-ffmpeg-widevine`
3. (*Optional*) Run script. And if it works well go to next step. 3. (*Optional*) Run script. And if it works well go to next step.
```sudo ./scripts/fix-opera.sh``` `sudo ./scripts/fix-opera.sh`
4. Run install script and answer few questions. 4. Run install script and answer few questions.
```sudo ./install.sh``` `sudo ./install.sh`
5. Delete the repo 5. Delete the repo
```rm -rf ./fix-opera-linux-ffmpeg-widevine``` `cd .. && rm -rf ./fix-opera-linux-ffmpeg-widevine`

View File

@@ -4,6 +4,21 @@ if [[ $(whoami) != "root" ]]; then
exit 1 exit 1
fi fi
if [[ $(uname -m) != "x86_64" ]]; then
printf 'This script is intended for 64-bit systems\n'
exit 1
fi
if ! which unzip > /dev/null; then
printf '\033[1munzip\033[0m package must be installed to run this script\n'
exit 1
fi
if ! which wget > /dev/null; then
printf '\033[1mwget\033[0m package must be installed to run this script\n'
exit 1
fi
readonly SCRIPT_PATH=$(dirname $(readlink -f $0)) readonly SCRIPT_PATH=$(dirname $(readlink -f $0))
readonly INSTALL_PATH="/root/.scripts" readonly INSTALL_PATH="/root/.scripts"
readonly USER_NAME="$(logname)" readonly USER_NAME="$(logname)"
@@ -14,16 +29,25 @@ create_hook ()
printf 'Choose your Linux distro:\n' printf 'Choose your Linux distro:\n'
printf ' 1. Debian-based (Debian/Ubuntu/Mint/etc.)\n' printf ' 1. Debian-based (Debian/Ubuntu/Mint/etc.)\n'
printf ' 2. Arch-based (Arch/Manjaro/etc.)\n' printf ' 2. Arch-based (Arch/Manjaro/etc.)\n'
printf ' 3. RedHat-based (RedHat/Fedora/etc.)\n'
printf ' 0. Other\n' printf ' 0. Other\n'
while read -p "Your choice: " DISTRIB; do while read -p "Your choice: " DISTRIB; do
case $DISTRIB in case $DISTRIB in
"1" ) "1" )
cp -f $SCRIPT_PATH/scripts/99fix-opera $INSTALL_PATH cp -f $SCRIPT_PATH/scripts/99fix-opera $INSTALL_PATH
ln -sf $INSTALL_PATH/99fix-opera /etc/apt/apt.conf.d/ ln -sf $INSTALL_PATH/99fix-opera /etc/apt/apt.conf.d/
printf 'Now the script will run automatically every time apt installs or updates Opera.\n'
break;; break;;
"2" ) "2" )
cp -f $SCRIPT_PATH/scripts/fix-opera.hook $INSTALL_PATH /usr/share/libalpm/hooks cp -f $SCRIPT_PATH/scripts/fix-opera.hook $INSTALL_PATH
ln -sf $INSTALL_PATH/fix-opera.hook /usr/share/libalpm/hooks/ ln -sf $INSTALL_PATH/fix-opera.hook /usr/share/libalpm/hooks/
printf 'Now the script will run automatically every time pacman installs or updates Opera.\n'
break;;
"3" )
dnf install python3-dnf-plugin-post-transaction-actions -y
cp -f $SCRIPT_PATH/scripts/fix-opera.action $INSTALL_PATH
ln -sf $INSTALL_PATH/fix-opera.action /etc/dnf/plugins/post-transaction-actions.d/
printf 'Now the script will run automatically every time dnf installs or updates Opera.\n'
break;; break;;
"0" ) "0" )
printf "Autostart for your Linux distro is currently unsupported\n" printf "Autostart for your Linux distro is currently unsupported\n"
@@ -34,6 +58,8 @@ create_hook ()
done done
} }
printf 'Installing script to your system...\n'
printf 'Would you like to apply Widevine CDM fix? [y/n]' printf 'Would you like to apply Widevine CDM fix? [y/n]'
while read FIX_WIDEVINE; do while read FIX_WIDEVINE; do
case $FIX_WIDEVINE in case $FIX_WIDEVINE in
@@ -53,6 +79,7 @@ done
mkdir -p $INSTALL_PATH mkdir -p $INSTALL_PATH
cp -f $SCRIPT_PATH/scripts/fix-opera.sh $INSTALL_PATH cp -f $SCRIPT_PATH/scripts/fix-opera.sh $INSTALL_PATH
chmod +x $INSTALL_PATH/fix-opera.sh
printf "Would you like to create an alias for user $USER_NAME? [y/n]" printf "Would you like to create an alias for user $USER_NAME? [y/n]"
while read CREATE_ALIAS; do while read CREATE_ALIAS; do
@@ -83,3 +110,16 @@ while read CREATE_HOOK; do
esac esac
done done
printf "Would you like to run it now? [y/n]"
while read RUN_NOW; do
case $RUN_NOW in
"y" | "Y")
$INSTALL_PATH/fix-opera.sh
break;;
"n" | "N")
break;;
* )
printf "Would you like to run it now? [y/n]"
continue;;
esac
done

View File

@@ -1,2 +1,2 @@
DPkg::Pre-Invoke {"stat -c %Z /usr/lib/x86_64-linux-gnu/opera/opera > /tmp/opera.timestamp";}; DPkg::Pre-Invoke {"stat -c %Z $(readlink -f $(which opera)) > /tmp/opera.timestamp";};
DPkg::Post-Invoke {"if [ `stat -c %Z /usr/lib/x86_64-linux-gnu/opera/opera` -ne `cat /tmp/opera.timestamp` ]; then /root/.scripts/fix-opera.sh; fi; rm /tmp/opera.timestamp";}; DPkg::Post-Invoke {"if [ `stat -c %Z $(readlink -f $(which opera))` -ne `cat /tmp/opera.timestamp` ]; then /root/.scripts/fix-opera.sh; fi; rm /tmp/opera.timestamp";};

1
scripts/fix-opera.action Normal file
View File

@@ -0,0 +1 @@
opera-stable:in:/root/.scripts/fix-opera.sh

View File

@@ -9,4 +9,7 @@ Target = opera
[Action] [Action]
Description = Fix video playback in Opera browser Description = Fix video playback in Opera browser
When = PostTransaction When = PostTransaction
Depends = bash
Depends = wget
Depends = unzip
Exec = /root/.scripts/fix-opera.sh Exec = /root/.scripts/fix-opera.sh

View File

@@ -92,7 +92,7 @@ if $FIX_WIDEVINE; then
fi fi
#Moving libraries to its place #Moving libraries to its place
printf 'Moving libraries to its place...\n' printf 'Moving libraries to their places...\n'
##ffmpeg ##ffmpeg
mv -f "$TEMP_DIR/opera-fix/$FFMPEG_SO_NAME" "$OPERA_LIB_DIR" mv -f "$TEMP_DIR/opera-fix/$FFMPEG_SO_NAME" "$OPERA_LIB_DIR"
chmod 0644 "$OPERA_LIB_DIR/$FFMPEG_SO_NAME" chmod 0644 "$OPERA_LIB_DIR/$FFMPEG_SO_NAME"
@@ -105,6 +105,6 @@ if $FIX_WIDEVINE; then
printf "[\n {\n \"preload\": \"$OPERA_WIDEVINE_DIR\"\n }\n]\n" > "$OPERA_WIDEVINE_CONFIG" printf "[\n {\n \"preload\": \"$OPERA_WIDEVINE_DIR\"\n }\n]\n" > "$OPERA_WIDEVINE_CONFIG"
fi fi
#Removing temprary files #Removing temporary files
printf 'Removing temprary files...\n' printf 'Removing temporary files...\n'
rm -rf "$TEMP_DIR/opera-fix" rm -rf "$TEMP_DIR/opera-fix"