AV1Master/src/static/client.sh

171 lines
4.5 KiB
Bash
Raw Normal View History

#! /usr/bin/env bash
2020-03-27 01:50:01 +01:00
set -euo pipefail
IFS=$'\n\t'
base_url="https://av1.dodsorf.as"
2020-04-20 09:20:07 +02:00
version="0.5.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
upstream_version=`curl -L -f -s "$base_url"/version`
2020-03-28 21:59:39 +01:00
retval=$?
set -e
if [ $retval -ne 0 ]; then
echo "Error: $retval"
echo ""
2020-03-28 21:59:39 +01:00
echo "Is the Job Server Down?"
continue
fi
2020-04-20 10:11:04 +02:00
if [[ $version != $upstream_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!"
2020-03-30 23:53:22 +02:00
echo "$job" | jq
2020-03-27 01:50:01 +01:00
2020-03-30 23:53:22 +02:00
job_id=`echo "$job" | jq -r .id`
2020-03-27 01:50:01 +01:00
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
2020-03-30 23:53:22 +02:00
source=`echo $job | jq -r .description.file_url`
2020-03-27 01:50:01 +01:00
sourceext=${source##*.}
echo "Downloading source file: $source"
2020-03-30 23:53:22 +02:00
source=`echo $job | jq -r .description.file_url`
2020-03-27 01:50:01 +01:00
2020-03-30 23:53:22 +02:00
name=`echo $job | jq -r .description.file_name`
2020-03-27 01:50:01 +01:00
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-30 23:53:22 +02:00
height=`echo $job | jq -r .description.resolution[0]`
width=`echo $job | jq -r .description.resolution[1]`
2020-03-28 21:59:39 +01:00
2020-03-30 23:53:22 +02:00
echo $job | jq
2020-03-28 21:59:39 +01:00
2020-03-30 23:53:22 +02:00
aomenco=`echo $job | jq -r .description.options.aomenc`
2020-03-28 02:55:31 +01:00
aomenco=${aomenco//[^a-zA-Z0-9_\- =]/}
2020-03-30 23:53:22 +02:00
ffmpego=`echo $job | jq -r .description.options.ffmpeg`
2020-03-28 02:55:31 +01:00
ffmpego=${ffmpego//[^a-zA-Z0-9_\- =:]/}
2020-04-01 01:10:15 +02:00
pix_fmt=`echo $job | jq -r .description.options.pix_fmt`
if [[ $pix_fmt = "YV12" ]]; then
ffpix="yv12p"
aompix="--yv12"
elif [[ $pix_fmt = "I420" ]]; then
ffpix="yv420p"
aompix="--i420"
elif [[ $pix_fmt = I422 ]]; then
ffpix="yv422p"
aompix="--i422"
elif [[ $pix_fmt = I444 ]]; then
ffpix="yv444p"
aompix="--i444"
fi
2020-03-30 23:53:22 +02:00
two_pass=`echo $job | jq -r .description.options.two_pass`
2020-03-28 02:55:31 +01:00
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-04-01 01:10:15 +02:00
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt '$ffpix' -f yuv4mpegpipe - | aomenc - '$aompix' '$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-04-01 01:10:15 +02:00
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt '$ffpix' -f yuv4mpegpipe - | aomenc - '$aompix' '$aomenco' \
2020-03-28 21:59:39 +01:00
--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-04-01 15:45:56 +02:00
echo "Deleting Source and Temporary files"
rm "$input" "$input".fpf
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-04-01 01:10:15 +02:00
-i "'$input'" '$ffmpego' -vf scale='$height':'$width' -pix_fmt '$ffpix' -f yuv4mpegpipe - | aomenc - '$aompix' '$aomenco' \
2020-03-28 21:59:39 +01:00
--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-04-01 15:45:56 +02:00
echo "Deleting Source"
rm "$input"
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-30 23:53:22 +02:00
echo "Uploading file!"
set +e
curl --data-binary @"$input".out.webm "$base_url"/upload/"$job_id"
set -e
retval=$?
2020-03-30 19:43:37 +02:00
echo ""
2020-03-30 23:53:22 +02:00
if [ $retval -ne 0 ]; then
echo "Couldn't upload file!"
continue
else
echo "Upload finished, deleting result!"
rm "$input".out.webm
fi
2020-03-30 19:43:37 +02:00
2020-03-27 01:50:01 +01:00
done