--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [01:01:20.788] Vidbot :: start() [01:01:20.788] Vidbot :: _next(), _stepIndex:0 of 4 [01:01:20.789] index :: _onStepStarted_vidbot(), step: 1 [01:01:20.790] Vidbot :: step[0], label:Initializing Core [01:01:20.799] index :: _onStepProgress_vidbot(), percent: 20 [01:01:20.799] Vidbot :: _parse() [01:01:20.801] index :: _onStepProgress_vidbot(), percent: 40 [01:01:20.801] Vidbot :: _validate() [01:01:20.802] index :: _onStepProgress_vidbot(), percent: 60 [01:01:20.802] Vidbot :: _fonts() [01:01:20.802] FabricFontManager :: add(), id: SourceSansPro-Bold [01:01:20.802] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [01:01:20.810] FabricFontManager :: add(), id: SourceSansPro-Light [01:01:20.811] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [01:01:20.811] FabricFontManager :: add(), id: DINOT-Bold [01:01:20.812] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [01:01:20.812] FabricFontManager :: add(), id: DINOT-Light [01:01:20.812] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [01:01:20.813] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [01:01:20.813] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [01:01:20.814] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [01:01:20.814] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [01:01:20.815] index :: _onStepProgress_vidbot(), percent: 80 [01:01:20.815] Vidbot :: _clips() [01:01:20.816] StreamManager :: add(), id:audio_vo, type:audio [01:01:20.816] AudioClip[audio_vo] :: constructor() [01:01:20.817] InputStream[audio_vo] :: constructor() [01:01:20.817] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [01:01:20.819] StreamManager :: add(), id:bg_music, type:audio [01:01:20.819] AudioClip[bg_music] :: constructor() [01:01:20.820] InputStream[bg_music] :: constructor() [01:01:20.820] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [01:01:20.820] StreamManager :: add(), id:simplefadedisplay, type:canvas [01:01:20.820] CanvasStream[canvas_1367234197071] :: constructor() [01:01:20.820] InputStream[canvas_1367234197071] :: constructor() [01:01:20.899] KenBurnsSlideshow[simplefadedisplay] :: constructor() [01:01:20.899] Overlay[simplefadedisplay] :: constructor() [01:01:20.900] CanvasClip[simplefadedisplay] :: constructor() [01:01:20.900] Clip[simplefadedisplay] :: constructor() [01:01:20.900] clip:"simplefadedisplay" added to stream:"canvas_1367234197071" [01:01:20.900] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1367234197071', clipId: 'simplefadedisplay' } [01:01:20.900] StreamManager :: add(), id:cpo, type:video [01:01:20.900] VideoStream[cpo] :: constructor() [01:01:20.901] InputStream[cpo] :: constructor() [01:01:20.901] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'cpo', clipId: null } [01:01:20.901] all added... [01:01:20.901] Vidbot :: _next(), _stepIndex:1 of 4 [01:01:20.901] index :: _onStepCompleted_vidbot(), step: 1 [01:01:20.901] index :: _onStepStarted_vidbot(), step: 2 [01:01:20.902] Vidbot :: step[1], label:Initializing Input Streams [01:01:20.902] StreamManager :: init() [01:01:20.902] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.25 } [01:01:20.903] index :: _onStepProgress_vidbot(), percent: 25 [01:01:20.903] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.5 } [01:01:20.903] index :: _onStepProgress_vidbot(), percent: 50 [01:01:20.903] CanvasStream[canvas_1367234197071] :: _init(), BEGIN [01:01:20.903] i:0, c.id:simplefadedisplay [01:01:20.904] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [01:01:20.904] KenBurnsSlideshow[simplefadedisplay] :: _validate() [01:01:20.905] KenBurnsSlideshow[undefined] :: _validateAnim() [01:01:20.905] KenBurnsSlideshow[undefined] :: _validateTheme() [01:01:20.906] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'cpo', progress: 0.75 } [01:01:20.906] index :: _onStepProgress_vidbot(), percent: 75 [01:01:20.907] KenBurnsSlideshow[simplefadedisplay] :: _build() [01:01:20.913] AnimatedImageFrame[aif] :: constructor() [01:01:20.914] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:20.915] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_1.jpg [01:01:20.975] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:20.980] AnimatedImageFrame[aif] :: _init(), END [01:01:20.982] AnimatedImageFrame[aif] :: constructor() [01:01:20.983] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:20.983] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_2.jpg [01:01:21.032] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.034] AnimatedImageFrame[aif] :: _init(), END [01:01:21.035] AnimatedImageFrame[aif] :: constructor() [01:01:21.035] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.035] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_3.jpg [01:01:21.081] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.083] AnimatedImageFrame[aif] :: _init(), END [01:01:21.083] AnimatedImageFrame[aif] :: constructor() [01:01:21.084] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.084] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_4.jpg [01:01:21.133] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.135] AnimatedImageFrame[aif] :: _init(), END [01:01:21.135] AnimatedImageFrame[aif] :: constructor() [01:01:21.135] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.135] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_5.jpg [01:01:21.178] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.180] AnimatedImageFrame[aif] :: _init(), END [01:01:21.180] AnimatedImageFrame[aif] :: constructor() [01:01:21.181] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.181] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_6.jpg [01:01:21.218] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.219] AnimatedImageFrame[aif] :: _init(), END [01:01:21.219] AnimatedImageFrame[aif] :: constructor() [01:01:21.220] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.220] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_7.jpg [01:01:21.257] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.258] AnimatedImageFrame[aif] :: _init(), END [01:01:21.259] AnimatedImageFrame[aif] :: constructor() [01:01:21.259] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.259] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_8.jpg [01:01:21.301] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.302] AnimatedImageFrame[aif] :: _init(), END [01:01:21.303] AnimatedImageFrame[aif] :: constructor() [01:01:21.303] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.303] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_9.jpg [01:01:21.342] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.343] AnimatedImageFrame[aif] :: _init(), END [01:01:21.344] AnimatedImageFrame[aif] :: constructor() [01:01:21.344] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.344] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_10.jpg [01:01:21.373] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.374] AnimatedImageFrame[aif] :: _init(), END [01:01:21.374] AnimatedImageFrame[aif] :: constructor() [01:01:21.375] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.375] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_11.jpg [01:01:21.405] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.406] AnimatedImageFrame[aif] :: _init(), END [01:01:21.406] AnimatedImageFrame[aif] :: constructor() [01:01:21.406] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.406] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_12.jpg [01:01:21.435] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.436] AnimatedImageFrame[aif] :: _init(), END [01:01:21.437] AnimatedImageFrame[aif] :: constructor() [01:01:21.437] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.437] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_13.jpg [01:01:21.468] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.469] AnimatedImageFrame[aif] :: _init(), END [01:01:21.469] AnimatedImageFrame[aif] :: constructor() [01:01:21.469] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.469] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_14.jpg [01:01:21.500] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.501] AnimatedImageFrame[aif] :: _init(), END [01:01:21.501] AnimatedImageFrame[aif] :: constructor() [01:01:21.501] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.502] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_15.jpg [01:01:21.532] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.533] AnimatedImageFrame[aif] :: _init(), END [01:01:21.534] AnimatedImageFrame[aif] :: constructor() [01:01:21.534] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.534] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_16.jpg [01:01:21.583] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.584] AnimatedImageFrame[aif] :: _init(), END [01:01:21.585] AnimatedImageFrame[aif] :: constructor() [01:01:21.585] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.585] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_17.jpg [01:01:21.613] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.614] AnimatedImageFrame[aif] :: _init(), END [01:01:21.615] AnimatedImageFrame[aif] :: constructor() [01:01:21.615] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.615] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_18.jpg [01:01:21.645] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.646] AnimatedImageFrame[aif] :: _init(), END [01:01:21.646] AnimatedImageFrame[aif] :: constructor() [01:01:21.646] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.647] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_19.jpg [01:01:21.677] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.678] AnimatedImageFrame[aif] :: _init(), END [01:01:21.679] AnimatedImageFrame[aif] :: constructor() [01:01:21.679] AnimatedImageFrame[aif] :: _init(), BEGIN [01:01:21.679] CanvasClip :: LoadImageWithPromise(), src: 7409571B-DC99-48A0-305E-847456F5E200_20.jpg [01:01:21.706] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:01:21.707] AnimatedImageFrame[aif] :: _init(), END [01:01:21.708] Overlay[simplefadedisplay] :: _animate() [01:01:21.709] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [01:01:21.709] CanvasStream[simplefadedisplay] :: _init(), p.then() [01:01:21.709] CanvasStream[canvas_1367234197071] :: _init(), promise.all.then() [01:01:21.711] CanvasStream[canvas_1367234197071] :: _init(), END [01:01:21.711] StreamMangaer :: init(), stream[canvas_1367234197071].then() [01:01:21.711] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1367234197071', progress: 1 } [01:01:21.711] index :: _onStepProgress_vidbot(), percent: 100 [01:01:21.711] StreamManager :: init(), promise.all.then... [01:01:21.711] Vidbot :: StreamMgr.on( 'INITED' ) [01:01:21.712] Vidbot :: _next(), _stepIndex:2 of 4 [01:01:21.712] index :: _onStepCompleted_vidbot(), step: 2 [01:01:21.712] index :: _onStepStarted_vidbot(), step: 3 [01:01:21.712] Vidbot :: step[2], label:Rendering Canvas Streams [01:01:21.712] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [01:01:21.712] StreamManager :: render() [01:01:21.713] CanvasStream[canvas_1367234197071] :: render() [01:01:21.773] index :: _onStepProgress_vidbot(), percent: 0 [01:01:59.353] index :: _onStepProgress_vidbot(), percent: 5 [01:02:41.838] index :: _onStepProgress_vidbot(), percent: 10 [01:03:26.426] index :: _onStepProgress_vidbot(), percent: 15 [01:04:08.239] index :: _onStepProgress_vidbot(), percent: 20 [01:04:50.915] index :: _onStepProgress_vidbot(), percent: 25 [01:05:36.370] index :: _onStepProgress_vidbot(), percent: 30 [01:06:21.588] index :: _onStepProgress_vidbot(), percent: 35 [01:07:02.937] index :: _onStepProgress_vidbot(), percent: 40 [01:07:49.137] index :: _onStepProgress_vidbot(), percent: 45 [01:08:26.183] index :: _onStepProgress_vidbot(), percent: 50 [01:09:04.167] index :: _onStepProgress_vidbot(), percent: 55 [01:09:37.306] index :: _onStepProgress_vidbot(), percent: 60 [01:10:17.768] index :: _onStepProgress_vidbot(), percent: 65 [01:10:59.660] index :: _onStepProgress_vidbot(), percent: 70 [01:11:36.808] index :: _onStepProgress_vidbot(), percent: 75 [01:12:16.551] index :: _onStepProgress_vidbot(), percent: 80 [01:12:53.346] index :: _onStepProgress_vidbot(), percent: 85 [01:13:28.258] index :: _onStepProgress_vidbot(), percent: 90 [01:14:02.963] index :: _onStepProgress_vidbot(), percent: 95 [01:14:34.061] index :: _onStepProgress_vidbot(), percent: 100 [01:14:34.564] StreamManager :: render(), Promise.all.then... [01:14:34.564] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [01:14:34.565] Vidbot :: _next(), _stepIndex:3 of 4 [01:14:34.565] index :: _onStepCompleted_vidbot(), step: 3 [01:14:34.565] index :: _onStepStarted_vidbot(), step: 4 [01:14:34.566] Vidbot :: step[3], label:Encoding Media [01:14:34.569] CanvasFilters :: Overlay() [01:14:34.569] VideoStream[cpo] :: inputOptions() [01:14:34.569] VideoFilters :: Tpad() [01:14:34.570] VideoFilters :: Scale() [01:14:34.570] VideoFilters :: Overlay() [01:14:34.571] AudioStream[audio_vo] :: inputOptions() [01:14:34.571] AudioFilters :: Volume() [01:14:34.571] filter: [3:a]volume=1[3_vol] [01:14:34.571] AudioFilters :: Delay() [01:14:34.572] filter: [3_vol]adelay=0|0[3_del] [01:14:34.572] AudioStream[bg_music] :: inputOptions() [01:14:34.572] AudioFilters :: Volume() [01:14:34.572] filter: [4:a]volume=0.15[4_vol] [01:14:34.572] AudioFilters :: FadeOut() [01:14:34.572] filter: [4_vol]afade=t=out:st=60:d=1[4_fadeout] [01:14:34.572] AudioFilters :: Delay() [01:14:34.572] filter: [4_fadeout]adelay=0|0[4_del] [01:14:34.572] VideoStream[cpo] :: inputOptions() [01:14:34.573] AudioFilters :: Volume() [01:14:34.573] filter: [5:a]volume=1[5_vol] [01:14:34.573] AudioFilters :: Delay() [01:14:34.573] filter: [5_vol]adelay=60000|60000[5_del] [01:14:34.573] AudioFilters :: Mix() [01:14:34.573] filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [01:14:34.573] mixed filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [01:14:34.576] hang.time: 60 [01:14:34.715] Vidbot :: ffmpeg.on( 'start' ) [01:14:34.716] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=80.76 -r 30 -i ./tmp/canvas_1367234197071_%05d.png -to 00:00:20.760 -i file:///var/app/video [01:14:34.716] _pre_processor/assets/cpo/nissan/nissan_540.mp4 -to 00:01:00.000 -i file:///var/www/html/clients/20363/audio/7409571B-DC99-48A0-305E-847456F5E200.mp3 [01:14:34.716] -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Rock-3.mp3 -to 00:00:20.760 -i file:///var/app/video_pre_processor/ [01:14:34.716] assets/cpo/nissan/nissan_540.mp4 -y -filter_complex [0:v][1:v]overlay=x=0:y=0[1_out];[2:v]tpad=start_duration=59.95[2_tpad];[2_tpad]scale=w=960:h=540[ [01:14:34.716] 2_scaled];[1_out][2_scaled]overlay=x=0:y=0:enable='between(t,60,80.76)'[2_out];[3:a]volume=1[3_vol];[3_vol]adelay=0|0[3_del];[4:a]volume=0.15[4_vol];[ [01:14:34.716] 4_vol]afade=t=out:st=60:d=1[4_fadeout];[4_fadeout]adelay=0|0[4_del];[5:a]volume=1[5_vol];[5_vol]adelay=60000|60000[5_del];[3_del][4_del][5_del]amix=in [01:14:34.716] puts=3:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [2_out] -preset veryfast -crf 18 -movflags frag_keyframe+emp [01:14:34.716] ty_moov -pix_fmt yuv420p /var/www/html/clients/20363/video/7409571B-DC99-48A0-305E-847456F5E200.mp4 [01:14:35.180] index :: _onStepProgress_vidbot(), percent: -2572125380 [01:14:35.570] index :: _onStepProgress_vidbot(), percent: 1 [01:14:37.090] index :: _onStepProgress_vidbot(), percent: 5 [01:14:39.113] index :: _onStepProgress_vidbot(), percent: 11 [01:14:40.622] index :: _onStepProgress_vidbot(), percent: 15 [01:14:42.654] index :: _onStepProgress_vidbot(), percent: 21 [01:14:44.178] index :: _onStepProgress_vidbot(), percent: 25 [01:14:46.194] index :: _onStepProgress_vidbot(), percent: 31 [01:14:47.700] index :: _onStepProgress_vidbot(), percent: 35 [01:14:49.221] index :: _onStepProgress_vidbot(), percent: 41 [01:14:50.747] index :: _onStepProgress_vidbot(), percent: 46 [01:14:52.258] index :: _onStepProgress_vidbot(), percent: 50 [01:14:54.300] index :: _onStepProgress_vidbot(), percent: 55 [01:14:55.817] index :: _onStepProgress_vidbot(), percent: 60 [01:14:57.343] index :: _onStepProgress_vidbot(), percent: 65 [01:14:58.866] index :: _onStepProgress_vidbot(), percent: 70 [01:15:00.381] index :: _onStepProgress_vidbot(), percent: 75 [01:15:01.903] index :: _onStepProgress_vidbot(), percent: 81 [01:15:03.406] index :: _onStepProgress_vidbot(), percent: 86 [01:15:04.407] index :: _onStepProgress_vidbot(), percent: 90 [01:15:05.425] index :: _onStepProgress_vidbot(), percent: 95 [01:15:06.898] index :: _onStepProgress_vidbot(), percent: 100 [01:15:06.984] Vidbot :: ffmpeg.on( 'end' ), Done! [01:15:06.984] StreamManager :: dispose() [01:15:06.984] CanvasStream[canvas_1367234197071] :: dispose() [01:15:07.012] Vidbot :: fflog.on( 'finish' ) [01:15:07.012] fflog.path: /var/www/html/clients/20363/video/7409571B-DC99-48A0-305E-847456F5E200.mp4.fflog [01:15:07.012] Vidbot :: _next(), _stepIndex:4 of 4 [01:15:07.012] index :: _onStepCompleted_vidbot(), step: 4 [01:15:07.013] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 826.244, output: '/var/www/html/clients/20363/video/7409571B-DC99-48A0-305E-847456F5E200.mp4', duration: 80.76 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/20363/video/7409571B-DC99-48A0-305E-847456F5E200.mp4 Media Duration : 00:01:20.760 Generation Time : 00:13:46.244 ---------------------------------------------------------------------------------------------------------------