mirror of https://github.com/OpenVidu/openvidu.git
openvidu-recording Docker container v2.0.1
parent
d10ea93b03
commit
0dcc77b0c5
|
@ -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
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue