--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [01:11:37.033] Vidbot :: start() [01:11:37.033] Vidbot :: _next(), _stepIndex:0 of 4 [01:11:37.033] index :: _onStepStarted_vidbot(), step: 1 [01:11:37.035] Vidbot :: step[0], label:Initializing Core [01:11:37.043] index :: _onStepProgress_vidbot(), percent: 20 [01:11:37.043] Vidbot :: _parse() [01:11:37.044] index :: _onStepProgress_vidbot(), percent: 40 [01:11:37.044] Vidbot :: _validate() [01:11:37.045] index :: _onStepProgress_vidbot(), percent: 60 [01:11:37.045] Vidbot :: _fonts() [01:11:37.046] FabricFontManager :: add(), id: SourceSansPro-Bold [01:11:37.046] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [01:11:37.053] FabricFontManager :: add(), id: SourceSansPro-Light [01:11:37.054] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [01:11:37.054] FabricFontManager :: add(), id: DINOT-Bold [01:11:37.054] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [01:11:37.055] FabricFontManager :: add(), id: DINOT-Light [01:11:37.055] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [01:11:37.056] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [01:11:37.056] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [01:11:37.057] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [01:11:37.057] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [01:11:37.058] index :: _onStepProgress_vidbot(), percent: 80 [01:11:37.058] Vidbot :: _clips() [01:11:37.059] StreamManager :: add(), id:audio_vo, type:audio [01:11:37.059] AudioClip[audio_vo] :: constructor() [01:11:37.059] InputStream[audio_vo] :: constructor() [01:11:37.059] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [01:11:37.062] StreamManager :: add(), id:bg_music, type:audio [01:11:37.062] AudioClip[bg_music] :: constructor() [01:11:37.062] InputStream[bg_music] :: constructor() [01:11:37.062] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [01:11:37.062] StreamManager :: add(), id:simplefadedisplay, type:canvas [01:11:37.063] CanvasStream[canvas_1259869803511] :: constructor() [01:11:37.063] InputStream[canvas_1259869803511] :: constructor() [01:11:37.134] KenBurnsSlideshow[simplefadedisplay] :: constructor() [01:11:37.134] Overlay[simplefadedisplay] :: constructor() [01:11:37.134] CanvasClip[simplefadedisplay] :: constructor() [01:11:37.134] Clip[simplefadedisplay] :: constructor() [01:11:37.135] clip:"simplefadedisplay" added to stream:"canvas_1259869803511" [01:11:37.135] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1259869803511', clipId: 'simplefadedisplay' } [01:11:37.135] StreamManager :: add(), id:carfax, type:video [01:11:37.135] VideoStream[carfax] :: constructor() [01:11:37.135] InputStream[carfax] :: constructor() [01:11:37.135] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'carfax', clipId: null } [01:11:37.135] all added... [01:11:37.135] Vidbot :: _next(), _stepIndex:1 of 4 [01:11:37.136] index :: _onStepCompleted_vidbot(), step: 1 [01:11:37.136] index :: _onStepStarted_vidbot(), step: 2 [01:11:37.136] Vidbot :: step[1], label:Initializing Input Streams [01:11:37.136] StreamManager :: init() [01:11:37.137] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.25 } [01:11:37.137] index :: _onStepProgress_vidbot(), percent: 25 [01:11:37.137] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.5 } [01:11:37.137] index :: _onStepProgress_vidbot(), percent: 50 [01:11:37.138] CanvasStream[canvas_1259869803511] :: _init(), BEGIN [01:11:37.138] i:0, c.id:simplefadedisplay [01:11:37.138] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [01:11:37.138] KenBurnsSlideshow[simplefadedisplay] :: _validate() [01:11:37.139] KenBurnsSlideshow[undefined] :: _validateAnim() [01:11:37.139] KenBurnsSlideshow[undefined] :: _validateTheme() [01:11:37.140] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'carfax', progress: 0.75 } [01:11:37.140] index :: _onStepProgress_vidbot(), percent: 75 [01:11:37.141] KenBurnsSlideshow[simplefadedisplay] :: _build() [01:11:37.146] AnimatedImageFrame[aif] :: constructor() [01:11:37.147] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.148] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_1.jpg [01:11:37.204] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.208] AnimatedImageFrame[aif] :: _init(), END [01:11:37.210] AnimatedImageFrame[aif] :: constructor() [01:11:37.210] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.210] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_2.jpg [01:11:37.474] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.475] AnimatedImageFrame[aif] :: _init(), END [01:11:37.476] AnimatedImageFrame[aif] :: constructor() [01:11:37.476] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.476] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_3.jpg [01:11:37.594] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.596] AnimatedImageFrame[aif] :: _init(), END [01:11:37.597] AnimatedImageFrame[aif] :: constructor() [01:11:37.597] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.597] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_4.jpg [01:11:37.640] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.641] AnimatedImageFrame[aif] :: _init(), END [01:11:37.641] AnimatedImageFrame[aif] :: constructor() [01:11:37.642] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.642] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_5.jpg [01:11:37.692] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.694] AnimatedImageFrame[aif] :: _init(), END [01:11:37.694] AnimatedImageFrame[aif] :: constructor() [01:11:37.694] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.695] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_6.jpg [01:11:37.743] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.744] AnimatedImageFrame[aif] :: _init(), END [01:11:37.745] AnimatedImageFrame[aif] :: constructor() [01:11:37.745] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.745] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_7.jpg [01:11:37.793] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.794] AnimatedImageFrame[aif] :: _init(), END [01:11:37.795] AnimatedImageFrame[aif] :: constructor() [01:11:37.795] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.795] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_8.jpg [01:11:37.838] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.839] AnimatedImageFrame[aif] :: _init(), END [01:11:37.840] AnimatedImageFrame[aif] :: constructor() [01:11:37.840] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.840] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_9.jpg [01:11:37.875] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.877] AnimatedImageFrame[aif] :: _init(), END [01:11:37.877] AnimatedImageFrame[aif] :: constructor() [01:11:37.877] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.877] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_10.jpg [01:11:37.917] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.918] AnimatedImageFrame[aif] :: _init(), END [01:11:37.918] AnimatedImageFrame[aif] :: constructor() [01:11:37.918] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.918] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_11.jpg [01:11:37.963] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:37.964] AnimatedImageFrame[aif] :: _init(), END [01:11:37.965] AnimatedImageFrame[aif] :: constructor() [01:11:37.965] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:37.965] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_12.jpg [01:11:38.021] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.023] AnimatedImageFrame[aif] :: _init(), END [01:11:38.023] AnimatedImageFrame[aif] :: constructor() [01:11:38.024] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.024] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_13.jpg [01:11:38.085] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.086] AnimatedImageFrame[aif] :: _init(), END [01:11:38.087] AnimatedImageFrame[aif] :: constructor() [01:11:38.087] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.087] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_14.jpg [01:11:38.143] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.144] AnimatedImageFrame[aif] :: _init(), END [01:11:38.145] AnimatedImageFrame[aif] :: constructor() [01:11:38.145] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.145] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_15.jpg [01:11:38.199] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.200] AnimatedImageFrame[aif] :: _init(), END [01:11:38.201] AnimatedImageFrame[aif] :: constructor() [01:11:38.201] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.201] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_16.jpg [01:11:38.247] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.248] AnimatedImageFrame[aif] :: _init(), END [01:11:38.249] AnimatedImageFrame[aif] :: constructor() [01:11:38.249] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.249] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_17.jpg [01:11:38.298] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.299] AnimatedImageFrame[aif] :: _init(), END [01:11:38.300] AnimatedImageFrame[aif] :: constructor() [01:11:38.300] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.300] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_18.jpg [01:11:38.386] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.387] AnimatedImageFrame[aif] :: _init(), END [01:11:38.388] AnimatedImageFrame[aif] :: constructor() [01:11:38.388] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.388] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_19.jpg [01:11:38.443] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.444] AnimatedImageFrame[aif] :: _init(), END [01:11:38.445] AnimatedImageFrame[aif] :: constructor() [01:11:38.445] AnimatedImageFrame[aif] :: _init(), BEGIN [01:11:38.445] CanvasClip :: LoadImageWithPromise(), src: 86038E22-9A26-1974-689C-1B132026509C_20.jpg [01:11:38.494] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:11:38.495] AnimatedImageFrame[aif] :: _init(), END [01:11:38.496] Overlay[simplefadedisplay] :: _animate() [01:11:38.497] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [01:11:38.497] CanvasStream[simplefadedisplay] :: _init(), p.then() [01:11:38.497] CanvasStream[canvas_1259869803511] :: _init(), promise.all.then() [01:11:38.499] CanvasStream[canvas_1259869803511] :: _init(), END [01:11:38.499] StreamMangaer :: init(), stream[canvas_1259869803511].then() [01:11:38.499] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1259869803511', progress: 1 } [01:11:38.499] index :: _onStepProgress_vidbot(), percent: 100 [01:11:38.499] StreamManager :: init(), promise.all.then... [01:11:38.499] Vidbot :: StreamMgr.on( 'INITED' ) [01:11:38.500] Vidbot :: _next(), _stepIndex:2 of 4 [01:11:38.500] index :: _onStepCompleted_vidbot(), step: 2 [01:11:38.500] index :: _onStepStarted_vidbot(), step: 3 [01:11:38.500] Vidbot :: step[2], label:Rendering Canvas Streams [01:11:38.501] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [01:11:38.501] StreamManager :: render() [01:11:38.501] CanvasStream[canvas_1259869803511] :: render() [01:11:38.623] index :: _onStepProgress_vidbot(), percent: 0 [01:12:30.546] index :: _onStepProgress_vidbot(), percent: 5 [01:13:27.875] index :: _onStepProgress_vidbot(), percent: 10 [01:14:44.442] index :: _onStepProgress_vidbot(), percent: 15 [01:15:45.199] index :: _onStepProgress_vidbot(), percent: 20 [01:16:56.019] index :: _onStepProgress_vidbot(), percent: 25 [01:17:53.812] index :: _onStepProgress_vidbot(), percent: 30 [01:18:43.789] index :: _onStepProgress_vidbot(), percent: 35 [01:19:34.206] index :: _onStepProgress_vidbot(), percent: 40 [01:20:24.713] index :: _onStepProgress_vidbot(), percent: 45 [01:21:16.423] index :: _onStepProgress_vidbot(), percent: 50 [01:22:10.230] index :: _onStepProgress_vidbot(), percent: 55 [01:23:02.100] index :: _onStepProgress_vidbot(), percent: 60 [01:24:19.710] index :: _onStepProgress_vidbot(), percent: 65 [01:25:39.960] index :: _onStepProgress_vidbot(), percent: 70 [01:26:46.858] index :: _onStepProgress_vidbot(), percent: 75 [01:27:30.332] index :: _onStepProgress_vidbot(), percent: 80 [01:28:25.722] index :: _onStepProgress_vidbot(), percent: 85 [01:29:42.502] index :: _onStepProgress_vidbot(), percent: 90 [01:30:48.131] index :: _onStepProgress_vidbot(), percent: 95 [01:31:41.443] index :: _onStepProgress_vidbot(), percent: 100 [01:31:42.394] StreamManager :: render(), Promise.all.then... [01:31:42.395] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [01:31:42.395] Vidbot :: _next(), _stepIndex:3 of 4 [01:31:42.395] index :: _onStepCompleted_vidbot(), step: 3 [01:31:42.396] index :: _onStepStarted_vidbot(), step: 4 [01:31:42.397] Vidbot :: step[3], label:Encoding Media [01:31:42.399] CanvasFilters :: Overlay() [01:31:42.400] VideoStream[carfax] :: inputOptions() [01:31:42.400] VideoFilters :: Tpad() [01:31:42.400] VideoFilters :: Scale() [01:31:42.401] VideoFilters :: Overlay() [01:31:42.402] AudioStream[audio_vo] :: inputOptions() [01:31:42.402] AudioFilters :: Volume() [01:31:42.402] filter: [3:a]volume=1[3_vol] [01:31:42.402] AudioFilters :: Delay() [01:31:42.403] filter: [3_vol]adelay=0|0[3_del] [01:31:42.403] AudioStream[bg_music] :: inputOptions() [01:31:42.403] AudioFilters :: Volume() [01:31:42.403] filter: [4:a]volume=0.25[4_vol] [01:31:42.403] AudioFilters :: FadeOut() [01:31:42.404] filter: [4_vol]afade=t=out:st=60:d=1[4_fadeout] [01:31:42.404] AudioFilters :: Delay() [01:31:42.404] filter: [4_fadeout]adelay=0|0[4_del] [01:31:42.404] VideoStream[carfax] :: inputOptions() [01:31:42.404] AudioFilters :: Volume() [01:31:42.404] filter: [5:a]volume=1[5_vol] [01:31:42.404] AudioFilters :: Delay() [01:31:42.404] filter: [5_vol]adelay=60000|60000[5_del] [01:31:42.404] AudioFilters :: Mix() [01:31:42.404] filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [01:31:42.404] mixed filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [01:31:42.407] hang.time: 60 [01:31:42.613] Vidbot :: ffmpeg.on( 'start' ) [01:31:42.614] ffmpeg -f lavfi -i color=c=000000:s=1280x720:r=30:duration=74.63 -r 30 -i ./tmp/canvas_1259869803511_%05d.png -to 00:00:14.630 -i file:///var/app/vide [01:31:42.614] o_pre_processor/assets/cpo/carfax_1owner/carfax_1owner_720.mp4 -to 00:01:00.000 -i file:///var/www/html/clients/10110/audio/86038E22-9A26-1974-689C-1B [01:31:42.614] 132026509C.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Orchestra-3_30.mp3 -to 00:00:14.630 -i file:///var/a [01:31:42.614] pp/video_pre_processor/assets/cpo/carfax_1owner/carfax_1owner_720.mp4 -y -filter_complex [0:v][1:v]overlay=x=0:y=0[1_out];[2:v]tpad=start_duration=59. [01:31:42.614] 95[2_tpad];[2_tpad]scale=w=1280:h=720[2_scaled];[1_out][2_scaled]overlay=x=0:y=0:enable='between(t,60,74.63)'[2_out];[3:a]volume=1[3_vol];[3_vol]adela [01:31:42.614] y=0|0[3_del];[4:a]volume=0.25[4_vol];[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|600 [01:31:42.614] 00[5_del];[3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [2_out] -preset veryfa [01:31:42.614] st -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/10110/video/86038E22-9A26-1974-689C-1B132026509C.mp4 [01:31:43.213] index :: _onStepProgress_vidbot(), percent: -2783396030 [01:31:43.524] index :: _onStepProgress_vidbot(), percent: 0 [01:31:46.049] index :: _onStepProgress_vidbot(), percent: 5 [01:31:48.608] index :: _onStepProgress_vidbot(), percent: 10 [01:31:51.139] index :: _onStepProgress_vidbot(), percent: 15 [01:31:53.671] index :: _onStepProgress_vidbot(), percent: 20 [01:31:56.273] index :: _onStepProgress_vidbot(), percent: 26 [01:31:57.780] index :: _onStepProgress_vidbot(), percent: 30 [01:31:59.817] index :: _onStepProgress_vidbot(), percent: 35 [01:32:01.847] index :: _onStepProgress_vidbot(), percent: 41 [01:32:03.346] index :: _onStepProgress_vidbot(), percent: 45 [01:32:05.374] index :: _onStepProgress_vidbot(), percent: 50 [01:32:07.413] index :: _onStepProgress_vidbot(), percent: 55 [01:32:08.931] index :: _onStepProgress_vidbot(), percent: 60 [01:32:10.951] index :: _onStepProgress_vidbot(), percent: 65 [01:32:12.997] index :: _onStepProgress_vidbot(), percent: 71 [01:32:14.528] index :: _onStepProgress_vidbot(), percent: 76 [01:32:16.058] index :: _onStepProgress_vidbot(), percent: 80 [01:32:17.569] index :: _onStepProgress_vidbot(), percent: 85 [01:32:19.583] index :: _onStepProgress_vidbot(), percent: 90 [01:32:21.590] index :: _onStepProgress_vidbot(), percent: 96 [01:32:22.811] index :: _onStepProgress_vidbot(), percent: 100 [01:32:22.884] Vidbot :: ffmpeg.on( 'end' ), Done! [01:32:22.885] StreamManager :: dispose() [01:32:22.885] CanvasStream[canvas_1259869803511] :: dispose() [01:32:22.903] Vidbot :: fflog.on( 'finish' ) [01:32:22.904] fflog.path: /var/www/html/clients/10110/video/86038E22-9A26-1974-689C-1B132026509C.mp4.fflog [01:32:22.904] Vidbot :: _next(), _stepIndex:4 of 4 [01:32:22.904] index :: _onStepCompleted_vidbot(), step: 4 [01:32:22.904] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 1245.889, output: '/var/www/html/clients/10110/video/86038E22-9A26-1974-689C-1B132026509C.mp4', duration: 74.63 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/10110/video/86038E22-9A26-1974-689C-1B132026509C.mp4 Media Duration : 00:01:14.629 Generation Time : 00:20:45.888 ---------------------------------------------------------------------------------------------------------------