openvidu-recording Docker container v2.0.1

pull/73/head
pabloFuente 2018-05-22 19:17:13 +02:00
parent d10ea93b03
commit 0dcc77b0c5
4 changed files with 70 additions and 52 deletions

View File

@ -8,26 +8,38 @@ if [[ $CURRENT_UID != $USER_ID ]]; then
adduser --uid $USER_ID --disabled-password --gecos "" myuser adduser --uid $USER_ID --disabled-password --gecos "" myuser
fi fi
URL="${URL:-https://www.youtube.com/watch?v=JMuzlEQz3uo}" URL=${URL:-https://www.youtube.com/watch?v=JMuzlEQz3uo}
RESOLUTION="${RESOLUTION:-1920x1080}" RESOLUTION=${RESOLUTION:-1920x1080}
FRAMERATE="${FRAMERATE:-24}" FRAMERATE=${FRAMERATE:-24}
VIDEO_SIZE="$RESOLUTION" VIDEO_SIZE=$RESOLUTION
ARRAY=(${VIDEO_SIZE//x/ }) ARRAY=(${VIDEO_SIZE//x/ })
VIDEO_ID="${VIDEO_ID:-video}" VIDEO_ID=${VIDEO_ID:-video}
VIDEO_NAME="${VIDEO_NAME:-video}" VIDEO_NAME=${VIDEO_NAME:-video}
VIDEO_FORMAT="${VIDEO_FORMAT:-mp4}" VIDEO_FORMAT=${VIDEO_FORMAT:-mp4}
RECORDING_JSON="'${RECORDING_JSON}'" RECORDING_JSON="${RECORDING_JSON}"
export URL
export RESOLUTION
export FRAMERATE
export VIDEO_SIZE
export ARRAY
export VIDEO_ID
export VIDEO_NAME
export VIDEO_FORMAT
export RECORDING_JSON
### Store Recording json data ### ### Store Recording json data ###
function1() {
echo $RECORDING_JSON > /recordings/.recording.$VIDEO_ID
}
export -f function1
if [[ $CURRENT_UID != $USER_ID ]]; then if [[ $CURRENT_UID != $USER_ID ]]; then
su myuser -c "echo ${RECORDING_JSON} > /recordings/.recording.${VIDEO_ID}" su myuser -c "bash -c function1"
else else
echo ${RECORDING_JSON} > /recordings/.recording.${VIDEO_ID} function1
fi fi
### Get a free display identificator ### ### Get a free display identificator ###
DISPLAY_NUM=99 DISPLAY_NUM=99
@ -46,16 +58,22 @@ do
fi fi
done done
export DISPLAY_NUM
echo "First available display -> :$DISPLAY_NUM" echo "First available display -> :$DISPLAY_NUM"
echo "----------------------------------------" echo "----------------------------------------"
### Start pulseaudio ### ### Start pulseaudio ###
function2() {
pulseaudio -D
}
export -f function2
if [[ $CURRENT_UID != $USER_ID ]]; then if [[ $CURRENT_UID != $USER_ID ]]; then
su myuser -c "pulseaudio -D" su myuser -c "bash -c function2"
else else
pulseaudio -D function2
fi fi
@ -64,10 +82,14 @@ fi
touch xvfb.log touch xvfb.log
chmod 777 xvfb.log chmod 777 xvfb.log
function3() {
xvfb-run --server-num=${DISPLAY_NUM} --server-args="-ac -screen 0 ${RESOLUTION}x24 -noreset" google-chrome -no-sandbox -test-type -disable-infobars -window-size=${ARRAY[0]},${ARRAY[1]} -no-first-run -ignore-certificate-errors --kiosk $URL &> xvfb.log &
}
export -f function3
if [[ $CURRENT_UID != $USER_ID ]]; then if [[ $CURRENT_UID != $USER_ID ]]; then
su myuser -c "xvfb-run --server-num=${DISPLAY_NUM} --server-args='-ac -screen 0 ${RESOLUTION}x24 -noreset' google-chrome -no-sandbox -test-type -disable-infobars -window-size=${ARRAY[0]},${ARRAY[1]} -no-first-run -ignore-certificate-errors --kiosk $URL &> xvfb.log &" su myuser -c "bash -c function3"
else else
xvfb-run --server-num=${DISPLAY_NUM} --server-args="-ac -screen 0 ${RESOLUTION}x24 -noreset" google-chrome -no-sandbox -test-type -disable-infobars -window-size=${ARRAY[0]},${ARRAY[1]} -no-first-run -ignore-certificate-errors --kiosk $URL &> xvfb.log & function3
fi fi
touch stop touch stop
@ -78,51 +100,47 @@ sleep 2
### Start recording with ffmpeg ### ### Start recording with ffmpeg ###
function4() {
<./stop ffmpeg -y -f alsa -i pulse -f x11grab -framerate 25 -video_size $RESOLUTION -i :$DISPLAY_NUM -c:a libfdk_aac -c:v libx264 -preset ultrafast -crf 28 -refs 4 -qmin 4 -pix_fmt yuv420p -filter:v fps=25 "/recordings/$VIDEO_NAME.$VIDEO_FORMAT"
}
export -f function4
if [[ $CURRENT_UID != $USER_ID ]]; then if [[ $CURRENT_UID != $USER_ID ]]; then
su myuser -c "<./stop ffmpeg -y -f alsa -i pulse -f x11grab -framerate 25 -video_size $RESOLUTION -i :${DISPLAY_NUM} -c:a libfdk_aac -c:v libx264 -preset ultrafast -crf 28 -refs 4 -qmin 4 -pix_fmt yuv420p -filter:v fps=25 '/recordings/${VIDEO_NAME}.${VIDEO_FORMAT}'" su myuser -c "bash -c function4"
else else
<./stop ffmpeg -y -f alsa -i pulse -f x11grab -framerate 25 -video_size $RESOLUTION -i :${DISPLAY_NUM} -c:a libfdk_aac -c:v libx264 -preset ultrafast -crf 28 -refs 4 -qmin 4 -pix_fmt yuv420p -filter:v fps=25 "/recordings/${VIDEO_NAME}.${VIDEO_FORMAT}" function4
fi fi
### Generate video report file ### ### Generate video report file ###
function5() {
ffprobe -v quiet -print_format json -show_format -show_streams /recordings/$VIDEO_NAME.$VIDEO_FORMAT > /recordings/$VIDEO_ID.info
}
export -f function5
if [[ $CURRENT_UID != $USER_ID ]]; then if [[ $CURRENT_UID != $USER_ID ]]; then
su myuser -c "ffprobe -v quiet -print_format json -show_format -show_streams /recordings/${VIDEO_NAME}.${VIDEO_FORMAT} > /recordings/${VIDEO_ID}.info" su myuser -c "bash -c function5"
else else
ffprobe -v quiet -print_format json -show_format -show_streams /recordings/${VIDEO_NAME}.${VIDEO_FORMAT} > /recordings/${VIDEO_ID}.info function5
fi fi
### Update Recording json data ### ### Update Recording json data ###
function6() {
TMP=$(mktemp /recordings/.$VIDEO_ID.XXXXXXXXXXXXXXXXXXXXXXX.json)
INFO=$(cat /recordings/$VIDEO_ID.info | jq '.')
HAS_AUDIO_AUX=$(echo $INFO | jq '.streams[] | select(.codec_type == "audio")')
if [ -z "$HAS_AUDIO_AUX" ]; then HAS_AUDIO=false; else HAS_AUDIO=true; fi
HAS_VIDEO_AUX=$(echo $INFO | jq '.streams[] | select(.codec_type == "video")')
if [ -z "$HAS_VIDEO_AUX" ]; then HAS_VIDEO=false; else HAS_VIDEO=true; fi
SIZE=$(echo $INFO | jq '.format.size | tonumber')
DURATION=$(echo $INFO | jq '.format.duration | tonumber')
STATUS="stopped"
jq -c -r ".hasAudio=$HAS_AUDIO | .hasVideo=$HAS_VIDEO | .duration=$DURATION | .size=$SIZE | .status=\"$STATUS\"" "/recordings/.recording.$VIDEO_ID" > $TMP && mv $TMP /recordings/.recording.$VIDEO_ID
}
export -f function6
if [[ $CURRENT_UID != $USER_ID ]]; then if [[ $CURRENT_UID != $USER_ID ]]; then
su myuser -c "bash -c function6"
TMP=$(su myuser -c "mktemp /recordings/.${VIDEO_ID}.XXXXXXXXXXXXXXXXXXXXXXX.if.json")
INFO=$(su myuser -c "cat /recordings/${VIDEO_ID}.info | jq '.'")
HAS_AUDIO_AUX=$(su myuser -c "echo '$INFO' | jq '.streams[] | select(.codec_type == \"audio\")'")
if [ -z "$HAS_AUDIO_AUX" ]; then HAS_AUDIO=false; else HAS_AUDIO=true; fi
HAS_VIDEO_AUX=$(su myuser -c "echo '$INFO' | jq '.streams[] | select(.codec_type == \"video\")'")
if [ -z "$HAS_VIDEO_AUX" ]; then HAS_VIDEO=false; else HAS_VIDEO=true; fi
SIZE=$(su myuser -c "echo '$INFO' | jq '.format.size | tonumber'")
DURATION=$(su myuser -c "echo '$INFO' | jq '.format.duration | tonumber'")
STATUS="stopped"
su myuser -c "jq -c -r \".hasAudio=${HAS_AUDIO} | .hasVideo=${HAS_VIDEO} | .duration=${DURATION} | .size=${SIZE} | .status=\\\"${STATUS}\\\"\" \"/recordings/.recording.${VIDEO_ID}\" > ${TMP} && mv ${TMP} \"/recordings/.recording.${VIDEO_ID}\""
else else
function6
TMP=$(mktemp /recordings/.${VIDEO_ID}.XXXXXXXXXXXXXXXXXXXXXXX.else.json) fi
INFO=$(cat /recordings/${VIDEO_ID}.info | jq '.')
HAS_AUDIO_AUX=$(echo "$INFO" | jq '.streams[] | select(.codec_type == "audio")')
if [ -z "$HAS_AUDIO_AUX" ]; then HAS_AUDIO=false; else HAS_AUDIO=true; fi
HAS_VIDEO_AUX=$(echo "$INFO" | jq '.streams[] | select(.codec_type == "video")')
if [ -z "$HAS_VIDEO_AUX" ]; then HAS_VIDEO=false; else HAS_VIDEO=true; fi
SIZE=$(echo "$INFO" | jq '.format.size | tonumber')
DURATION=$(echo "$INFO" | jq '.format.duration | tonumber')
STATUS="stopped"
jq -c -r ".hasAudio=${HAS_AUDIO} | .hasVideo=${HAS_VIDEO} | .duration=${DURATION} | .size=${SIZE} | .status=\"${STATUS}\"" "/recordings/.recording.${VIDEO_ID}" > ${TMP} && mv ${TMP} "/recordings/.recording.${VIDEO_ID}"
fi

View File

@ -2,7 +2,7 @@ spring.profiles.active=docker
server.address: 0.0.0.0 server.address: 0.0.0.0
server.ssl.enabled: true server.ssl.enabled: true
openvidu.recording.version: 1.8.0 openvidu.recording.version: 2.0.1

View File

@ -1,8 +1,9 @@
spring.profiles.active=ngrok spring.profiles.active=ngrok
server.port: 5000 server.port: 5000
server.ssl.enabled: false
server.address: 0.0.0.0 server.address: 0.0.0.0
server.ssl.enabled: false
openvidu.recording.version: 2.0.1
kms.uris=[\"ws://localhost:8888/kurento\"] kms.uris=[\"ws://localhost:8888/kurento\"]
openvidu.secret: MY_SECRET openvidu.secret: MY_SECRET
@ -10,5 +11,4 @@ openvidu.publicurl: ngrok
openvidu.cdr: false openvidu.cdr: false
openvidu.recording: false openvidu.recording: false
openvidu.recording.path: /opt/openvidu/recordings openvidu.recording.path: /opt/openvidu/recordings
openvidu.recording.public-access: false openvidu.recording.public-access: false
openvidu.recording.version: 1.8.0

View File

@ -1,6 +1,6 @@
server.address: 0.0.0.0 server.address: 0.0.0.0
server.ssl.enabled: true server.ssl.enabled: true
openvidu.recording.version: 2.0.0 openvidu.recording.version: 2.0.1