--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [15:31:17.449] Vidbot :: start() [15:31:17.450] Vidbot :: _next(), _stepIndex:0 of 4 [15:31:17.450] index :: _onStepStarted_vidbot(), step: 1 [15:31:17.452] Vidbot :: step[0], label:Initializing Core [15:31:17.460] index :: _onStepProgress_vidbot(), percent: 20 [15:31:17.460] Vidbot :: _parse() [15:31:17.462] index :: _onStepProgress_vidbot(), percent: 40 [15:31:17.462] Vidbot :: _validate() [15:31:17.462] index :: _onStepProgress_vidbot(), percent: 60 [15:31:17.463] Vidbot :: _fonts() [15:31:17.463] FabricFontManager :: add(), id: SourceSansPro-Bold [15:31:17.463] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [15:31:17.471] FabricFontManager :: add(), id: SourceSansPro-Light [15:31:17.471] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [15:31:17.472] FabricFontManager :: add(), id: DINOT-Bold [15:31:17.472] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [15:31:17.473] FabricFontManager :: add(), id: DINOT-Light [15:31:17.473] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [15:31:17.474] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [15:31:17.474] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [15:31:17.474] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [15:31:17.475] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [15:31:17.476] index :: _onStepProgress_vidbot(), percent: 80 [15:31:17.476] Vidbot :: _clips() [15:31:17.476] StreamManager :: add(), id:audio_vo, type:audio [15:31:17.477] AudioClip[audio_vo] :: constructor() [15:31:17.477] InputStream[audio_vo] :: constructor() [15:31:17.477] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [15:31:17.479] StreamManager :: add(), id:bg_music, type:audio [15:31:17.480] AudioClip[bg_music] :: constructor() [15:31:17.480] InputStream[bg_music] :: constructor() [15:31:17.480] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [15:31:17.480] StreamManager :: add(), id:simplefadedisplay, type:canvas [15:31:17.480] CanvasStream[canvas_1751937425127] :: constructor() [15:31:17.481] InputStream[canvas_1751937425127] :: constructor() [15:31:17.555] KenBurnsSlideshow[simplefadedisplay] :: constructor() [15:31:17.555] Overlay[simplefadedisplay] :: constructor() [15:31:17.555] CanvasClip[simplefadedisplay] :: constructor() [15:31:17.556] Clip[simplefadedisplay] :: constructor() [15:31:17.556] clip:"simplefadedisplay" added to stream:"canvas_1751937425127" [15:31:17.556] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1751937425127', clipId: 'simplefadedisplay' } [15:31:17.556] StreamManager :: add(), id:caption, type:canvas [15:31:17.556] RenCaption[caption] :: constructor() [15:31:17.556] Ren[caption] :: constructor() [15:31:17.556] Overlay[caption] :: constructor() [15:31:17.556] CanvasClip[caption] :: constructor() [15:31:17.556] Clip[caption] :: constructor() [15:31:17.557] clip:"caption" added to stream:"canvas_1751937425127" [15:31:17.557] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1751937425127', clipId: 'caption' } [15:31:17.557] all added... [15:31:17.557] Vidbot :: _next(), _stepIndex:1 of 4 [15:31:17.557] index :: _onStepCompleted_vidbot(), step: 1 [15:31:17.557] index :: _onStepStarted_vidbot(), step: 2 [15:31:17.558] Vidbot :: step[1], label:Initializing Input Streams [15:31:17.558] StreamManager :: init() [15:31:17.558] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [15:31:17.559] index :: _onStepProgress_vidbot(), percent: 33 [15:31:17.559] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [15:31:17.559] index :: _onStepProgress_vidbot(), percent: 67 [15:31:17.559] CanvasStream[canvas_1751937425127] :: _init(), BEGIN [15:31:17.560] i:0, c.id:simplefadedisplay [15:31:17.560] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [15:31:17.560] KenBurnsSlideshow[simplefadedisplay] :: _validate() [15:31:17.561] KenBurnsSlideshow[undefined] :: _validateAnim() [15:31:17.561] KenBurnsSlideshow[undefined] :: _validateTheme() [15:31:17.562] i:1, c.id:caption [15:31:17.562] RenCaption[caption] :: _init() [15:31:17.563] RenCaption[caption] :: _validate() [15:31:17.564] KenBurnsSlideshow[simplefadedisplay] :: _build() [15:31:17.570] AnimatedImageFrame[aif] :: constructor() [15:31:17.571] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.572] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_1.jpg [15:31:17.585] RenCaption[caption] :: _build() [15:31:17.601] Overlay[caption] :: _animate() [15:31:17.604] CanvasStream[caption] :: _init(), p.then() [15:31:17.619] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.622] AnimatedImageFrame[aif] :: _init(), END [15:31:17.624] AnimatedImageFrame[aif] :: constructor() [15:31:17.624] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.624] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_2.jpg [15:31:17.637] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.638] AnimatedImageFrame[aif] :: _init(), END [15:31:17.639] AnimatedImageFrame[aif] :: constructor() [15:31:17.639] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.639] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_3.jpg [15:31:17.650] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.652] AnimatedImageFrame[aif] :: _init(), END [15:31:17.652] AnimatedImageFrame[aif] :: constructor() [15:31:17.652] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.652] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_4.jpg [15:31:17.663] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.664] AnimatedImageFrame[aif] :: _init(), END [15:31:17.665] AnimatedImageFrame[aif] :: constructor() [15:31:17.665] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.665] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_1.jpg [15:31:17.676] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.677] AnimatedImageFrame[aif] :: _init(), END [15:31:17.677] AnimatedImageFrame[aif] :: constructor() [15:31:17.677] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.678] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_2.jpg [15:31:17.688] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.689] AnimatedImageFrame[aif] :: _init(), END [15:31:17.690] AnimatedImageFrame[aif] :: constructor() [15:31:17.690] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.690] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_3.jpg [15:31:17.701] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.701] AnimatedImageFrame[aif] :: _init(), END [15:31:17.702] AnimatedImageFrame[aif] :: constructor() [15:31:17.702] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.702] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_4.jpg [15:31:17.712] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.713] AnimatedImageFrame[aif] :: _init(), END [15:31:17.714] AnimatedImageFrame[aif] :: constructor() [15:31:17.714] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.714] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_1.jpg [15:31:17.724] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.725] AnimatedImageFrame[aif] :: _init(), END [15:31:17.726] AnimatedImageFrame[aif] :: constructor() [15:31:17.726] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.726] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_2.jpg [15:31:17.736] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.737] AnimatedImageFrame[aif] :: _init(), END [15:31:17.738] AnimatedImageFrame[aif] :: constructor() [15:31:17.738] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.738] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_3.jpg [15:31:17.748] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.749] AnimatedImageFrame[aif] :: _init(), END [15:31:17.750] AnimatedImageFrame[aif] :: constructor() [15:31:17.750] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.750] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_4.jpg [15:31:17.760] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.761] AnimatedImageFrame[aif] :: _init(), END [15:31:17.762] AnimatedImageFrame[aif] :: constructor() [15:31:17.762] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.762] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_1.jpg [15:31:17.773] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.774] AnimatedImageFrame[aif] :: _init(), END [15:31:17.774] AnimatedImageFrame[aif] :: constructor() [15:31:17.774] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.774] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_2.jpg [15:31:17.785] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.786] AnimatedImageFrame[aif] :: _init(), END [15:31:17.786] AnimatedImageFrame[aif] :: constructor() [15:31:17.786] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.786] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_3.jpg [15:31:17.797] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.797] AnimatedImageFrame[aif] :: _init(), END [15:31:17.798] AnimatedImageFrame[aif] :: constructor() [15:31:17.798] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.798] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_4.jpg [15:31:17.809] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.810] AnimatedImageFrame[aif] :: _init(), END [15:31:17.810] AnimatedImageFrame[aif] :: constructor() [15:31:17.810] AnimatedImageFrame[aif] :: _init(), BEGIN [15:31:17.810] CanvasClip :: LoadImageWithPromise(), src: 2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71_1.jpg [15:31:17.821] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:31:17.822] AnimatedImageFrame[aif] :: _init(), END [15:31:17.822] Overlay[simplefadedisplay] :: _animate() [15:31:17.823] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [15:31:17.823] CanvasStream[simplefadedisplay] :: _init(), p.then() [15:31:17.823] CanvasStream[canvas_1751937425127] :: _init(), promise.all.then() [15:31:17.825] CanvasStream[canvas_1751937425127] :: _init(), END [15:31:17.825] StreamMangaer :: init(), stream[canvas_1751937425127].then() [15:31:17.825] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1751937425127', progress: 1 } [15:31:17.825] index :: _onStepProgress_vidbot(), percent: 100 [15:31:17.826] StreamManager :: init(), promise.all.then... [15:31:17.826] Vidbot :: StreamMgr.on( 'INITED' ) [15:31:17.826] Vidbot :: _next(), _stepIndex:2 of 4 [15:31:17.826] index :: _onStepCompleted_vidbot(), step: 2 [15:31:17.826] index :: _onStepStarted_vidbot(), step: 3 [15:31:17.826] Vidbot :: step[2], label:Rendering Canvas Streams [15:31:17.827] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [15:31:17.827] StreamManager :: render() [15:31:17.827] CanvasStream[canvas_1751937425127] :: render() [15:31:17.858] index :: _onStepProgress_vidbot(), percent: 0 [15:31:25.663] index :: _onStepProgress_vidbot(), percent: 5 [15:31:34.600] index :: _onStepProgress_vidbot(), percent: 10 [15:31:43.952] index :: _onStepProgress_vidbot(), percent: 15 [15:31:54.410] index :: _onStepProgress_vidbot(), percent: 20 [15:32:02.686] index :: _onStepProgress_vidbot(), percent: 25 [15:32:11.721] index :: _onStepProgress_vidbot(), percent: 30 [15:32:20.847] index :: _onStepProgress_vidbot(), percent: 35 [15:32:29.279] index :: _onStepProgress_vidbot(), percent: 40 [15:32:38.414] index :: _onStepProgress_vidbot(), percent: 45 [15:32:47.348] index :: _onStepProgress_vidbot(), percent: 50 [15:32:55.931] index :: _onStepProgress_vidbot(), percent: 55 [15:33:04.790] index :: _onStepProgress_vidbot(), percent: 60 [15:33:13.934] index :: _onStepProgress_vidbot(), percent: 65 [15:33:22.134] index :: _onStepProgress_vidbot(), percent: 70 [15:33:30.758] index :: _onStepProgress_vidbot(), percent: 75 [15:33:39.172] index :: _onStepProgress_vidbot(), percent: 80 [15:33:48.243] index :: _onStepProgress_vidbot(), percent: 85 [15:33:57.061] index :: _onStepProgress_vidbot(), percent: 90 [15:34:05.902] index :: _onStepProgress_vidbot(), percent: 95 [15:34:14.308] index :: _onStepProgress_vidbot(), percent: 100 [15:34:14.993] StreamManager :: render(), Promise.all.then... [15:34:14.994] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [15:34:14.994] Vidbot :: _next(), _stepIndex:3 of 4 [15:34:14.994] index :: _onStepCompleted_vidbot(), step: 3 [15:34:14.995] index :: _onStepStarted_vidbot(), step: 4 [15:34:14.996] Vidbot :: step[3], label:Encoding Media [15:34:14.998] CanvasFilters :: Overlay() [15:34:14.999] AudioStream[audio_vo] :: inputOptions() [15:34:14.999] AudioFilters :: Volume() [15:34:14.999] filter: [2:a]volume=1[2_vol] [15:34:14.999] AudioFilters :: Delay() [15:34:15.000] filter: [2_vol]adelay=0|0[2_del] [15:34:15.000] AudioStream[bg_music] :: inputOptions() [15:34:15.000] AudioFilters :: Volume() [15:34:15.000] filter: [3:a]volume=0.25[3_vol] [15:34:15.000] AudioFilters :: FadeOut() [15:34:15.000] filter: [3_vol]afade=t=out:st=48.8:d=1[3_fadeout] [15:34:15.000] AudioFilters :: Delay() [15:34:15.000] filter: [3_fadeout]adelay=0|0[3_del] [15:34:15.000] AudioFilters :: Mix() [15:34:15.001] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:34:15.001] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:34:15.003] hang.time: 60 [15:34:15.123] Vidbot :: ffmpeg.on( 'start' ) [15:34:15.124] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=48.8 -r 30 -i ./tmp/canvas_1751937425127_%05d.png -to 00:00:48.799 -i file:///var/www/html/c [15:34:15.124] lients/1301/audio/2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71.mp3 -to 00:00:48.799 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Orchestr [15:34:15.124] a-3_30.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=ou [15:34:15.124] t:st=48.8: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 -ma [15:34:15.124] p [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/1301/video/2E4FE821-2A51-231 [15:34:15.124] C-EC6C-2D2FF1FE5C71.mp4 [15:34:15.280] index :: _onStepProgress_vidbot(), percent: -4256656675 [15:34:15.725] index :: _onStepProgress_vidbot(), percent: 4 [15:34:16.233] index :: _onStepProgress_vidbot(), percent: 8 [15:34:16.735] index :: _onStepProgress_vidbot(), percent: 13 [15:34:17.245] index :: _onStepProgress_vidbot(), percent: 20 [15:34:17.738] index :: _onStepProgress_vidbot(), percent: 25 [15:34:18.238] index :: _onStepProgress_vidbot(), percent: 32 [15:34:18.745] index :: _onStepProgress_vidbot(), percent: 38 [15:34:19.240] index :: _onStepProgress_vidbot(), percent: 45 [15:34:19.740] index :: _onStepProgress_vidbot(), percent: 51 [15:34:20.241] index :: _onStepProgress_vidbot(), percent: 57 [15:34:20.742] index :: _onStepProgress_vidbot(), percent: 62 [15:34:21.243] index :: _onStepProgress_vidbot(), percent: 68 [15:34:21.761] index :: _onStepProgress_vidbot(), percent: 73 [15:34:22.266] index :: _onStepProgress_vidbot(), percent: 79 [15:34:22.770] index :: _onStepProgress_vidbot(), percent: 84 [15:34:23.276] index :: _onStepProgress_vidbot(), percent: 89 [15:34:23.784] index :: _onStepProgress_vidbot(), percent: 94 [15:34:24.184] index :: _onStepProgress_vidbot(), percent: 100 [15:34:24.215] Vidbot :: ffmpeg.on( 'end' ), Done! [15:34:24.215] StreamManager :: dispose() [15:34:24.216] CanvasStream[canvas_1751937425127] :: dispose() [15:34:24.220] Vidbot :: fflog.on( 'finish' ) [15:34:24.221] fflog.path: /var/www/html/clients/1301/video/2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71.mp4.fflog [15:34:24.221] Vidbot :: _next(), _stepIndex:4 of 4 [15:34:24.221] index :: _onStepCompleted_vidbot(), step: 4 [15:34:24.221] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 186.785, output: '/var/www/html/clients/1301/video/2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71.mp4', duration: 48.8 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/1301/video/2E4FE821-2A51-231C-EC6C-2D2FF1FE5C71.mp4 Media Duration : 00:00:48.799 Generation Time : 00:03:06.784 ---------------------------------------------------------------------------------------------------------------