--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.6.0... --------------------------------------------------------------------------------------------------------------- [22:01:29.740] Vidbot :: start() [22:01:29.740] Vidbot :: _next(), _stepIndex:0 of 4 [22:01:29.741] index :: _onStepStarted_vidbot(), step: 1 [22:01:29.742] Vidbot :: step[0], label:Initializing Core [22:01:29.750] index :: _onStepProgress_vidbot(), percent: 20 [22:01:29.750] Vidbot :: _parse() [22:01:29.752] index :: _onStepProgress_vidbot(), percent: 40 [22:01:29.752] Vidbot :: _validate() [22:01:29.753] index :: _onStepProgress_vidbot(), percent: 60 [22:01:29.753] Vidbot :: _fonts() [22:01:29.753] FabricFontManager :: add(), id: SourceSansPro-Bold [22:01:29.753] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [22:01:29.761] FabricFontManager :: add(), id: SourceSansPro-Light [22:01:29.761] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [22:01:29.762] FabricFontManager :: add(), id: DINOT-Bold [22:01:29.762] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [22:01:29.763] FabricFontManager :: add(), id: DINOT-Light [22:01:29.763] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [22:01:29.764] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [22:01:29.764] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [22:01:29.765] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [22:01:29.765] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [22:01:29.766] index :: _onStepProgress_vidbot(), percent: 80 [22:01:29.766] Vidbot :: _clips() [22:01:29.767] StreamManager :: add(), id:audio_vo, type:audio [22:01:29.767] AudioClip[audio_vo] :: constructor() [22:01:29.767] InputStream[audio_vo] :: constructor() [22:01:29.767] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [22:01:29.770] StreamManager :: add(), id:bg_music, type:audio [22:01:29.770] AudioClip[bg_music] :: constructor() [22:01:29.770] InputStream[bg_music] :: constructor() [22:01:29.770] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [22:01:29.771] StreamManager :: add(), id:simplefadedisplay, type:canvas [22:01:29.771] CanvasStream[canvas_1239462824442] :: constructor() [22:01:29.771] InputStream[canvas_1239462824442] :: constructor() [22:01:29.849] KenBurnsSlideshow[simplefadedisplay] :: constructor() [22:01:29.849] Overlay[simplefadedisplay] :: constructor() [22:01:29.849] CanvasClip[simplefadedisplay] :: constructor() [22:01:29.849] Clip[simplefadedisplay] :: constructor() [22:01:29.849] clip:"simplefadedisplay" added to stream:"canvas_1239462824442" [22:01:29.849] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1239462824442', clipId: 'simplefadedisplay' } [22:01:29.850] StreamManager :: add(), id:caption, type:canvas [22:01:29.850] RenCaption[caption] :: constructor() [22:01:29.850] Ren[caption] :: constructor() [22:01:29.850] Overlay[caption] :: constructor() [22:01:29.850] CanvasClip[caption] :: constructor() [22:01:29.850] Clip[caption] :: constructor() [22:01:29.850] clip:"caption" added to stream:"canvas_1239462824442" [22:01:29.850] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1239462824442', clipId: 'caption' } [22:01:29.850] all added... [22:01:29.851] Vidbot :: _next(), _stepIndex:1 of 4 [22:01:29.851] index :: _onStepCompleted_vidbot(), step: 1 [22:01:29.851] index :: _onStepStarted_vidbot(), step: 2 [22:01:29.851] Vidbot :: step[1], label:Initializing Input Streams [22:01:29.852] StreamManager :: init() [22:01:29.852] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [22:01:29.852] index :: _onStepProgress_vidbot(), percent: 33 [22:01:29.852] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [22:01:29.852] index :: _onStepProgress_vidbot(), percent: 67 [22:01:29.853] CanvasStream[canvas_1239462824442] :: _init(), BEGIN [22:01:29.853] i:0, c.id:simplefadedisplay [22:01:29.853] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [22:01:29.854] KenBurnsSlideshow[simplefadedisplay] :: _validate() [22:01:29.854] KenBurnsSlideshow[undefined] :: _validateAnim() [22:01:29.854] KenBurnsSlideshow[undefined] :: _validateTheme() [22:01:29.856] i:1, c.id:caption [22:01:29.856] RenCaption[caption] :: _init() [22:01:29.856] RenCaption[caption] :: _validate() [22:01:29.857] KenBurnsSlideshow[simplefadedisplay] :: _build() [22:01:29.863] AnimatedImageFrame[aif] :: constructor() [22:01:29.864] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:29.864] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_1.jpg [22:01:29.878] RenCaption[caption] :: _build() [22:01:29.896] Overlay[caption] :: _animate() [22:01:29.899] CanvasStream[caption] :: _init(), p.then() [22:01:29.934] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:29.946] AnimatedImageFrame[aif] :: _init(), END [22:01:29.948] AnimatedImageFrame[aif] :: constructor() [22:01:29.948] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:29.948] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_2.jpg [22:01:29.970] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:29.971] AnimatedImageFrame[aif] :: _init(), END [22:01:29.972] AnimatedImageFrame[aif] :: constructor() [22:01:29.972] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:29.972] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_3.jpg [22:01:29.993] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:29.995] AnimatedImageFrame[aif] :: _init(), END [22:01:29.995] AnimatedImageFrame[aif] :: constructor() [22:01:29.995] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:29.995] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_4.jpg [22:01:30.015] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.016] AnimatedImageFrame[aif] :: _init(), END [22:01:30.017] AnimatedImageFrame[aif] :: constructor() [22:01:30.017] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.017] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_5.jpg [22:01:30.035] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.036] AnimatedImageFrame[aif] :: _init(), END [22:01:30.036] AnimatedImageFrame[aif] :: constructor() [22:01:30.037] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.037] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_6.jpg [22:01:30.053] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.054] AnimatedImageFrame[aif] :: _init(), END [22:01:30.055] AnimatedImageFrame[aif] :: constructor() [22:01:30.055] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.055] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_7.jpg [22:01:30.075] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.076] AnimatedImageFrame[aif] :: _init(), END [22:01:30.076] AnimatedImageFrame[aif] :: constructor() [22:01:30.077] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.077] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_8.jpg [22:01:30.095] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.096] AnimatedImageFrame[aif] :: _init(), END [22:01:30.096] AnimatedImageFrame[aif] :: constructor() [22:01:30.097] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.097] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_9.jpg [22:01:30.116] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.117] AnimatedImageFrame[aif] :: _init(), END [22:01:30.117] AnimatedImageFrame[aif] :: constructor() [22:01:30.118] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.118] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_10.jpg [22:01:30.136] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.137] AnimatedImageFrame[aif] :: _init(), END [22:01:30.138] AnimatedImageFrame[aif] :: constructor() [22:01:30.138] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.138] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_11.jpg [22:01:30.159] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.160] AnimatedImageFrame[aif] :: _init(), END [22:01:30.160] AnimatedImageFrame[aif] :: constructor() [22:01:30.160] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.160] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_12.jpg [22:01:30.180] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.181] AnimatedImageFrame[aif] :: _init(), END [22:01:30.181] AnimatedImageFrame[aif] :: constructor() [22:01:30.182] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.182] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_13.jpg [22:01:30.201] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.202] AnimatedImageFrame[aif] :: _init(), END [22:01:30.203] AnimatedImageFrame[aif] :: constructor() [22:01:30.203] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.203] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_14.jpg [22:01:30.222] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.223] AnimatedImageFrame[aif] :: _init(), END [22:01:30.223] AnimatedImageFrame[aif] :: constructor() [22:01:30.224] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.224] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_15.jpg [22:01:30.242] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.243] AnimatedImageFrame[aif] :: _init(), END [22:01:30.243] AnimatedImageFrame[aif] :: constructor() [22:01:30.243] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.244] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_16.jpg [22:01:30.260] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.261] AnimatedImageFrame[aif] :: _init(), END [22:01:30.262] AnimatedImageFrame[aif] :: constructor() [22:01:30.262] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.262] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_17.jpg [22:01:30.281] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.282] AnimatedImageFrame[aif] :: _init(), END [22:01:30.283] AnimatedImageFrame[aif] :: constructor() [22:01:30.283] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.283] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_18.jpg [22:01:30.302] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.302] AnimatedImageFrame[aif] :: _init(), END [22:01:30.303] AnimatedImageFrame[aif] :: constructor() [22:01:30.303] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.303] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_19.jpg [22:01:30.333] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.334] AnimatedImageFrame[aif] :: _init(), END [22:01:30.334] AnimatedImageFrame[aif] :: constructor() [22:01:30.335] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.335] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_20.jpg [22:01:30.353] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.355] AnimatedImageFrame[aif] :: _init(), END [22:01:30.355] AnimatedImageFrame[aif] :: constructor() [22:01:30.355] AnimatedImageFrame[aif] :: _init(), BEGIN [22:01:30.355] CanvasClip :: LoadImageWithPromise(), src: 2290B07E-CD81-742E-D946-7BAF1AFADF93_1.jpg [22:01:30.375] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:01:30.376] AnimatedImageFrame[aif] :: _init(), END [22:01:30.377] Overlay[simplefadedisplay] :: _animate() [22:01:30.378] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [22:01:30.378] CanvasStream[simplefadedisplay] :: _init(), p.then() [22:01:30.378] CanvasStream[canvas_1239462824442] :: _init(), promise.all.then() [22:01:30.380] CanvasStream[canvas_1239462824442] :: _init(), END [22:01:30.380] StreamMangaer :: init(), stream[canvas_1239462824442].then() [22:01:30.380] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1239462824442', progress: 1 } [22:01:30.380] index :: _onStepProgress_vidbot(), percent: 100 [22:01:30.380] StreamManager :: init(), promise.all.then... [22:01:30.380] Vidbot :: StreamMgr.on( 'INITED' ) [22:01:30.381] Vidbot :: _next(), _stepIndex:2 of 4 [22:01:30.381] index :: _onStepCompleted_vidbot(), step: 2 [22:01:30.381] index :: _onStepStarted_vidbot(), step: 3 [22:01:30.381] Vidbot :: step[2], label:Rendering Canvas Streams [22:01:30.381] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [22:01:30.382] StreamManager :: render() [22:01:30.382] CanvasStream[canvas_1239462824442] :: render() [22:01:30.413] index :: _onStepProgress_vidbot(), percent: 0 [22:01:48.229] index :: _onStepProgress_vidbot(), percent: 5 [22:02:07.196] index :: _onStepProgress_vidbot(), percent: 10 [22:02:23.671] index :: _onStepProgress_vidbot(), percent: 15 [22:02:41.437] index :: _onStepProgress_vidbot(), percent: 20 [22:02:58.923] index :: _onStepProgress_vidbot(), percent: 25 [22:03:16.155] index :: _onStepProgress_vidbot(), percent: 30 [22:03:35.798] index :: _onStepProgress_vidbot(), percent: 35 [22:03:55.199] index :: _onStepProgress_vidbot(), percent: 40 [22:04:15.085] index :: _onStepProgress_vidbot(), percent: 45 [22:04:36.025] index :: _onStepProgress_vidbot(), percent: 50 [22:04:55.963] index :: _onStepProgress_vidbot(), percent: 55 [22:05:12.530] index :: _onStepProgress_vidbot(), percent: 60 [22:05:29.831] index :: _onStepProgress_vidbot(), percent: 65 [22:05:48.733] index :: _onStepProgress_vidbot(), percent: 70 [22:06:08.093] index :: _onStepProgress_vidbot(), percent: 75 [22:06:25.887] index :: _onStepProgress_vidbot(), percent: 80 [22:06:44.825] index :: _onStepProgress_vidbot(), percent: 85 [22:07:04.783] index :: _onStepProgress_vidbot(), percent: 90 [22:07:21.687] index :: _onStepProgress_vidbot(), percent: 95 [22:07:41.185] index :: _onStepProgress_vidbot(), percent: 100 [22:07:43.182] StreamManager :: render(), Promise.all.then... [22:07:43.183] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [22:07:43.183] Vidbot :: _next(), _stepIndex:3 of 4 [22:07:43.183] index :: _onStepCompleted_vidbot(), step: 3 [22:07:43.184] index :: _onStepStarted_vidbot(), step: 4 [22:07:43.185] Vidbot :: step[3], label:Encoding Media [22:07:43.189] CanvasFilters :: Overlay() [22:07:43.189] AudioStream[audio_vo] :: inputOptions() [22:07:43.190] AudioFilters :: Volume() [22:07:43.190] filter: [2:a]volume=1[2_vol] [22:07:43.190] AudioFilters :: Delay() [22:07:43.190] filter: [2_vol]adelay=0|0[2_del] [22:07:43.190] AudioStream[bg_music] :: inputOptions() [22:07:43.190] AudioFilters :: Volume() [22:07:43.190] filter: [3:a]volume=0.25[3_vol] [22:07:43.191] AudioFilters :: FadeOut() [22:07:43.191] filter: [3_vol]afade=t=out:st=60.05:d=1[3_fadeout] [22:07:43.191] AudioFilters :: Delay() [22:07:43.191] filter: [3_fadeout]adelay=0|0[3_del] [22:07:43.191] AudioFilters :: Mix() [22:07:43.191] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [22:07:43.191] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [22:07:43.194] hang.time: 60 [22:07:43.306] Vidbot :: ffmpeg.on( 'start' ) [22:07:43.306] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60.05 -r 30 -i ./tmp/canvas_1239462824442_%05d.png -to 00:01:00.049 -i file:///var/www/html/ [22:07:43.306] clients/9172/audio/2290B07E-CD81-742E-D946-7BAF1AFADF93.mp3 -to 00:01:00.049 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/PushPin [22:07:43.306] .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 [22:07:43.307] 0.05: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_ [22:07:43.307] out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/9172/video/2290B07E-CD81-742E-D94 [22:07:43.307] 6-7BAF1AFADF93.mp4 [22:07:43.507] index :: _onStepProgress_vidbot(), percent: -3459198097 [22:07:43.897] index :: _onStepProgress_vidbot(), percent: 1 [22:07:44.918] index :: _onStepProgress_vidbot(), percent: 5 [22:07:46.440] index :: _onStepProgress_vidbot(), percent: 11 [22:07:47.951] index :: _onStepProgress_vidbot(), percent: 16 [22:07:48.982] index :: _onStepProgress_vidbot(), percent: 20 [22:07:49.999] index :: _onStepProgress_vidbot(), percent: 25 [22:07:51.010] index :: _onStepProgress_vidbot(), percent: 30 [22:07:52.021] index :: _onStepProgress_vidbot(), percent: 35 [22:07:53.036] index :: _onStepProgress_vidbot(), percent: 41 [22:07:54.051] index :: _onStepProgress_vidbot(), percent: 46 [22:07:55.072] index :: _onStepProgress_vidbot(), percent: 52 [22:07:55.573] index :: _onStepProgress_vidbot(), percent: 55 [22:07:56.590] index :: _onStepProgress_vidbot(), percent: 61 [22:07:57.598] index :: _onStepProgress_vidbot(), percent: 66 [22:07:58.100] index :: _onStepProgress_vidbot(), percent: 70 [22:07:59.108] index :: _onStepProgress_vidbot(), percent: 76 [22:07:59.608] index :: _onStepProgress_vidbot(), percent: 80 [22:08:00.614] index :: _onStepProgress_vidbot(), percent: 86 [22:08:01.621] index :: _onStepProgress_vidbot(), percent: 92 [22:08:02.639] index :: _onStepProgress_vidbot(), percent: 96 [22:08:03.405] index :: _onStepProgress_vidbot(), percent: 100 [22:08:03.450] Vidbot :: ffmpeg.on( 'end' ), Done! [22:08:03.450] StreamManager :: dispose() [22:08:03.451] CanvasStream[canvas_1239462824442] :: dispose() [22:08:03.456] Vidbot :: fflog.on( 'finish' ) [22:08:03.456] fflog.path: /var/www/html/clients/9172/video/2290B07E-CD81-742E-D946-7BAF1AFADF93.mp4.fflog [22:08:03.456] Vidbot :: _next(), _stepIndex:4 of 4 [22:08:03.456] index :: _onStepCompleted_vidbot(), step: 4 [22:08:03.457] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 393.737, output: '/var/www/html/clients/9172/video/2290B07E-CD81-742E-D946-7BAF1AFADF93.mp4', duration: 60.05 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/9172/video/2290B07E-CD81-742E-D946-7BAF1AFADF93.mp4 Media Duration : 00:01:00.049 Generation Time : 00:06:33.737 ---------------------------------------------------------------------------------------------------------------