mirror of
https://github.com/Ld-Hagen/fix-opera-linux-ffmpeg-widevine.git
synced 2025-12-29 11:33:00 +03:00
Compare commits
16 Commits
nwjs-ffmpe
...
nwjs-ffmpe
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
423c8ea9ec | ||
|
|
e0e13e6cb1 | ||
|
|
0883b15800 | ||
|
|
927444aaaa | ||
|
|
5fbd2e216e | ||
|
|
e06398b956 | ||
|
|
4b4541cd59 | ||
|
|
a850c9bb5c | ||
|
|
40513adc42 | ||
|
|
8d56cf17dd | ||
|
|
976ea8fb35 | ||
|
|
8dba65eec6 | ||
|
|
b77acfb324 | ||
|
|
59dc39dfbc | ||
|
|
96dcbff82e | ||
|
|
5f3fa8273a |
@@ -105,7 +105,7 @@ while read CREATE_HOOK; do
|
|||||||
"n" | "N")
|
"n" | "N")
|
||||||
break;;
|
break;;
|
||||||
* )
|
* )
|
||||||
printf "Would you like to create an alias for user $USER_NAME? [y/n]"
|
printf "Would you like to run it automatically after each Opera update?? [y/n]"
|
||||||
continue;;
|
continue;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -20,27 +20,35 @@ if ! which wget > /dev/null; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if which pacman > /dev/null; then
|
||||||
|
ARCH_SYSTEM=true
|
||||||
|
fi
|
||||||
|
|
||||||
#Config section
|
#Config section
|
||||||
readonly FIX_WIDEVINE=true
|
readonly FIX_WIDEVINE=true
|
||||||
readonly TEMP_DIR='/tmp'
|
readonly TEMP_DIR='/tmp'
|
||||||
readonly FFMPEG_SRC_MAIN='https://api.github.com/repos/iteufel/nwjs-ffmpeg-prebuilt/releases'
|
readonly FFMPEG_SRC_MAIN='https://api.github.com/repos/Ld-Hagen/nwjs-ffmpeg-prebuilt/releases'
|
||||||
readonly FFMPEG_SRC_ALT='https://api.github.com/repos/Ld-Hagen/fix-opera-linux-ffmpeg-widevine/releases'
|
readonly FFMPEG_SRC_ALT='https://api.github.com/repos/Ld-Hagen/fix-opera-linux-ffmpeg-widevine/releases'
|
||||||
readonly WIDEVINE_VERSIONS='https://dl.google.com/widevine-cdm/versions.txt'
|
readonly WIDEVINE_VERSIONS='https://dl.google.com/widevine-cdm/versions.txt'
|
||||||
readonly FFMPEG_SO_NAME='libffmpeg.so'
|
readonly FFMPEG_SO_NAME='libffmpeg.so'
|
||||||
readonly WIDEVINE_SO_NAME='libwidevinecdm.so'
|
readonly WIDEVINE_SO_NAME='libwidevinecdm.so'
|
||||||
readonly WIDEVINE_MANIFEST_NAME='manifest.json'
|
readonly WIDEVINE_MANIFEST_NAME='manifest.json'
|
||||||
|
|
||||||
readonly OPERA_DIR=$(dirname $(readlink -f $(which opera)))
|
OPERA_VERSIONS=()
|
||||||
readonly OPERA_LIB_DIR="$OPERA_DIR/lib_extra"
|
|
||||||
readonly OPERA_WIDEVINE_DIR="$OPERA_LIB_DIR/WidevineCdm"
|
if [ -x "$(command -v opera)" ]; then
|
||||||
readonly OPERA_WIDEVINE_SO_DIR="$OPERA_WIDEVINE_DIR/_platform_specific/linux_x64"
|
OPERA_VERSIONS+=("opera")
|
||||||
readonly OPERA_WIDEVINE_CONFIG="$OPERA_DIR/resources/widevine_config.json"
|
fi
|
||||||
|
|
||||||
|
if [ -x "$(command -v opera-beta)" ]; then
|
||||||
|
OPERA_VERSIONS+=("opera-beta")
|
||||||
|
fi
|
||||||
|
|
||||||
#Getting download links
|
#Getting download links
|
||||||
printf 'Getting download links...\n'
|
printf 'Getting download links...\n'
|
||||||
##ffmpeg
|
##ffmpeg
|
||||||
readonly FFMPEG_URL_MAIN=$(wget -qO - $FFMPEG_SRC_MAIN | grep browser_download_url | cut -d '"' -f 4 | grep linux-x64 | head -n 1)
|
readonly FFMPEG_URL_MAIN=$(wget -q4O - $FFMPEG_SRC_MAIN | grep browser_download_url | cut -d '"' -f 4 | grep linux-x64 | head -n 1)
|
||||||
readonly FFMPEG_URL_ALT=$(wget -qO - $FFMPEG_SRC_ALT | grep browser_download_url | cut -d '"' -f 4 | grep linux-x64 | head -n 1)
|
readonly FFMPEG_URL_ALT=$(wget -q4O - $FFMPEG_SRC_ALT | grep browser_download_url | cut -d '"' -f 4 | grep linux-x64 | head -n 1)
|
||||||
[[ $(basename $FFMPEG_URL_ALT) < $(basename $FFMPEG_URL_MAIN) ]] && readonly FFMPEG_URL=$FFMPEG_URL_MAIN || readonly FFMPEG_URL=$FFMPEG_URL_ALT
|
[[ $(basename $FFMPEG_URL_ALT) < $(basename $FFMPEG_URL_MAIN) ]] && readonly FFMPEG_URL=$FFMPEG_URL_MAIN || readonly FFMPEG_URL=$FFMPEG_URL_ALT
|
||||||
if [[ -z $FFMPEG_URL ]]; then
|
if [[ -z $FFMPEG_URL ]]; then
|
||||||
printf 'Failed to get ffmpeg download URL. Exiting...\n'
|
printf 'Failed to get ffmpeg download URL. Exiting...\n'
|
||||||
@@ -49,7 +57,7 @@ fi
|
|||||||
|
|
||||||
##Widevine
|
##Widevine
|
||||||
if $FIX_WIDEVINE; then
|
if $FIX_WIDEVINE; then
|
||||||
readonly WIDEVINE_LATEST=`wget -qO - $WIDEVINE_VERSIONS | tail -n1`
|
readonly WIDEVINE_LATEST=`wget -q4O - $WIDEVINE_VERSIONS | tail -n1`
|
||||||
readonly WIDEVINE_URL="https://dl.google.com/widevine-cdm/$WIDEVINE_LATEST-linux-x64.zip"
|
readonly WIDEVINE_URL="https://dl.google.com/widevine-cdm/$WIDEVINE_LATEST-linux-x64.zip"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -57,14 +65,14 @@ fi
|
|||||||
printf 'Downloading files...\n'
|
printf 'Downloading files...\n'
|
||||||
mkdir -p "$TEMP_DIR/opera-fix"
|
mkdir -p "$TEMP_DIR/opera-fix"
|
||||||
##ffmpeg
|
##ffmpeg
|
||||||
wget -q --show-progress $FFMPEG_URL -O "$TEMP_DIR/opera-fix/ffmpeg.zip"
|
wget -q4 --show-progress $FFMPEG_URL -O "$TEMP_DIR/opera-fix/ffmpeg.zip"
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
printf 'Failed to download ffmpeg. Check your internet connection or try later\n'
|
printf 'Failed to download ffmpeg. Check your internet connection or try later\n'
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
##Widevine
|
##Widevine
|
||||||
if $FIX_WIDEVINE; then
|
if $FIX_WIDEVINE; then
|
||||||
wget -q --show-progress "$WIDEVINE_URL" -O "$TEMP_DIR/opera-fix/widevine.zip"
|
wget -q4 --show-progress "$WIDEVINE_URL" -O "$TEMP_DIR/opera-fix/widevine.zip"
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
printf 'Failed to download Widevine CDM. Check your internet connection or try later\n'
|
printf 'Failed to download Widevine CDM. Check your internet connection or try later\n'
|
||||||
exit 1
|
exit 1
|
||||||
@@ -80,6 +88,19 @@ if $FIX_WIDEVINE; then
|
|||||||
unzip -o "$TEMP_DIR/opera-fix/widevine.zip" -d $TEMP_DIR/opera-fix > /dev/null
|
unzip -o "$TEMP_DIR/opera-fix/widevine.zip" -d $TEMP_DIR/opera-fix > /dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
for opera in ${OPERA_VERSIONS[@]}; do
|
||||||
|
echo "Doing $opera"
|
||||||
|
EXECUTABLE=$(command -v "$opera")
|
||||||
|
if [[ $ARCH_SYSTEM -eq true ]]; then
|
||||||
|
OPERA_DIR=$(dirname $(cat $EXECUTABLE | grep exec | cut -d ' ' -f 2))
|
||||||
|
else
|
||||||
|
OPERA_DIR=$(dirname $(readlink -f $EXECUTABLE))
|
||||||
|
fi
|
||||||
|
OPERA_LIB_DIR="$OPERA_DIR/lib_extra"
|
||||||
|
OPERA_WIDEVINE_DIR="$OPERA_LIB_DIR/WidevineCdm"
|
||||||
|
OPERA_WIDEVINE_SO_DIR="$OPERA_WIDEVINE_DIR/_platform_specific/linux_x64"
|
||||||
|
OPERA_WIDEVINE_CONFIG="$OPERA_DIR/resources/widevine_config.json"
|
||||||
|
|
||||||
#Removing old libraries and preparing directories
|
#Removing old libraries and preparing directories
|
||||||
printf 'Removing old libraries & making directories...\n'
|
printf 'Removing old libraries & making directories...\n'
|
||||||
##ffmpeg
|
##ffmpeg
|
||||||
@@ -94,16 +115,17 @@ fi
|
|||||||
#Moving libraries to its place
|
#Moving libraries to its place
|
||||||
printf 'Moving libraries to their places...\n'
|
printf 'Moving libraries to their places...\n'
|
||||||
##ffmpeg
|
##ffmpeg
|
||||||
mv -f "$TEMP_DIR/opera-fix/$FFMPEG_SO_NAME" "$OPERA_LIB_DIR"
|
cp -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"
|
||||||
##Widevine
|
##Widevine
|
||||||
if $FIX_WIDEVINE; then
|
if $FIX_WIDEVINE; then
|
||||||
mv -f "$TEMP_DIR/opera-fix/$WIDEVINE_SO_NAME" "$OPERA_WIDEVINE_SO_DIR"
|
cp -f "$TEMP_DIR/opera-fix/$WIDEVINE_SO_NAME" "$OPERA_WIDEVINE_SO_DIR"
|
||||||
chmod 0644 "$OPERA_WIDEVINE_SO_DIR/$WIDEVINE_SO_NAME"
|
chmod 0644 "$OPERA_WIDEVINE_SO_DIR/$WIDEVINE_SO_NAME"
|
||||||
mv -f "$TEMP_DIR/opera-fix/$WIDEVINE_MANIFEST_NAME" "$OPERA_WIDEVINE_DIR"
|
cp -f "$TEMP_DIR/opera-fix/$WIDEVINE_MANIFEST_NAME" "$OPERA_WIDEVINE_DIR"
|
||||||
chmod 0644 "$OPERA_WIDEVINE_DIR/$WIDEVINE_MANIFEST_NAME"
|
chmod 0644 "$OPERA_WIDEVINE_DIR/$WIDEVINE_MANIFEST_NAME"
|
||||||
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
|
||||||
|
done
|
||||||
|
|
||||||
#Removing temporary files
|
#Removing temporary files
|
||||||
printf 'Removing temporary files...\n'
|
printf 'Removing temporary files...\n'
|
||||||
|
|||||||
Reference in New Issue
Block a user