--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [22:52:25.198] Vidbot :: start() [22:52:25.198] Vidbot :: _next(), _stepIndex:0 of 4 [22:52:25.199] index :: _onStepStarted_vidbot(), step: 1 [22:52:25.200] Vidbot :: step[0], label:Initializing Core [22:52:25.209] index :: _onStepProgress_vidbot(), percent: 20 [22:52:25.209] Vidbot :: _parse() [22:52:25.211] index :: _onStepProgress_vidbot(), percent: 40 [22:52:25.211] Vidbot :: _validate() [22:52:25.212] index :: _onStepProgress_vidbot(), percent: 60 [22:52:25.212] Vidbot :: _fonts() [22:52:25.212] FabricFontManager :: add(), id: SourceSansPro-Bold [22:52:25.212] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [22:52:25.221] FabricFontManager :: add(), id: SourceSansPro-Light [22:52:25.221] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [22:52:25.222] FabricFontManager :: add(), id: DINOT-Bold [22:52:25.222] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [22:52:25.223] FabricFontManager :: add(), id: DINOT-Light [22:52:25.223] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [22:52:25.223] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [22:52:25.224] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [22:52:25.224] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [22:52:25.224] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [22:52:25.225] index :: _onStepProgress_vidbot(), percent: 80 [22:52:25.226] Vidbot :: _clips() [22:52:25.226] StreamManager :: add(), id:audio_vo, type:audio [22:52:25.227] AudioClip[audio_vo] :: constructor() [22:52:25.227] InputStream[audio_vo] :: constructor() [22:52:25.227] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [22:52:25.230] StreamManager :: add(), id:bg_music, type:audio [22:52:25.230] AudioClip[bg_music] :: constructor() [22:52:25.230] InputStream[bg_music] :: constructor() [22:52:25.230] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [22:52:25.230] StreamManager :: add(), id:intro, type:video [22:52:25.230] VideoStream[intro] :: constructor() [22:52:25.231] InputStream[intro] :: constructor() [22:52:25.231] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'intro', clipId: null } [22:52:25.231] StreamManager :: add(), id:simplefadedisplay, type:canvas [22:52:25.231] CanvasStream[canvas_577931238850] :: constructor() [22:52:25.231] InputStream[canvas_577931238850] :: constructor() [22:52:25.315] KenBurnsSlideshow[simplefadedisplay] :: constructor() [22:52:25.315] Overlay[simplefadedisplay] :: constructor() [22:52:25.315] CanvasClip[simplefadedisplay] :: constructor() [22:52:25.315] Clip[simplefadedisplay] :: constructor() [22:52:25.315] clip:"simplefadedisplay" added to stream:"canvas_577931238850" [22:52:25.315] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_577931238850', clipId: 'simplefadedisplay' } [22:52:25.315] all added... [22:52:25.316] Vidbot :: _next(), _stepIndex:1 of 4 [22:52:25.316] index :: _onStepCompleted_vidbot(), step: 1 [22:52:25.316] index :: _onStepStarted_vidbot(), step: 2 [22:52:25.316] Vidbot :: step[1], label:Initializing Input Streams [22:52:25.317] StreamManager :: init() [22:52:25.317] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.25 } [22:52:25.317] index :: _onStepProgress_vidbot(), percent: 25 [22:52:25.317] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.5 } [22:52:25.318] index :: _onStepProgress_vidbot(), percent: 50 [22:52:25.318] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'intro', progress: 0.75 } [22:52:25.318] index :: _onStepProgress_vidbot(), percent: 75 [22:52:25.318] CanvasStream[canvas_577931238850] :: _init(), BEGIN [22:52:25.318] i:0, c.id:simplefadedisplay [22:52:25.319] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [22:52:25.319] KenBurnsSlideshow[simplefadedisplay] :: _validate() [22:52:25.319] KenBurnsSlideshow[undefined] :: _validateAnim() [22:52:25.320] KenBurnsSlideshow[undefined] :: _validateTheme() [22:52:25.322] KenBurnsSlideshow[simplefadedisplay] :: _build() [22:52:25.328] AnimatedImageFrame[aif] :: constructor() [22:52:25.329] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.329] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_1.jpg [22:52:25.366] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.370] AnimatedImageFrame[aif] :: _init(), END [22:52:25.372] AnimatedImageFrame[aif] :: constructor() [22:52:25.372] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.372] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_2.jpg [22:52:25.389] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.391] AnimatedImageFrame[aif] :: _init(), END [22:52:25.392] AnimatedImageFrame[aif] :: constructor() [22:52:25.392] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.392] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_3.jpg [22:52:25.414] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.415] AnimatedImageFrame[aif] :: _init(), END [22:52:25.416] AnimatedImageFrame[aif] :: constructor() [22:52:25.416] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.416] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_4.jpg [22:52:25.441] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.443] AnimatedImageFrame[aif] :: _init(), END [22:52:25.443] AnimatedImageFrame[aif] :: constructor() [22:52:25.443] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.443] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_5.jpg [22:52:25.460] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.462] AnimatedImageFrame[aif] :: _init(), END [22:52:25.462] AnimatedImageFrame[aif] :: constructor() [22:52:25.462] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.462] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_6.jpg [22:52:25.479] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.480] AnimatedImageFrame[aif] :: _init(), END [22:52:25.481] AnimatedImageFrame[aif] :: constructor() [22:52:25.481] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.481] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_7.jpg [22:52:25.498] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.499] AnimatedImageFrame[aif] :: _init(), END [22:52:25.499] AnimatedImageFrame[aif] :: constructor() [22:52:25.499] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.499] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_8.jpg [22:52:25.516] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.517] AnimatedImageFrame[aif] :: _init(), END [22:52:25.517] AnimatedImageFrame[aif] :: constructor() [22:52:25.517] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.517] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_9.jpg [22:52:25.533] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.534] AnimatedImageFrame[aif] :: _init(), END [22:52:25.535] AnimatedImageFrame[aif] :: constructor() [22:52:25.535] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.535] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_10.jpg [22:52:25.551] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.552] AnimatedImageFrame[aif] :: _init(), END [22:52:25.553] AnimatedImageFrame[aif] :: constructor() [22:52:25.553] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.553] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_11.jpg [22:52:25.569] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.570] AnimatedImageFrame[aif] :: _init(), END [22:52:25.571] AnimatedImageFrame[aif] :: constructor() [22:52:25.571] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.571] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_12.jpg [22:52:25.587] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.588] AnimatedImageFrame[aif] :: _init(), END [22:52:25.588] AnimatedImageFrame[aif] :: constructor() [22:52:25.588] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.588] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_13.jpg [22:52:25.605] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.606] AnimatedImageFrame[aif] :: _init(), END [22:52:25.606] AnimatedImageFrame[aif] :: constructor() [22:52:25.606] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.606] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_14.jpg [22:52:25.622] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.624] AnimatedImageFrame[aif] :: _init(), END [22:52:25.624] AnimatedImageFrame[aif] :: constructor() [22:52:25.624] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.624] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_15.jpg [22:52:25.641] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.642] AnimatedImageFrame[aif] :: _init(), END [22:52:25.642] AnimatedImageFrame[aif] :: constructor() [22:52:25.643] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.643] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_16.jpg [22:52:25.659] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.660] AnimatedImageFrame[aif] :: _init(), END [22:52:25.660] AnimatedImageFrame[aif] :: constructor() [22:52:25.660] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.660] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_17.jpg [22:52:25.676] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.677] AnimatedImageFrame[aif] :: _init(), END [22:52:25.677] AnimatedImageFrame[aif] :: constructor() [22:52:25.677] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.677] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_18.jpg [22:52:25.692] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.693] AnimatedImageFrame[aif] :: _init(), END [22:52:25.693] AnimatedImageFrame[aif] :: constructor() [22:52:25.693] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.693] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_19.jpg [22:52:25.712] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.713] AnimatedImageFrame[aif] :: _init(), END [22:52:25.713] AnimatedImageFrame[aif] :: constructor() [22:52:25.713] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:25.713] CanvasClip :: LoadImageWithPromise(), src: 89A793F0-C838-1E30-3D58-3234B14D41BD_20.jpg [22:52:25.733] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:25.733] AnimatedImageFrame[aif] :: _init(), END [22:52:25.734] Overlay[simplefadedisplay] :: _animate() [22:52:25.735] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [22:52:25.735] CanvasStream[simplefadedisplay] :: _init(), p.then() [22:52:25.736] CanvasStream[canvas_577931238850] :: _init(), promise.all.then() [22:52:25.737] CanvasStream[canvas_577931238850] :: _init(), END [22:52:25.737] StreamMangaer :: init(), stream[canvas_577931238850].then() [22:52:25.737] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_577931238850', progress: 1 } [22:52:25.738] index :: _onStepProgress_vidbot(), percent: 100 [22:52:25.738] StreamManager :: init(), promise.all.then... [22:52:25.738] Vidbot :: StreamMgr.on( 'INITED' ) [22:52:25.738] Vidbot :: _next(), _stepIndex:2 of 4 [22:52:25.738] index :: _onStepCompleted_vidbot(), step: 2 [22:52:25.738] index :: _onStepStarted_vidbot(), step: 3 [22:52:25.738] Vidbot :: step[2], label:Rendering Canvas Streams [22:52:25.739] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [22:52:25.739] StreamManager :: render() [22:52:25.740] CanvasStream[canvas_577931238850] :: render() [22:52:25.814] index :: _onStepProgress_vidbot(), percent: 0 [22:52:31.818] index :: _onStepProgress_vidbot(), percent: 5 [22:52:44.452] index :: _onStepProgress_vidbot(), percent: 10 [22:53:04.616] index :: _onStepProgress_vidbot(), percent: 15 [22:53:19.183] index :: _onStepProgress_vidbot(), percent: 20 [22:53:33.466] index :: _onStepProgress_vidbot(), percent: 25 [22:53:46.037] index :: _onStepProgress_vidbot(), percent: 30 [22:53:59.051] index :: _onStepProgress_vidbot(), percent: 35 [22:54:11.881] index :: _onStepProgress_vidbot(), percent: 40 [22:54:24.733] index :: _onStepProgress_vidbot(), percent: 45 [22:54:35.585] index :: _onStepProgress_vidbot(), percent: 50 [22:54:49.362] index :: _onStepProgress_vidbot(), percent: 55 [22:55:03.061] index :: _onStepProgress_vidbot(), percent: 60 [22:55:17.771] index :: _onStepProgress_vidbot(), percent: 65 [22:55:32.525] index :: _onStepProgress_vidbot(), percent: 70 [22:55:47.115] index :: _onStepProgress_vidbot(), percent: 75 [22:56:01.922] index :: _onStepProgress_vidbot(), percent: 80 [22:56:15.163] index :: _onStepProgress_vidbot(), percent: 85 [22:56:27.290] index :: _onStepProgress_vidbot(), percent: 90 [22:56:40.392] index :: _onStepProgress_vidbot(), percent: 95 [22:57:01.691] index :: _onStepProgress_vidbot(), percent: 100 [22:57:03.603] StreamManager :: render(), Promise.all.then... [22:57:03.603] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [22:57:03.604] Vidbot :: _next(), _stepIndex:3 of 4 [22:57:03.604] index :: _onStepCompleted_vidbot(), step: 3 [22:57:03.605] index :: _onStepStarted_vidbot(), step: 4 [22:57:03.606] Vidbot :: step[3], label:Encoding Media [22:57:03.608] VideoStream[intro] :: inputOptions() [22:57:03.609] VideoFilters :: Scale() [22:57:03.609] VideoFilters :: Overlay() [22:57:03.610] CanvasFilters :: Overlay() [22:57:03.610] AudioStream[audio_vo] :: inputOptions() [22:57:03.610] AudioFilters :: Volume() [22:57:03.611] filter: [3:a]volume=1[3_vol] [22:57:03.611] AudioFilters :: Delay() [22:57:03.611] filter: [3_vol]adelay=5030|5030[3_del] [22:57:03.611] AudioStream[bg_music] :: inputOptions() [22:57:03.611] AudioFilters :: Volume() [22:57:03.611] filter: [4:a]volume=0.25[4_vol] [22:57:03.611] AudioFilters :: FadeOut() [22:57:03.612] filter: [4_vol]afade=t=out:st=60:d=1[4_fadeout] [22:57:03.612] AudioFilters :: Delay() [22:57:03.612] filter: [4_fadeout]adelay=5030|5030[4_del] [22:57:03.612] VideoStream[intro] :: inputOptions() [22:57:03.612] AudioFilters :: Volume() [22:57:03.612] filter: [5:a]volume=1[5_vol] [22:57:03.612] AudioFilters :: Delay() [22:57:03.612] filter: [5_vol]adelay=0|0[5_del] [22:57:03.612] AudioFilters :: Mix() [22:57:03.612] filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [22:57:03.612] mixed filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [22:57:03.615] hang.time: 60 [22:57:03.741] Vidbot :: ffmpeg.on( 'start' ) [22:57:03.742] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=65.03 -to 00:00:05.030 -i file:///var/www/html/clients/9660/library/960_intro.mp4 -r 30 -i . [22:57:03.742] /tmp/canvas_577931238850_%05d.png -to 00:01:00.000 -i file:///var/www/html/clients/9660/audio/89A793F0-C838-1E30-3D58-3234B14D41BD.mp3 -to 00:01:00.00 [22:57:03.742] 0 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Orchestra-3_30.mp3 -to 00:00:05.030 -i file:///var/www/html/clients/9660/library/9 [22:57:03.742] 60_intro.mp4 -y -filter_complex [1:v]scale=w=960:h=540[1_scaled];[0:v][1_scaled]overlay=x=0:y=0:enable='between(t,0,5.03)'[1_out];[1_out][2:v]overlay= [22:57:03.742] x=0:y=0[2_out];[3:a]volume=1[3_vol];[3_vol]adelay=5030|5030[3_del];[4:a]volume=0.25[4_vol];[4_vol]afade=t=out:st=60:d=1[4_fadeout];[4_fadeout]adelay=5 [22:57:03.742] 030|5030[4_del];[5:a]volume=1[5_vol];[5_vol]adelay=0|0[5_del];[3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] -acodec aac -vcodec libx264 - [22:57:03.742] r 30 -f mp4 -map [a_out] -map [2_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/9660/video/89 [22:57:03.742] A793F0-C838-1E30-3D58-3234B14D41BD.mp4 [22:57:04.624] index :: _onStepProgress_vidbot(), percent: -3194292568 [22:57:04.942] index :: _onStepProgress_vidbot(), percent: 1 [22:57:07.806] index :: _onStepProgress_vidbot(), percent: 5 [22:57:09.828] index :: _onStepProgress_vidbot(), percent: 10 [22:57:11.381] index :: _onStepProgress_vidbot(), percent: 15 [22:57:12.887] index :: _onStepProgress_vidbot(), percent: 20 [22:57:14.423] index :: _onStepProgress_vidbot(), percent: 27 [22:57:15.428] index :: _onStepProgress_vidbot(), percent: 30 [22:57:16.952] index :: _onStepProgress_vidbot(), percent: 36 [22:57:17.953] index :: _onStepProgress_vidbot(), percent: 40 [22:57:19.483] index :: _onStepProgress_vidbot(), percent: 46 [22:57:20.501] index :: _onStepProgress_vidbot(), percent: 50 [22:57:21.504] index :: _onStepProgress_vidbot(), percent: 55 [22:57:22.522] index :: _onStepProgress_vidbot(), percent: 60 [22:57:23.525] index :: _onStepProgress_vidbot(), percent: 65 [22:57:25.046] index :: _onStepProgress_vidbot(), percent: 72 [22:57:26.060] index :: _onStepProgress_vidbot(), percent: 76 [22:57:27.070] index :: _onStepProgress_vidbot(), percent: 80 [22:57:28.083] index :: _onStepProgress_vidbot(), percent: 85 [22:57:29.597] index :: _onStepProgress_vidbot(), percent: 91 [22:57:30.600] index :: _onStepProgress_vidbot(), percent: 95 [22:57:31.847] index :: _onStepProgress_vidbot(), percent: 100 [22:57:31.898] Vidbot :: ffmpeg.on( 'end' ), Done! [22:57:31.898] StreamManager :: dispose() [22:57:31.899] CanvasStream[canvas_577931238850] :: dispose() [22:57:31.904] Vidbot :: fflog.on( 'finish' ) [22:57:31.904] fflog.path: /var/www/html/clients/9660/video/89A793F0-C838-1E30-3D58-3234B14D41BD.mp4.fflog [22:57:31.904] Vidbot :: _next(), _stepIndex:4 of 4 [22:57:31.904] index :: _onStepCompleted_vidbot(), step: 4 [22:57:31.905] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 306.727, output: '/var/www/html/clients/9660/video/89A793F0-C838-1E30-3D58-3234B14D41BD.mp4', duration: 65.03 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/9660/video/89A793F0-C838-1E30-3D58-3234B14D41BD.mp4 Media Duration : 00:01:05.030 Generation Time : 00:05:06.726 ---------------------------------------------------------------------------------------------------------------