--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [17:19:40.201] Vidbot :: start() [17:19:40.202] Vidbot :: _next(), _stepIndex:0 of 4 [17:19:40.203] index :: _onStepStarted_vidbot(), step: 1 [17:19:40.204] Vidbot :: step[0], label:Initializing Core [17:19:40.220] index :: _onStepProgress_vidbot(), percent: 20 [17:19:40.220] Vidbot :: _parse() [17:19:40.222] index :: _onStepProgress_vidbot(), percent: 40 [17:19:40.222] Vidbot :: _validate() [17:19:40.223] index :: _onStepProgress_vidbot(), percent: 60 [17:19:40.223] Vidbot :: _fonts() [17:19:40.223] FabricFontManager :: add(), id: SourceSansPro-Bold [17:19:40.224] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [17:19:40.232] FabricFontManager :: add(), id: SourceSansPro-Light [17:19:40.233] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [17:19:40.233] FabricFontManager :: add(), id: DINOT-Bold [17:19:40.233] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [17:19:40.234] FabricFontManager :: add(), id: DINOT-Light [17:19:40.234] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [17:19:40.235] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [17:19:40.235] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [17:19:40.236] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [17:19:40.236] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [17:19:40.237] index :: _onStepProgress_vidbot(), percent: 80 [17:19:40.237] Vidbot :: _clips() [17:19:40.238] StreamManager :: add(), id:audio_vo, type:audio [17:19:40.238] AudioClip[audio_vo] :: constructor() [17:19:40.239] InputStream[audio_vo] :: constructor() [17:19:40.239] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [17:19:40.242] StreamManager :: add(), id:bg_music, type:audio [17:19:40.242] AudioClip[bg_music] :: constructor() [17:19:40.242] InputStream[bg_music] :: constructor() [17:19:40.242] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [17:19:40.242] StreamManager :: add(), id:simplefadedisplay, type:canvas [17:19:40.243] CanvasStream[canvas_1332868328211] :: constructor() [17:19:40.243] InputStream[canvas_1332868328211] :: constructor() [17:19:40.327] KenBurnsSlideshow[simplefadedisplay] :: constructor() [17:19:40.327] Overlay[simplefadedisplay] :: constructor() [17:19:40.328] CanvasClip[simplefadedisplay] :: constructor() [17:19:40.328] Clip[simplefadedisplay] :: constructor() [17:19:40.328] clip:"simplefadedisplay" added to stream:"canvas_1332868328211" [17:19:40.328] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1332868328211', clipId: 'simplefadedisplay' } [17:19:40.328] StreamManager :: add(), id:caption, type:canvas [17:19:40.328] RenCaption[caption] :: constructor() [17:19:40.329] Ren[caption] :: constructor() [17:19:40.329] Overlay[caption] :: constructor() [17:19:40.329] CanvasClip[caption] :: constructor() [17:19:40.329] Clip[caption] :: constructor() [17:19:40.329] clip:"caption" added to stream:"canvas_1332868328211" [17:19:40.329] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1332868328211', clipId: 'caption' } [17:19:40.329] all added... [17:19:40.329] Vidbot :: _next(), _stepIndex:1 of 4 [17:19:40.330] index :: _onStepCompleted_vidbot(), step: 1 [17:19:40.330] index :: _onStepStarted_vidbot(), step: 2 [17:19:40.330] Vidbot :: step[1], label:Initializing Input Streams [17:19:40.331] StreamManager :: init() [17:19:40.331] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [17:19:40.331] index :: _onStepProgress_vidbot(), percent: 33 [17:19:40.331] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [17:19:40.332] index :: _onStepProgress_vidbot(), percent: 67 [17:19:40.332] CanvasStream[canvas_1332868328211] :: _init(), BEGIN [17:19:40.332] i:0, c.id:simplefadedisplay [17:19:40.333] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [17:19:40.333] KenBurnsSlideshow[simplefadedisplay] :: _validate() [17:19:40.334] KenBurnsSlideshow[undefined] :: _validateAnim() [17:19:40.341] KenBurnsSlideshow[undefined] :: _validateTheme() [17:19:40.343] i:1, c.id:caption [17:19:40.343] RenCaption[caption] :: _init() [17:19:40.343] RenCaption[caption] :: _validate() [17:19:40.345] KenBurnsSlideshow[simplefadedisplay] :: _build() [17:19:40.351] AnimatedImageFrame[aif] :: constructor() [17:19:40.352] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.353] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_1.jpg [17:19:40.366] RenCaption[caption] :: _build() [17:19:40.388] Overlay[caption] :: _animate() [17:19:40.390] CanvasStream[caption] :: _init(), p.then() [17:19:40.410] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.414] AnimatedImageFrame[aif] :: _init(), END [17:19:40.416] AnimatedImageFrame[aif] :: constructor() [17:19:40.416] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.416] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_2.jpg [17:19:40.434] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.436] AnimatedImageFrame[aif] :: _init(), END [17:19:40.436] AnimatedImageFrame[aif] :: constructor() [17:19:40.436] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.437] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_3.jpg [17:19:40.454] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.456] AnimatedImageFrame[aif] :: _init(), END [17:19:40.456] AnimatedImageFrame[aif] :: constructor() [17:19:40.457] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.457] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_4.jpg [17:19:40.472] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.474] AnimatedImageFrame[aif] :: _init(), END [17:19:40.474] AnimatedImageFrame[aif] :: constructor() [17:19:40.475] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.475] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_5.jpg [17:19:40.508] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.509] AnimatedImageFrame[aif] :: _init(), END [17:19:40.510] AnimatedImageFrame[aif] :: constructor() [17:19:40.510] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.510] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_6.jpg [17:19:40.526] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.527] AnimatedImageFrame[aif] :: _init(), END [17:19:40.528] AnimatedImageFrame[aif] :: constructor() [17:19:40.528] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.528] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_7.jpg [17:19:40.544] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.545] AnimatedImageFrame[aif] :: _init(), END [17:19:40.545] AnimatedImageFrame[aif] :: constructor() [17:19:40.546] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.546] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_8.jpg [17:19:40.562] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.563] AnimatedImageFrame[aif] :: _init(), END [17:19:40.564] AnimatedImageFrame[aif] :: constructor() [17:19:40.564] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.564] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_9.jpg [17:19:40.582] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.583] AnimatedImageFrame[aif] :: _init(), END [17:19:40.583] AnimatedImageFrame[aif] :: constructor() [17:19:40.583] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.584] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_10.jpg [17:19:40.598] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.599] AnimatedImageFrame[aif] :: _init(), END [17:19:40.600] AnimatedImageFrame[aif] :: constructor() [17:19:40.600] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.600] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_11.jpg [17:19:40.616] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.617] AnimatedImageFrame[aif] :: _init(), END [17:19:40.617] AnimatedImageFrame[aif] :: constructor() [17:19:40.618] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.618] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_12.jpg [17:19:40.634] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.635] AnimatedImageFrame[aif] :: _init(), END [17:19:40.636] AnimatedImageFrame[aif] :: constructor() [17:19:40.636] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.636] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_13.jpg [17:19:40.652] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.654] AnimatedImageFrame[aif] :: _init(), END [17:19:40.654] AnimatedImageFrame[aif] :: constructor() [17:19:40.654] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.654] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_14.jpg [17:19:40.672] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.673] AnimatedImageFrame[aif] :: _init(), END [17:19:40.673] AnimatedImageFrame[aif] :: constructor() [17:19:40.673] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.674] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_15.jpg [17:19:40.692] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.693] AnimatedImageFrame[aif] :: _init(), END [17:19:40.694] AnimatedImageFrame[aif] :: constructor() [17:19:40.694] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.694] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_16.jpg [17:19:40.709] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.711] AnimatedImageFrame[aif] :: _init(), END [17:19:40.712] AnimatedImageFrame[aif] :: constructor() [17:19:40.712] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.712] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_17.jpg [17:19:40.729] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.730] AnimatedImageFrame[aif] :: _init(), END [17:19:40.731] AnimatedImageFrame[aif] :: constructor() [17:19:40.731] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.731] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_18.jpg [17:19:40.748] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.749] AnimatedImageFrame[aif] :: _init(), END [17:19:40.750] AnimatedImageFrame[aif] :: constructor() [17:19:40.750] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.750] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_19.jpg [17:19:40.770] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.771] AnimatedImageFrame[aif] :: _init(), END [17:19:40.772] AnimatedImageFrame[aif] :: constructor() [17:19:40.772] AnimatedImageFrame[aif] :: _init(), BEGIN [17:19:40.772] CanvasClip :: LoadImageWithPromise(), src: 78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1_20.jpg [17:19:40.788] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [17:19:40.789] AnimatedImageFrame[aif] :: _init(), END [17:19:40.789] Overlay[simplefadedisplay] :: _animate() [17:19:40.790] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [17:19:40.790] CanvasStream[simplefadedisplay] :: _init(), p.then() [17:19:40.790] CanvasStream[canvas_1332868328211] :: _init(), promise.all.then() [17:19:40.793] CanvasStream[canvas_1332868328211] :: _init(), END [17:19:40.793] StreamMangaer :: init(), stream[canvas_1332868328211].then() [17:19:40.793] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1332868328211', progress: 1 } [17:19:40.793] index :: _onStepProgress_vidbot(), percent: 100 [17:19:40.793] StreamManager :: init(), promise.all.then... [17:19:40.793] Vidbot :: StreamMgr.on( 'INITED' ) [17:19:40.794] Vidbot :: _next(), _stepIndex:2 of 4 [17:19:40.794] index :: _onStepCompleted_vidbot(), step: 2 [17:19:40.794] index :: _onStepStarted_vidbot(), step: 3 [17:19:40.794] Vidbot :: step[2], label:Rendering Canvas Streams [17:19:40.794] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [17:19:40.795] StreamManager :: render() [17:19:40.795] CanvasStream[canvas_1332868328211] :: render() [17:19:40.831] index :: _onStepProgress_vidbot(), percent: 0 [17:19:52.182] index :: _onStepProgress_vidbot(), percent: 5 [17:20:07.686] index :: _onStepProgress_vidbot(), percent: 10 [17:20:23.254] index :: _onStepProgress_vidbot(), percent: 15 [17:20:35.778] index :: _onStepProgress_vidbot(), percent: 20 [17:20:48.245] index :: _onStepProgress_vidbot(), percent: 25 [17:21:01.732] index :: _onStepProgress_vidbot(), percent: 30 [17:21:15.206] index :: _onStepProgress_vidbot(), percent: 35 [17:21:28.589] index :: _onStepProgress_vidbot(), percent: 40 [17:21:44.946] index :: _onStepProgress_vidbot(), percent: 45 [17:21:58.122] index :: _onStepProgress_vidbot(), percent: 50 [17:22:11.334] index :: _onStepProgress_vidbot(), percent: 55 [17:22:24.521] index :: _onStepProgress_vidbot(), percent: 60 [17:22:37.360] index :: _onStepProgress_vidbot(), percent: 65 [17:22:51.108] index :: _onStepProgress_vidbot(), percent: 70 [17:23:05.367] index :: _onStepProgress_vidbot(), percent: 75 [17:23:18.049] index :: _onStepProgress_vidbot(), percent: 80 [17:23:31.833] index :: _onStepProgress_vidbot(), percent: 85 [17:23:45.448] index :: _onStepProgress_vidbot(), percent: 90 [17:23:58.509] index :: _onStepProgress_vidbot(), percent: 95 [17:24:14.077] index :: _onStepProgress_vidbot(), percent: 100 [17:24:15.560] StreamManager :: render(), Promise.all.then... [17:24:15.561] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [17:24:15.561] Vidbot :: _next(), _stepIndex:3 of 4 [17:24:15.561] index :: _onStepCompleted_vidbot(), step: 3 [17:24:15.562] index :: _onStepStarted_vidbot(), step: 4 [17:24:15.563] Vidbot :: step[3], label:Encoding Media [17:24:15.565] CanvasFilters :: Overlay() [17:24:15.566] AudioStream[audio_vo] :: inputOptions() [17:24:15.566] AudioFilters :: Volume() [17:24:15.566] filter: [2:a]volume=1[2_vol] [17:24:15.566] AudioFilters :: Delay() [17:24:15.567] filter: [2_vol]adelay=0|0[2_del] [17:24:15.567] AudioStream[bg_music] :: inputOptions() [17:24:15.567] AudioFilters :: Volume() [17:24:15.567] filter: [3:a]volume=0.25[3_vol] [17:24:15.567] AudioFilters :: FadeOut() [17:24:15.567] filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout] [17:24:15.567] AudioFilters :: Delay() [17:24:15.567] filter: [3_fadeout]adelay=0|0[3_del] [17:24:15.567] AudioFilters :: Mix() [17:24:15.568] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [17:24:15.568] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [17:24:15.570] hang.time: 60 [17:24:15.680] Vidbot :: ffmpeg.on( 'start' ) [17:24:15.680] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60 -r 30 -i ./tmp/canvas_1332868328211_%05d.png -to 00:01:00.000 -i file:///var/www/html/cli [17:24:15.680] ents/1013/audio/78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF10_EDM_3 [17:24:15.680] .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=t=out:st=6 [17:24:15.680] 0: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 mp4 -map [a_out [17:24:15.680] ] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/1013/video/78F7C8CC-BA0F-8A20-8DEA-B [17:24:15.680] 2CFF8E3BCB1.mp4 [17:24:15.868] index :: _onStepProgress_vidbot(), percent: -3462080762 [17:24:16.289] index :: _onStepProgress_vidbot(), percent: 1 [17:24:17.300] index :: _onStepProgress_vidbot(), percent: 7 [17:24:17.800] index :: _onStepProgress_vidbot(), percent: 12 [17:24:18.301] index :: _onStepProgress_vidbot(), percent: 15 [17:24:19.304] index :: _onStepProgress_vidbot(), percent: 23 [17:24:19.805] index :: _onStepProgress_vidbot(), percent: 26 [17:24:20.305] index :: _onStepProgress_vidbot(), percent: 30 [17:24:21.314] index :: _onStepProgress_vidbot(), percent: 37 [17:24:21.817] index :: _onStepProgress_vidbot(), percent: 42 [17:24:22.320] index :: _onStepProgress_vidbot(), percent: 45 [17:24:23.325] index :: _onStepProgress_vidbot(), percent: 52 [17:24:24.334] index :: _onStepProgress_vidbot(), percent: 57 [17:24:24.830] index :: _onStepProgress_vidbot(), percent: 60 [17:24:25.836] index :: _onStepProgress_vidbot(), percent: 65 [17:24:26.842] index :: _onStepProgress_vidbot(), percent: 71 [17:24:27.844] index :: _onStepProgress_vidbot(), percent: 77 [17:24:28.352] index :: _onStepProgress_vidbot(), percent: 81 [17:24:28.859] index :: _onStepProgress_vidbot(), percent: 85 [17:24:29.867] index :: _onStepProgress_vidbot(), percent: 93 [17:24:30.369] index :: _onStepProgress_vidbot(), percent: 97 [17:24:30.777] index :: _onStepProgress_vidbot(), percent: 100 [17:24:30.809] Vidbot :: ffmpeg.on( 'end' ), Done! [17:24:30.809] StreamManager :: dispose() [17:24:30.810] CanvasStream[canvas_1332868328211] :: dispose() [17:24:30.815] Vidbot :: fflog.on( 'finish' ) [17:24:30.815] fflog.path: /var/www/html/clients/1013/video/78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1.mp4.fflog [17:24:30.815] Vidbot :: _next(), _stepIndex:4 of 4 [17:24:30.816] index :: _onStepCompleted_vidbot(), step: 4 [17:24:30.816] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 290.635, output: '/var/www/html/clients/1013/video/78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1.mp4', duration: 60 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/1013/video/78F7C8CC-BA0F-8A20-8DEA-B2CFF8E3BCB1.mp4 Media Duration : 00:01:00.000 Generation Time : 00:04:50.634 ---------------------------------------------------------------------------------------------------------------