--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [06:04:59.046] Vidbot :: start() [06:04:59.046] Vidbot :: _next(), _stepIndex:0 of 4 [06:04:59.047] index :: _onStepStarted_vidbot(), step: 1 [06:04:59.048] Vidbot :: step[0], label:Initializing Core [06:04:59.063] index :: _onStepProgress_vidbot(), percent: 20 [06:04:59.064] Vidbot :: _parse() [06:04:59.065] index :: _onStepProgress_vidbot(), percent: 40 [06:04:59.065] Vidbot :: _validate() [06:04:59.066] index :: _onStepProgress_vidbot(), percent: 60 [06:04:59.066] Vidbot :: _fonts() [06:04:59.067] FabricFontManager :: add(), id: SourceSansPro-Bold [06:04:59.067] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [06:04:59.075] FabricFontManager :: add(), id: SourceSansPro-Light [06:04:59.075] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [06:04:59.076] FabricFontManager :: add(), id: DINOT-Bold [06:04:59.076] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [06:04:59.077] FabricFontManager :: add(), id: DINOT-Light [06:04:59.077] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [06:04:59.078] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [06:04:59.078] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [06:04:59.079] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [06:04:59.079] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [06:04:59.080] index :: _onStepProgress_vidbot(), percent: 80 [06:04:59.080] Vidbot :: _clips() [06:04:59.081] StreamManager :: add(), id:audio_vo, type:audio [06:04:59.081] AudioClip[audio_vo] :: constructor() [06:04:59.081] InputStream[audio_vo] :: constructor() [06:04:59.081] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [06:04:59.084] StreamManager :: add(), id:bg_music, type:audio [06:04:59.084] AudioClip[bg_music] :: constructor() [06:04:59.084] InputStream[bg_music] :: constructor() [06:04:59.085] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [06:04:59.085] StreamManager :: add(), id:simplefadedisplay, type:canvas [06:04:59.085] CanvasStream[canvas_725328342502] :: constructor() [06:04:59.085] InputStream[canvas_725328342502] :: constructor() [06:04:59.175] KenBurnsSlideshow[simplefadedisplay] :: constructor() [06:04:59.175] Overlay[simplefadedisplay] :: constructor() [06:04:59.175] CanvasClip[simplefadedisplay] :: constructor() [06:04:59.176] Clip[simplefadedisplay] :: constructor() [06:04:59.176] clip:"simplefadedisplay" added to stream:"canvas_725328342502" [06:04:59.176] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_725328342502', clipId: 'simplefadedisplay' } [06:04:59.176] StreamManager :: add(), id:outro, type:video [06:04:59.176] VideoStream[outro] :: constructor() [06:04:59.176] InputStream[outro] :: constructor() [06:04:59.177] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'outro', clipId: null } [06:04:59.177] all added... [06:04:59.177] Vidbot :: _next(), _stepIndex:1 of 4 [06:04:59.177] index :: _onStepCompleted_vidbot(), step: 1 [06:04:59.177] index :: _onStepStarted_vidbot(), step: 2 [06:04:59.178] Vidbot :: step[1], label:Initializing Input Streams [06:04:59.178] StreamManager :: init() [06:04:59.178] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.25 } [06:04:59.179] index :: _onStepProgress_vidbot(), percent: 25 [06:04:59.179] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.5 } [06:04:59.179] index :: _onStepProgress_vidbot(), percent: 50 [06:04:59.179] CanvasStream[canvas_725328342502] :: _init(), BEGIN [06:04:59.179] i:0, c.id:simplefadedisplay [06:04:59.180] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [06:04:59.180] KenBurnsSlideshow[simplefadedisplay] :: _validate() [06:04:59.181] KenBurnsSlideshow[undefined] :: _validateAnim() [06:04:59.181] KenBurnsSlideshow[undefined] :: _validateTheme() [06:04:59.182] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'outro', progress: 0.75 } [06:04:59.182] index :: _onStepProgress_vidbot(), percent: 75 [06:04:59.183] KenBurnsSlideshow[simplefadedisplay] :: _build() [06:04:59.189] AnimatedImageFrame[aif] :: constructor() [06:04:59.190] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.191] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_1.jpg [06:04:59.254] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.258] AnimatedImageFrame[aif] :: _init(), END [06:04:59.260] AnimatedImageFrame[aif] :: constructor() [06:04:59.260] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.260] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_2.jpg [06:04:59.312] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.314] AnimatedImageFrame[aif] :: _init(), END [06:04:59.315] AnimatedImageFrame[aif] :: constructor() [06:04:59.315] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.315] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_3.jpg [06:04:59.371] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.373] AnimatedImageFrame[aif] :: _init(), END [06:04:59.374] AnimatedImageFrame[aif] :: constructor() [06:04:59.374] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.374] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_4.jpg [06:04:59.420] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.422] AnimatedImageFrame[aif] :: _init(), END [06:04:59.422] AnimatedImageFrame[aif] :: constructor() [06:04:59.423] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.423] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_5.jpg [06:04:59.474] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.475] AnimatedImageFrame[aif] :: _init(), END [06:04:59.475] AnimatedImageFrame[aif] :: constructor() [06:04:59.476] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.476] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_6.jpg [06:04:59.533] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.534] AnimatedImageFrame[aif] :: _init(), END [06:04:59.535] AnimatedImageFrame[aif] :: constructor() [06:04:59.535] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.535] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_7.jpg [06:04:59.587] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.589] AnimatedImageFrame[aif] :: _init(), END [06:04:59.589] AnimatedImageFrame[aif] :: constructor() [06:04:59.589] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.589] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_8.jpg [06:04:59.636] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.638] AnimatedImageFrame[aif] :: _init(), END [06:04:59.638] AnimatedImageFrame[aif] :: constructor() [06:04:59.639] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.639] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_9.jpg [06:04:59.730] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.732] AnimatedImageFrame[aif] :: _init(), END [06:04:59.733] AnimatedImageFrame[aif] :: constructor() [06:04:59.733] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.733] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_10.jpg [06:04:59.792] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.793] AnimatedImageFrame[aif] :: _init(), END [06:04:59.793] AnimatedImageFrame[aif] :: constructor() [06:04:59.793] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.793] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_11.jpg [06:04:59.852] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.853] AnimatedImageFrame[aif] :: _init(), END [06:04:59.854] AnimatedImageFrame[aif] :: constructor() [06:04:59.854] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.854] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_12.jpg [06:04:59.915] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.916] AnimatedImageFrame[aif] :: _init(), END [06:04:59.917] AnimatedImageFrame[aif] :: constructor() [06:04:59.917] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.917] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_13.jpg [06:04:59.975] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:04:59.976] AnimatedImageFrame[aif] :: _init(), END [06:04:59.977] AnimatedImageFrame[aif] :: constructor() [06:04:59.977] AnimatedImageFrame[aif] :: _init(), BEGIN [06:04:59.977] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_14.jpg [06:05:00.036] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.038] AnimatedImageFrame[aif] :: _init(), END [06:05:00.038] AnimatedImageFrame[aif] :: constructor() [06:05:00.038] AnimatedImageFrame[aif] :: _init(), BEGIN [06:05:00.039] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_15.jpg [06:05:00.092] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.093] AnimatedImageFrame[aif] :: _init(), END [06:05:00.094] AnimatedImageFrame[aif] :: constructor() [06:05:00.094] AnimatedImageFrame[aif] :: _init(), BEGIN [06:05:00.094] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_16.jpg [06:05:00.159] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.160] AnimatedImageFrame[aif] :: _init(), END [06:05:00.161] AnimatedImageFrame[aif] :: constructor() [06:05:00.161] AnimatedImageFrame[aif] :: _init(), BEGIN [06:05:00.161] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_17.jpg [06:05:00.218] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.219] AnimatedImageFrame[aif] :: _init(), END [06:05:00.220] AnimatedImageFrame[aif] :: constructor() [06:05:00.220] AnimatedImageFrame[aif] :: _init(), BEGIN [06:05:00.220] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_18.jpg [06:05:00.275] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.282] AnimatedImageFrame[aif] :: _init(), END [06:05:00.283] AnimatedImageFrame[aif] :: constructor() [06:05:00.283] AnimatedImageFrame[aif] :: _init(), BEGIN [06:05:00.283] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_19.jpg [06:05:00.348] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.349] AnimatedImageFrame[aif] :: _init(), END [06:05:00.350] AnimatedImageFrame[aif] :: constructor() [06:05:00.350] AnimatedImageFrame[aif] :: _init(), BEGIN [06:05:00.350] CanvasClip :: LoadImageWithPromise(), src: 68145A00-4460-5349-E495-CCD13427CAA7_20.jpg [06:05:00.415] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [06:05:00.417] AnimatedImageFrame[aif] :: _init(), END [06:05:00.418] Overlay[simplefadedisplay] :: _animate() [06:05:00.419] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [06:05:00.419] CanvasStream[simplefadedisplay] :: _init(), p.then() [06:05:00.419] CanvasStream[canvas_725328342502] :: _init(), promise.all.then() [06:05:00.421] CanvasStream[canvas_725328342502] :: _init(), END [06:05:00.421] StreamMangaer :: init(), stream[canvas_725328342502].then() [06:05:00.421] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_725328342502', progress: 1 } [06:05:00.421] index :: _onStepProgress_vidbot(), percent: 100 [06:05:00.421] StreamManager :: init(), promise.all.then... [06:05:00.421] Vidbot :: StreamMgr.on( 'INITED' ) [06:05:00.422] Vidbot :: _next(), _stepIndex:2 of 4 [06:05:00.422] index :: _onStepCompleted_vidbot(), step: 2 [06:05:00.422] index :: _onStepStarted_vidbot(), step: 3 [06:05:00.422] Vidbot :: step[2], label:Rendering Canvas Streams [06:05:00.423] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [06:05:00.423] StreamManager :: render() [06:05:00.423] CanvasStream[canvas_725328342502] :: render() [06:05:00.541] index :: _onStepProgress_vidbot(), percent: 0 [06:05:41.045] index :: _onStepProgress_vidbot(), percent: 5 [06:06:21.976] index :: _onStepProgress_vidbot(), percent: 10 [06:06:58.215] index :: _onStepProgress_vidbot(), percent: 15 [06:07:31.374] index :: _onStepProgress_vidbot(), percent: 20 [06:08:14.216] index :: _onStepProgress_vidbot(), percent: 25 [06:08:57.105] index :: _onStepProgress_vidbot(), percent: 30 [06:09:45.324] index :: _onStepProgress_vidbot(), percent: 35 [06:10:34.690] index :: _onStepProgress_vidbot(), percent: 40 [06:11:36.255] index :: _onStepProgress_vidbot(), percent: 45 [06:12:50.938] index :: _onStepProgress_vidbot(), percent: 50 [06:14:04.839] index :: _onStepProgress_vidbot(), percent: 55 [06:15:22.473] index :: _onStepProgress_vidbot(), percent: 60 [06:16:39.011] index :: _onStepProgress_vidbot(), percent: 65 [06:17:51.026] index :: _onStepProgress_vidbot(), percent: 70 [06:19:07.550] index :: _onStepProgress_vidbot(), percent: 75 [06:20:24.689] index :: _onStepProgress_vidbot(), percent: 80 [06:21:42.144] index :: _onStepProgress_vidbot(), percent: 85 [06:22:52.711] index :: _onStepProgress_vidbot(), percent: 90 [06:24:16.758] index :: _onStepProgress_vidbot(), percent: 95 [06:25:24.855] index :: _onStepProgress_vidbot(), percent: 100 [06:25:25.726] StreamManager :: render(), Promise.all.then... [06:25:25.727] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [06:25:25.727] Vidbot :: _next(), _stepIndex:3 of 4 [06:25:25.727] index :: _onStepCompleted_vidbot(), step: 3 [06:25:25.728] index :: _onStepStarted_vidbot(), step: 4 [06:25:25.729] Vidbot :: step[3], label:Encoding Media [06:25:25.732] CanvasFilters :: Overlay() [06:25:25.732] VideoStream[outro] :: inputOptions() [06:25:25.732] VideoFilters :: Tpad() [06:25:25.733] VideoFilters :: Scale() [06:25:25.733] VideoFilters :: Overlay() [06:25:25.734] AudioStream[audio_vo] :: inputOptions() [06:25:25.734] AudioFilters :: Volume() [06:25:25.734] filter: [3:a]volume=1[3_vol] [06:25:25.734] AudioFilters :: Delay() [06:25:25.734] filter: [3_vol]adelay=0|0[3_del] [06:25:25.735] AudioStream[bg_music] :: inputOptions() [06:25:25.735] AudioFilters :: Volume() [06:25:25.735] filter: [4:a]volume=0.15[4_vol] [06:25:25.735] AudioFilters :: FadeOut() [06:25:25.735] filter: [4_vol]afade=t=out:st=60:d=1[4_fadeout] [06:25:25.735] AudioFilters :: Delay() [06:25:25.735] filter: [4_fadeout]adelay=0|0[4_del] [06:25:25.735] VideoStream[outro] :: inputOptions() [06:25:25.735] AudioFilters :: Volume() [06:25:25.735] filter: [5:a]volume=1[5_vol] [06:25:25.735] AudioFilters :: Delay() [06:25:25.736] filter: [5_vol]adelay=60000|60000[5_del] [06:25:25.736] AudioFilters :: Mix() [06:25:25.736] filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [06:25:25.736] mixed filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [06:25:25.739] hang.time: 60 [06:25:25.914] Vidbot :: ffmpeg.on( 'start' ) [06:25:25.915] ffmpeg -f lavfi -i color=c=000000:s=1280x720:r=30:duration=67.67 -r 30 -i ./tmp/canvas_725328342502_%05d.png -to 00:00:07.669 -i file:///var/www/html/ [06:25:25.915] clients/21205/library/1280_outro.mp4 -to 00:01:00.000 -i file:///var/www/html/clients/21205/audio/68145A00-4460-5349-E495-CCD13427CAA7.mp3 -to 00:01:0 [06:25:25.915] 0.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Jazz-2.mp3 -to 00:00:07.669 -i file:///var/www/html/clients/21205/library/1280 [06:25:25.915] _outro.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=1280:h=720[2_scaled];[1_out][2_s [06:25:25.915] caled]overlay=x=0:y=0:enable='between(t,60,67.67)'[2_out];[3:a]volume=1[3_vol];[3_vol]adelay=0|0[3_del];[4:a]volume=0.15[4_vol];[4_vol]afade=t=out:st= [06:25:25.915] 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=inputs=3:duration=longe [06:25:25.915] st[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [2_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv4 [06:25:25.915] 20p /var/www/html/clients/21205/video/68145A00-4460-5349-E495-CCD13427CAA7.mp4 [06:25:26.322] index :: _onStepProgress_vidbot(), percent: -3069674091 [06:25:26.721] index :: _onStepProgress_vidbot(), percent: 1 [06:25:28.745] index :: _onStepProgress_vidbot(), percent: 5 [06:25:30.771] index :: _onStepProgress_vidbot(), percent: 10 [06:25:32.822] index :: _onStepProgress_vidbot(), percent: 15 [06:25:35.352] index :: _onStepProgress_vidbot(), percent: 20 [06:25:37.401] index :: _onStepProgress_vidbot(), percent: 25 [06:25:39.922] index :: _onStepProgress_vidbot(), percent: 30 [06:25:41.938] index :: _onStepProgress_vidbot(), percent: 35 [06:25:44.474] index :: _onStepProgress_vidbot(), percent: 41 [06:25:46.515] index :: _onStepProgress_vidbot(), percent: 45 [06:25:48.564] index :: _onStepProgress_vidbot(), percent: 50 [06:25:51.105] index :: _onStepProgress_vidbot(), percent: 56 [06:25:55.643] index :: _onStepProgress_vidbot(), percent: 61 [06:25:57.662] index :: _onStepProgress_vidbot(), percent: 65 [06:25:59.684] index :: _onStepProgress_vidbot(), percent: 70 [06:26:01.732] index :: _onStepProgress_vidbot(), percent: 75 [06:26:03.730] index :: _onStepProgress_vidbot(), percent: 80 [06:26:06.264] index :: _onStepProgress_vidbot(), percent: 85 [06:26:08.286] index :: _onStepProgress_vidbot(), percent: 92 [06:26:09.302] index :: _onStepProgress_vidbot(), percent: 95 [06:26:10.784] index :: _onStepProgress_vidbot(), percent: 100 [06:26:10.891] Vidbot :: ffmpeg.on( 'end' ), Done! [06:26:10.892] StreamManager :: dispose() [06:26:10.892] CanvasStream[canvas_725328342502] :: dispose() [06:26:10.917] Vidbot :: fflog.on( 'finish' ) [06:26:10.917] fflog.path: /var/www/html/clients/21205/video/68145A00-4460-5349-E495-CCD13427CAA7.mp4.fflog [06:26:10.918] Vidbot :: _next(), _stepIndex:4 of 4 [06:26:10.918] index :: _onStepCompleted_vidbot(), step: 4 [06:26:10.918] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 1271.891, output: '/var/www/html/clients/21205/video/68145A00-4460-5349-E495-CCD13427CAA7.mp4', duration: 67.67 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/21205/video/68145A00-4460-5349-E495-CCD13427CAA7.mp4 Media Duration : 00:01:07.670 Generation Time : 00:21:11.891 ---------------------------------------------------------------------------------------------------------------