AV1Master/client.sh

132 lines
3.6 KiB
Bash
Raw Normal View History

2020-03-27 01:50:01 +01:00
#! /usr/bin/env nix-shell
#! nix-shell -i bash -p bash curl jq libaom ffmpeg-full
set -euo pipefail
IFS=$'\n\t'
2020-03-27 08:43:19 +01:00
base_url="$1"
2020-03-28 02:55:31 +01:00
version="0.2.0"
2020-03-27 01:50:01 +01:00
while true; do
2020-03-27 09:40:55 +01:00
sleep 30
2020-03-28 21:59:39 +01:00
set +e
2020-03-27 01:50:01 +01:00
upsteam_version=`curl -s "$base_url"/version`
2020-03-28 21:59:39 +01:00
retval=$?
set -e
if [ $retval -ne 0 ]; then
echo "Is the Job Server Down?"
continue
fi
2020-03-27 01:50:01 +01:00
if [[ $version != $upsteam_version ]]; then
2020-03-28 21:59:39 +01:00
echo "Wrong version: client version is $version, while job server requires $upstream_version"
2020-03-27 01:50:01 +01:00
break
fi
2020-03-28 21:59:39 +01:00
set +e
2020-03-27 01:50:01 +01:00
job=`curl -s "$base_url"/request_job | jq`
2020-03-28 21:59:39 +01:00
retval=$?
set -e
if [[ $job = "null" ]] || [ $retval -ne 0 ]; then
2020-03-27 01:50:01 +01:00
echo "No Jobs Available ¯\_(ツ)_/¯"
continue
fi
echo "Got new job!"
echo "$job" | jq
job_id=`echo "$job" | jq -r .id`
echo "Reserving Job"
2020-03-28 21:59:39 +01:00
set +e
2020-03-27 01:50:01 +01:00
curl -s "$base_url"/edit_status/"$job_id"/reserved
2020-03-28 21:59:39 +01:00
retval=$?
set -e
if [ $retval -ne 0 ]; then
echo "Is the Job Server Down?"
continue
fi
echo "Reserved!"
2020-03-27 01:50:01 +01:00
source=`echo $job | jq -r .description.file_url`
sourceext=${source##*.}
echo "Downloading source file: $source"
source=`echo $job | jq -r .description.file_url`
name=`echo $job | jq -r .description.file_name`
input="$name.$job_id.$sourceext"
2020-03-28 21:59:39 +01:00
set +e
2020-03-27 01:50:01 +01:00
curl "$source" -o "$input"
2020-03-28 21:59:39 +01:00
retval=$?
set -e
if [ $retval -ne 0 ]; then
echo "Could not Download file!"
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
continue
fi
2020-03-27 01:50:01 +01:00
echo ""
echo "Starting Encode"
2020-03-28 21:59:39 +01:00
height=`echo $job | jq -r .description.resolution[0]`
width=`echo $job | jq -r .description.resolution[1]`
echo $job | jq
2020-03-28 02:55:31 +01:00
aomenco=`echo $job | jq -r .description.options.aomenc`
aomenco=${aomenco//[^a-zA-Z0-9_\- =]/}
ffmpego=`echo $job | jq -r .description.options.ffmpeg`
ffmpego=${ffmpego//[^a-zA-Z0-9_\- =:]/}
two_pass=`echo $job | jq -r .description.options.two_pass`
if [[ $two_pass = true ]]; then
2020-03-28 21:59:39 +01:00
set +e
2020-03-28 02:55:31 +01:00
eval 'ffmpeg -nostats -hide_banner -loglevel warning \
2020-03-28 21:59:39 +01:00
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt yuv422p -f yuv4mpegpipe - | aomenc - --i422 '$aomenco' \
2020-03-28 02:55:31 +01:00
--pass=1 --passes=2 --fpf="'$input'.fpf" --webm -o "'$input'.out.webm"'
2020-03-28 21:59:39 +01:00
retval=$?
if [ $retval -ne 0 ]; then
echo "Error running encode pass 1"
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
echo ""
continue
fi
2020-03-28 02:55:31 +01:00
eval 'ffmpeg -nostats -hide_banner -loglevel warning \
2020-03-28 21:59:39 +01:00
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt yuv422p -f yuv4mpegpipe - | aomenc - --i422 '$aomenco' \
--pass=2 --passes=2 --fpf="'$input'.fpf" --webm -o "'$input'.out.webm"'
retval=$?
if [ $retval -ne 0 ]; then
echo "Error running encode pass 2"
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
echo ""
continue
fi
set -e
2020-03-28 02:55:31 +01:00
else
2020-03-28 21:59:39 +01:00
set +e
2020-03-28 02:55:31 +01:00
eval 'ffmpeg -nostats -hide_banner -loglevel warning \
2020-03-28 21:59:39 +01:00
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt yuv422p -f yuv4mpegpipe - | aomenc - --i422 '$aomenco' \
--passes=1 --fpf="'$input'.fpf" --webm -o "'$input'.out.webm"'
retval=$?
if [ $retval -ne 0 ]; then
echo "Error running encode"
curl -s -L "$base_url"/edit_status/"$job_id"/error || true
echo ""
continue
fi
set -e
2020-03-28 02:55:31 +01:00
fi
2020-03-27 01:50:01 +01:00
2020-03-28 21:59:39 +01:00
set +e
2020-03-27 08:43:19 +01:00
curl -s -L "$base_url"/edit_status/"$job_id"/completed
2020-03-28 21:59:39 +01:00
set -e
2020-03-27 08:43:19 +01:00
2020-03-27 01:50:01 +01:00
done