--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [19:17:04.227] Vidbot :: start() [19:17:04.227] Vidbot :: _next(), _stepIndex:0 of 4 [19:17:04.228] index :: _onStepStarted_vidbot(), step: 1 [19:17:04.229] Vidbot :: step[0], label:Initializing Core [19:17:04.238] index :: _onStepProgress_vidbot(), percent: 20 [19:17:04.239] Vidbot :: _parse() [19:17:04.240] index :: _onStepProgress_vidbot(), percent: 40 [19:17:04.240] Vidbot :: _validate() [19:17:04.241] index :: _onStepProgress_vidbot(), percent: 60 [19:17:04.241] Vidbot :: _fonts() [19:17:04.242] FabricFontManager :: add(), id: SourceSansPro-Bold [19:17:04.242] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [19:17:04.250] FabricFontManager :: add(), id: SourceSansPro-Light [19:17:04.250] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [19:17:04.251] FabricFontManager :: add(), id: DINOT-Bold [19:17:04.251] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [19:17:04.252] FabricFontManager :: add(), id: DINOT-Light [19:17:04.252] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [19:17:04.253] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [19:17:04.253] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [19:17:04.254] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [19:17:04.254] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [19:17:04.255] index :: _onStepProgress_vidbot(), percent: 80 [19:17:04.255] Vidbot :: _clips() [19:17:04.256] StreamManager :: add(), id:audio_vo, type:audio [19:17:04.256] AudioClip[audio_vo] :: constructor() [19:17:04.256] InputStream[audio_vo] :: constructor() [19:17:04.256] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [19:17:04.259] StreamManager :: add(), id:bg_music, type:audio [19:17:04.259] AudioClip[bg_music] :: constructor() [19:17:04.259] InputStream[bg_music] :: constructor() [19:17:04.259] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [19:17:04.260] StreamManager :: add(), id:simplefadedisplay, type:canvas [19:17:04.260] CanvasStream[canvas_1005975130741] :: constructor() [19:17:04.260] InputStream[canvas_1005975130741] :: constructor() [19:17:04.344] KenBurnsSlideshow[simplefadedisplay] :: constructor() [19:17:04.344] Overlay[simplefadedisplay] :: constructor() [19:17:04.344] CanvasClip[simplefadedisplay] :: constructor() [19:17:04.344] Clip[simplefadedisplay] :: constructor() [19:17:04.345] clip:"simplefadedisplay" added to stream:"canvas_1005975130741" [19:17:04.345] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1005975130741', clipId: 'simplefadedisplay' } [19:17:04.345] StreamManager :: add(), id:caption, type:canvas [19:17:04.345] RenCaption[caption] :: constructor() [19:17:04.345] Ren[caption] :: constructor() [19:17:04.345] Overlay[caption] :: constructor() [19:17:04.345] CanvasClip[caption] :: constructor() [19:17:04.346] Clip[caption] :: constructor() [19:17:04.346] clip:"caption" added to stream:"canvas_1005975130741" [19:17:04.346] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1005975130741', clipId: 'caption' } [19:17:04.346] all added... [19:17:04.346] Vidbot :: _next(), _stepIndex:1 of 4 [19:17:04.346] index :: _onStepCompleted_vidbot(), step: 1 [19:17:04.347] index :: _onStepStarted_vidbot(), step: 2 [19:17:04.347] Vidbot :: step[1], label:Initializing Input Streams [19:17:04.347] StreamManager :: init() [19:17:04.348] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [19:17:04.348] index :: _onStepProgress_vidbot(), percent: 33 [19:17:04.348] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [19:17:04.348] index :: _onStepProgress_vidbot(), percent: 67 [19:17:04.348] CanvasStream[canvas_1005975130741] :: _init(), BEGIN [19:17:04.349] i:0, c.id:simplefadedisplay [19:17:04.349] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [19:17:04.349] KenBurnsSlideshow[simplefadedisplay] :: _validate() [19:17:04.350] KenBurnsSlideshow[undefined] :: _validateAnim() [19:17:04.350] KenBurnsSlideshow[undefined] :: _validateTheme() [19:17:04.351] i:1, c.id:caption [19:17:04.352] RenCaption[caption] :: _init() [19:17:04.352] RenCaption[caption] :: _validate() [19:17:04.353] KenBurnsSlideshow[simplefadedisplay] :: _build() [19:17:04.360] AnimatedImageFrame[aif] :: constructor() [19:17:04.361] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.361] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_1.jpg [19:17:04.374] RenCaption[caption] :: _build() [19:17:04.391] Overlay[caption] :: _animate() [19:17:04.394] CanvasStream[caption] :: _init(), p.then() [19:17:04.410] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.414] AnimatedImageFrame[aif] :: _init(), END [19:17:04.415] AnimatedImageFrame[aif] :: constructor() [19:17:04.416] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.416] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_2.jpg [19:17:04.432] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.433] AnimatedImageFrame[aif] :: _init(), END [19:17:04.434] AnimatedImageFrame[aif] :: constructor() [19:17:04.434] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.434] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_3.jpg [19:17:04.446] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.447] AnimatedImageFrame[aif] :: _init(), END [19:17:04.448] AnimatedImageFrame[aif] :: constructor() [19:17:04.448] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.448] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_4.jpg [19:17:04.459] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.460] AnimatedImageFrame[aif] :: _init(), END [19:17:04.461] AnimatedImageFrame[aif] :: constructor() [19:17:04.461] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.461] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_1.jpg [19:17:04.472] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.473] AnimatedImageFrame[aif] :: _init(), END [19:17:04.474] AnimatedImageFrame[aif] :: constructor() [19:17:04.474] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.474] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_2.jpg [19:17:04.485] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.486] AnimatedImageFrame[aif] :: _init(), END [19:17:04.487] AnimatedImageFrame[aif] :: constructor() [19:17:04.487] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.487] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_3.jpg [19:17:04.498] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.499] AnimatedImageFrame[aif] :: _init(), END [19:17:04.499] AnimatedImageFrame[aif] :: constructor() [19:17:04.500] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.500] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_4.jpg [19:17:04.511] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.512] AnimatedImageFrame[aif] :: _init(), END [19:17:04.512] AnimatedImageFrame[aif] :: constructor() [19:17:04.512] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.512] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_1.jpg [19:17:04.524] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.524] AnimatedImageFrame[aif] :: _init(), END [19:17:04.525] AnimatedImageFrame[aif] :: constructor() [19:17:04.525] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.525] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_2.jpg [19:17:04.536] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.537] AnimatedImageFrame[aif] :: _init(), END [19:17:04.537] AnimatedImageFrame[aif] :: constructor() [19:17:04.538] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.538] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_3.jpg [19:17:04.549] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.550] AnimatedImageFrame[aif] :: _init(), END [19:17:04.550] AnimatedImageFrame[aif] :: constructor() [19:17:04.550] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.550] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_4.jpg [19:17:04.561] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.562] AnimatedImageFrame[aif] :: _init(), END [19:17:04.563] AnimatedImageFrame[aif] :: constructor() [19:17:04.563] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.563] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_1.jpg [19:17:04.574] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.575] AnimatedImageFrame[aif] :: _init(), END [19:17:04.576] AnimatedImageFrame[aif] :: constructor() [19:17:04.576] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.576] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_2.jpg [19:17:04.587] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.588] AnimatedImageFrame[aif] :: _init(), END [19:17:04.588] AnimatedImageFrame[aif] :: constructor() [19:17:04.588] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.588] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_3.jpg [19:17:04.600] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.600] AnimatedImageFrame[aif] :: _init(), END [19:17:04.601] AnimatedImageFrame[aif] :: constructor() [19:17:04.601] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.601] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_4.jpg [19:17:04.612] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.613] AnimatedImageFrame[aif] :: _init(), END [19:17:04.613] AnimatedImageFrame[aif] :: constructor() [19:17:04.614] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.614] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_1.jpg [19:17:04.624] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.625] AnimatedImageFrame[aif] :: _init(), END [19:17:04.626] AnimatedImageFrame[aif] :: constructor() [19:17:04.626] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.626] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_2.jpg [19:17:04.637] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.639] AnimatedImageFrame[aif] :: _init(), END [19:17:04.639] AnimatedImageFrame[aif] :: constructor() [19:17:04.639] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.639] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_3.jpg [19:17:04.655] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.656] AnimatedImageFrame[aif] :: _init(), END [19:17:04.657] AnimatedImageFrame[aif] :: constructor() [19:17:04.657] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.657] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_4.jpg [19:17:04.668] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.669] AnimatedImageFrame[aif] :: _init(), END [19:17:04.670] AnimatedImageFrame[aif] :: constructor() [19:17:04.670] AnimatedImageFrame[aif] :: _init(), BEGIN [19:17:04.670] CanvasClip :: LoadImageWithPromise(), src: 1F88BD61-BF99-F626-8A6B-2922B41B1771_1.jpg [19:17:04.681] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [19:17:04.681] AnimatedImageFrame[aif] :: _init(), END [19:17:04.682] Overlay[simplefadedisplay] :: _animate() [19:17:04.682] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [19:17:04.682] CanvasStream[simplefadedisplay] :: _init(), p.then() [19:17:04.683] CanvasStream[canvas_1005975130741] :: _init(), promise.all.then() [19:17:04.685] CanvasStream[canvas_1005975130741] :: _init(), END [19:17:04.685] StreamMangaer :: init(), stream[canvas_1005975130741].then() [19:17:04.685] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1005975130741', progress: 1 } [19:17:04.685] index :: _onStepProgress_vidbot(), percent: 100 [19:17:04.685] StreamManager :: init(), promise.all.then... [19:17:04.686] Vidbot :: StreamMgr.on( 'INITED' ) [19:17:04.686] Vidbot :: _next(), _stepIndex:2 of 4 [19:17:04.686] index :: _onStepCompleted_vidbot(), step: 2 [19:17:04.686] index :: _onStepStarted_vidbot(), step: 3 [19:17:04.686] Vidbot :: step[2], label:Rendering Canvas Streams [19:17:04.687] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [19:17:04.687] StreamManager :: render() [19:17:04.687] CanvasStream[canvas_1005975130741] :: render() [19:17:04.724] index :: _onStepProgress_vidbot(), percent: 0 [19:17:13.654] index :: _onStepProgress_vidbot(), percent: 5 [19:17:22.571] index :: _onStepProgress_vidbot(), percent: 10 [19:17:31.779] index :: _onStepProgress_vidbot(), percent: 15 [19:17:40.858] index :: _onStepProgress_vidbot(), percent: 20 [19:17:50.383] index :: _onStepProgress_vidbot(), percent: 25 [19:17:59.656] index :: _onStepProgress_vidbot(), percent: 30 [19:18:08.383] index :: _onStepProgress_vidbot(), percent: 35 [19:18:17.591] index :: _onStepProgress_vidbot(), percent: 40 [19:18:26.783] index :: _onStepProgress_vidbot(), percent: 45 [19:18:36.268] index :: _onStepProgress_vidbot(), percent: 50 [19:18:45.539] index :: _onStepProgress_vidbot(), percent: 55 [19:18:54.382] index :: _onStepProgress_vidbot(), percent: 60 [19:19:03.475] index :: _onStepProgress_vidbot(), percent: 65 [19:19:12.545] index :: _onStepProgress_vidbot(), percent: 70 [19:19:21.716] index :: _onStepProgress_vidbot(), percent: 75 [19:19:30.767] index :: _onStepProgress_vidbot(), percent: 80 [19:19:39.489] index :: _onStepProgress_vidbot(), percent: 85 [19:19:48.755] index :: _onStepProgress_vidbot(), percent: 90 [19:19:58.026] index :: _onStepProgress_vidbot(), percent: 95 [19:20:07.330] index :: _onStepProgress_vidbot(), percent: 100 [19:20:08.446] StreamManager :: render(), Promise.all.then... [19:20:08.447] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [19:20:08.447] Vidbot :: _next(), _stepIndex:3 of 4 [19:20:08.447] index :: _onStepCompleted_vidbot(), step: 3 [19:20:08.448] index :: _onStepStarted_vidbot(), step: 4 [19:20:08.449] Vidbot :: step[3], label:Encoding Media [19:20:08.451] CanvasFilters :: Overlay() [19:20:08.451] AudioStream[audio_vo] :: inputOptions() [19:20:08.451] AudioFilters :: Volume() [19:20:08.451] filter: [2:a]volume=1[2_vol] [19:20:08.452] AudioFilters :: Delay() [19:20:08.452] filter: [2_vol]adelay=0|0[2_del] [19:20:08.452] AudioStream[bg_music] :: inputOptions() [19:20:08.452] AudioFilters :: Volume() [19:20:08.452] filter: [3:a]volume=0.25[3_vol] [19:20:08.452] AudioFilters :: FadeOut() [19:20:08.452] filter: [3_vol]afade=t=out:st=60.51:d=1[3_fadeout] [19:20:08.452] AudioFilters :: Delay() [19:20:08.452] filter: [3_fadeout]adelay=0|0[3_del] [19:20:08.452] AudioFilters :: Mix() [19:20:08.453] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [19:20:08.453] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [19:20:08.455] hang.time: 60 [19:20:08.553] Vidbot :: ffmpeg.on( 'start' ) [19:20:08.553] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60.51 -r 30 -i ./tmp/canvas_1005975130741_%05d.png -to 00:01:00.509 -i file:///var/www/html/ [19:20:08.553] clients/3493/audio/1F88BD61-BF99-F626-8A6B-2922B41B1771.mp3 -to 00:01:00.509 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF3_Eas [19:20:08.553] y_Listening.mp3 -y -filter_complex [0:v][1:v]overlay=x=0:y=0[1_out];[2:a]volume=1[2_vol];[2_vol]adelay=0|0[2_del];[3:a]volume=0.25[3_vol];[3_vol]afade [19:20:08.553] =t=out:st=60.51:d=1[3_fadeout];[3_fadeout]adelay=0|0[3_del];[2_del][3_del]amix=inputs=2:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f m [19:20:08.553] p4 -map [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/3493/video/1F88BD61-BF [19:20:08.553] 99-F626-8A6B-2922B41B1771.mp4 [19:20:08.681] index :: _onStepProgress_vidbot(), percent: -3432901103 [19:20:09.124] index :: _onStepProgress_vidbot(), percent: 2 [19:20:10.127] index :: _onStepProgress_vidbot(), percent: 7 [19:20:10.629] index :: _onStepProgress_vidbot(), percent: 10 [19:20:11.631] index :: _onStepProgress_vidbot(), percent: 16 [19:20:12.640] index :: _onStepProgress_vidbot(), percent: 22 [19:20:13.141] index :: _onStepProgress_vidbot(), percent: 25 [19:20:14.153] index :: _onStepProgress_vidbot(), percent: 32 [19:20:14.657] index :: _onStepProgress_vidbot(), percent: 36 [19:20:15.665] index :: _onStepProgress_vidbot(), percent: 42 [19:20:16.230] index :: _onStepProgress_vidbot(), percent: 45 [19:20:17.202] index :: _onStepProgress_vidbot(), percent: 52 [19:20:17.702] index :: _onStepProgress_vidbot(), percent: 56 [19:20:18.208] index :: _onStepProgress_vidbot(), percent: 60 [19:20:19.221] index :: _onStepProgress_vidbot(), percent: 65 [19:20:20.234] index :: _onStepProgress_vidbot(), percent: 72 [19:20:20.735] index :: _onStepProgress_vidbot(), percent: 75 [19:20:21.743] index :: _onStepProgress_vidbot(), percent: 82 [19:20:22.244] index :: _onStepProgress_vidbot(), percent: 85 [19:20:23.245] index :: _onStepProgress_vidbot(), percent: 92 [19:20:23.747] index :: _onStepProgress_vidbot(), percent: 95 [19:20:24.413] index :: _onStepProgress_vidbot(), percent: 100 [19:20:24.430] Vidbot :: ffmpeg.on( 'end' ), Done! [19:20:24.431] StreamManager :: dispose() [19:20:24.431] CanvasStream[canvas_1005975130741] :: dispose() [19:20:24.448] Vidbot :: fflog.on( 'finish' ) [19:20:24.449] fflog.path: /var/www/html/clients/3493/video/1F88BD61-BF99-F626-8A6B-2922B41B1771.mp4.fflog [19:20:24.449] Vidbot :: _next(), _stepIndex:4 of 4 [19:20:24.449] index :: _onStepCompleted_vidbot(), step: 4 [19:20:24.449] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 200.242, output: '/var/www/html/clients/3493/video/1F88BD61-BF99-F626-8A6B-2922B41B1771.mp4', duration: 60.51 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/3493/video/1F88BD61-BF99-F626-8A6B-2922B41B1771.mp4 Media Duration : 00:01:00.509 Generation Time : 00:03:20.241 ---------------------------------------------------------------------------------------------------------------