--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [05:31:38.299] Vidbot :: start() [05:31:38.300] Vidbot :: _next(), _stepIndex:0 of 4 [05:31:38.300] index :: _onStepStarted_vidbot(), step: 1 [05:31:38.302] Vidbot :: step[0], label:Initializing Core [05:31:38.311] index :: _onStepProgress_vidbot(), percent: 20 [05:31:38.311] Vidbot :: _parse() [05:31:38.312] index :: _onStepProgress_vidbot(), percent: 40 [05:31:38.313] Vidbot :: _validate() [05:31:38.314] index :: _onStepProgress_vidbot(), percent: 60 [05:31:38.314] Vidbot :: _fonts() [05:31:38.314] FabricFontManager :: add(), id: SourceSansPro-Bold [05:31:38.314] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [05:31:38.324] FabricFontManager :: add(), id: SourceSansPro-Light [05:31:38.324] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [05:31:38.325] FabricFontManager :: add(), id: DINOT-Bold [05:31:38.325] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [05:31:38.325] FabricFontManager :: add(), id: DINOT-Light [05:31:38.326] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [05:31:38.326] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [05:31:38.326] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [05:31:38.327] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [05:31:38.327] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [05:31:38.328] index :: _onStepProgress_vidbot(), percent: 80 [05:31:38.328] Vidbot :: _clips() [05:31:38.329] StreamManager :: add(), id:audio_vo, type:audio [05:31:38.329] AudioClip[audio_vo] :: constructor() [05:31:38.330] InputStream[audio_vo] :: constructor() [05:31:38.330] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [05:31:38.333] StreamManager :: add(), id:bg_music, type:audio [05:31:38.333] AudioClip[bg_music] :: constructor() [05:31:38.333] InputStream[bg_music] :: constructor() [05:31:38.333] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [05:31:38.333] StreamManager :: add(), id:simplefadedisplay, type:canvas [05:31:38.334] CanvasStream[canvas_1714245679895] :: constructor() [05:31:38.334] InputStream[canvas_1714245679895] :: constructor() [05:31:38.411] KenBurnsSlideshow[simplefadedisplay] :: constructor() [05:31:38.412] Overlay[simplefadedisplay] :: constructor() [05:31:38.412] CanvasClip[simplefadedisplay] :: constructor() [05:31:38.412] Clip[simplefadedisplay] :: constructor() [05:31:38.412] clip:"simplefadedisplay" added to stream:"canvas_1714245679895" [05:31:38.412] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1714245679895', clipId: 'simplefadedisplay' } [05:31:38.412] StreamManager :: add(), id:caption, type:canvas [05:31:38.412] RenCaption[caption] :: constructor() [05:31:38.413] Ren[caption] :: constructor() [05:31:38.413] Overlay[caption] :: constructor() [05:31:38.413] CanvasClip[caption] :: constructor() [05:31:38.413] Clip[caption] :: constructor() [05:31:38.413] clip:"caption" added to stream:"canvas_1714245679895" [05:31:38.413] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1714245679895', clipId: 'caption' } [05:31:38.413] all added... [05:31:38.413] Vidbot :: _next(), _stepIndex:1 of 4 [05:31:38.413] index :: _onStepCompleted_vidbot(), step: 1 [05:31:38.414] index :: _onStepStarted_vidbot(), step: 2 [05:31:38.414] Vidbot :: step[1], label:Initializing Input Streams [05:31:38.414] StreamManager :: init() [05:31:38.415] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [05:31:38.415] index :: _onStepProgress_vidbot(), percent: 33 [05:31:38.415] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [05:31:38.415] index :: _onStepProgress_vidbot(), percent: 67 [05:31:38.415] CanvasStream[canvas_1714245679895] :: _init(), BEGIN [05:31:38.416] i:0, c.id:simplefadedisplay [05:31:38.416] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [05:31:38.416] KenBurnsSlideshow[simplefadedisplay] :: _validate() [05:31:38.417] KenBurnsSlideshow[undefined] :: _validateAnim() [05:31:38.417] KenBurnsSlideshow[undefined] :: _validateTheme() [05:31:38.418] i:1, c.id:caption [05:31:38.418] RenCaption[caption] :: _init() [05:31:38.419] RenCaption[caption] :: _validate() [05:31:38.420] KenBurnsSlideshow[simplefadedisplay] :: _build() [05:31:38.426] AnimatedImageFrame[aif] :: constructor() [05:31:38.427] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.427] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_1.jpg [05:31:38.439] RenCaption[caption] :: _build() [05:31:38.456] Overlay[caption] :: _animate() [05:31:38.459] CanvasStream[caption] :: _init(), p.then() [05:31:38.476] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.479] AnimatedImageFrame[aif] :: _init(), END [05:31:38.480] AnimatedImageFrame[aif] :: constructor() [05:31:38.480] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.480] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_2.jpg [05:31:38.500] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.501] AnimatedImageFrame[aif] :: _init(), END [05:31:38.502] AnimatedImageFrame[aif] :: constructor() [05:31:38.502] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.502] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_3.jpg [05:31:38.517] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.518] AnimatedImageFrame[aif] :: _init(), END [05:31:38.519] AnimatedImageFrame[aif] :: constructor() [05:31:38.519] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.519] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_4.jpg [05:31:38.532] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.533] AnimatedImageFrame[aif] :: _init(), END [05:31:38.534] AnimatedImageFrame[aif] :: constructor() [05:31:38.534] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.534] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_1.jpg [05:31:38.547] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.548] AnimatedImageFrame[aif] :: _init(), END [05:31:38.549] AnimatedImageFrame[aif] :: constructor() [05:31:38.549] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.549] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_2.jpg [05:31:38.561] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.562] AnimatedImageFrame[aif] :: _init(), END [05:31:38.562] AnimatedImageFrame[aif] :: constructor() [05:31:38.562] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.563] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_3.jpg [05:31:38.574] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.575] AnimatedImageFrame[aif] :: _init(), END [05:31:38.576] AnimatedImageFrame[aif] :: constructor() [05:31:38.576] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.576] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_4.jpg [05:31:38.588] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.589] AnimatedImageFrame[aif] :: _init(), END [05:31:38.590] AnimatedImageFrame[aif] :: constructor() [05:31:38.590] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.590] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_1.jpg [05:31:38.602] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.603] AnimatedImageFrame[aif] :: _init(), END [05:31:38.603] AnimatedImageFrame[aif] :: constructor() [05:31:38.604] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.604] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_2.jpg [05:31:38.616] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.618] AnimatedImageFrame[aif] :: _init(), END [05:31:38.618] AnimatedImageFrame[aif] :: constructor() [05:31:38.618] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.618] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_3.jpg [05:31:38.631] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.633] AnimatedImageFrame[aif] :: _init(), END [05:31:38.633] AnimatedImageFrame[aif] :: constructor() [05:31:38.633] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.633] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_4.jpg [05:31:38.646] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.647] AnimatedImageFrame[aif] :: _init(), END [05:31:38.647] AnimatedImageFrame[aif] :: constructor() [05:31:38.648] AnimatedImageFrame[aif] :: _init(), BEGIN [05:31:38.648] CanvasClip :: LoadImageWithPromise(), src: 69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D_1.jpg [05:31:38.660] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [05:31:38.661] AnimatedImageFrame[aif] :: _init(), END [05:31:38.661] Overlay[simplefadedisplay] :: _animate() [05:31:38.662] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [05:31:38.662] CanvasStream[simplefadedisplay] :: _init(), p.then() [05:31:38.662] CanvasStream[canvas_1714245679895] :: _init(), promise.all.then() [05:31:38.664] CanvasStream[canvas_1714245679895] :: _init(), END [05:31:38.664] StreamMangaer :: init(), stream[canvas_1714245679895].then() [05:31:38.664] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1714245679895', progress: 1 } [05:31:38.664] index :: _onStepProgress_vidbot(), percent: 100 [05:31:38.664] StreamManager :: init(), promise.all.then... [05:31:38.665] Vidbot :: StreamMgr.on( 'INITED' ) [05:31:38.665] Vidbot :: _next(), _stepIndex:2 of 4 [05:31:38.665] index :: _onStepCompleted_vidbot(), step: 2 [05:31:38.665] index :: _onStepStarted_vidbot(), step: 3 [05:31:38.665] Vidbot :: step[2], label:Rendering Canvas Streams [05:31:38.665] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [05:31:38.666] StreamManager :: render() [05:31:38.666] CanvasStream[canvas_1714245679895] :: render() [05:31:38.698] index :: _onStepProgress_vidbot(), percent: 0 [05:31:47.480] index :: _onStepProgress_vidbot(), percent: 5 [05:31:56.350] index :: _onStepProgress_vidbot(), percent: 10 [05:32:05.623] index :: _onStepProgress_vidbot(), percent: 15 [05:32:15.707] index :: _onStepProgress_vidbot(), percent: 20 [05:32:25.475] index :: _onStepProgress_vidbot(), percent: 25 [05:32:35.522] index :: _onStepProgress_vidbot(), percent: 30 [05:32:45.239] index :: _onStepProgress_vidbot(), percent: 35 [05:32:54.852] index :: _onStepProgress_vidbot(), percent: 40 [05:33:04.608] index :: _onStepProgress_vidbot(), percent: 45 [05:33:14.597] index :: _onStepProgress_vidbot(), percent: 50 [05:33:23.654] index :: _onStepProgress_vidbot(), percent: 55 [05:33:32.700] index :: _onStepProgress_vidbot(), percent: 60 [05:33:42.418] index :: _onStepProgress_vidbot(), percent: 65 [05:33:51.766] index :: _onStepProgress_vidbot(), percent: 70 [05:34:00.718] index :: _onStepProgress_vidbot(), percent: 75 [05:34:09.685] index :: _onStepProgress_vidbot(), percent: 80 [05:34:19.426] index :: _onStepProgress_vidbot(), percent: 85 [05:34:27.777] index :: _onStepProgress_vidbot(), percent: 90 [05:34:36.046] index :: _onStepProgress_vidbot(), percent: 95 [05:34:46.148] index :: _onStepProgress_vidbot(), percent: 100 [05:34:46.998] StreamManager :: render(), Promise.all.then... [05:34:46.998] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [05:34:46.999] Vidbot :: _next(), _stepIndex:3 of 4 [05:34:46.999] index :: _onStepCompleted_vidbot(), step: 3 [05:34:46.999] index :: _onStepStarted_vidbot(), step: 4 [05:34:47.000] Vidbot :: step[3], label:Encoding Media [05:34:47.003] CanvasFilters :: Overlay() [05:34:47.003] AudioStream[audio_vo] :: inputOptions() [05:34:47.004] AudioFilters :: Volume() [05:34:47.004] filter: [2:a]volume=1[2_vol] [05:34:47.004] AudioFilters :: Delay() [05:34:47.004] filter: [2_vol]adelay=0|0[2_del] [05:34:47.004] AudioStream[bg_music] :: inputOptions() [05:34:47.005] AudioFilters :: Volume() [05:34:47.005] filter: [3:a]volume=0.25[3_vol] [05:34:47.005] AudioFilters :: FadeOut() [05:34:47.005] filter: [3_vol]afade=t=out:st=36.58:d=1[3_fadeout] [05:34:47.005] AudioFilters :: Delay() [05:34:47.005] filter: [3_fadeout]adelay=0|0[3_del] [05:34:47.005] AudioFilters :: Mix() [05:34:47.005] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [05:34:47.005] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [05:34:47.008] hang.time: 60 [05:34:47.094] Vidbot :: ffmpeg.on( 'start' ) [05:34:47.094] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=36.58 -r 30 -i ./tmp/canvas_1714245679895_%05d.png -to 00:00:36.579 -i file:///var/www/html/ [05:34:47.094] clients/1301/audio/69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D.mp3 -to 00:00:36.579 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Concept [05:34:47.094] 1.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= [05:34:47.094] 36.58: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 [05:34:47.094] _out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/1301/video/69FD2BFB-2C1C-1F04-47 [05:34:47.094] 5C-5F55DBCD8C1D.mp4 [05:34:47.223] index :: _onStepProgress_vidbot(), percent: -5678645318 [05:34:47.672] index :: _onStepProgress_vidbot(), percent: 3 [05:34:48.176] index :: _onStepProgress_vidbot(), percent: 7 [05:34:48.676] index :: _onStepProgress_vidbot(), percent: 12 [05:34:49.183] index :: _onStepProgress_vidbot(), percent: 17 [05:34:49.684] index :: _onStepProgress_vidbot(), percent: 22 [05:34:50.192] index :: _onStepProgress_vidbot(), percent: 27 [05:34:50.696] index :: _onStepProgress_vidbot(), percent: 33 [05:34:51.198] index :: _onStepProgress_vidbot(), percent: 38 [05:34:51.704] index :: _onStepProgress_vidbot(), percent: 43 [05:34:52.208] index :: _onStepProgress_vidbot(), percent: 49 [05:34:52.718] index :: _onStepProgress_vidbot(), percent: 54 [05:34:53.212] index :: _onStepProgress_vidbot(), percent: 59 [05:34:53.715] index :: _onStepProgress_vidbot(), percent: 64 [05:34:54.222] index :: _onStepProgress_vidbot(), percent: 71 [05:34:54.728] index :: _onStepProgress_vidbot(), percent: 77 [05:34:55.240] index :: _onStepProgress_vidbot(), percent: 82 [05:34:55.737] index :: _onStepProgress_vidbot(), percent: 86 [05:34:56.246] index :: _onStepProgress_vidbot(), percent: 92 [05:34:56.751] index :: _onStepProgress_vidbot(), percent: 98 [05:34:56.912] index :: _onStepProgress_vidbot(), percent: 100 [05:34:56.942] Vidbot :: ffmpeg.on( 'end' ), Done! [05:34:56.943] StreamManager :: dispose() [05:34:56.943] CanvasStream[canvas_1714245679895] :: dispose() [05:34:56.948] Vidbot :: fflog.on( 'finish' ) [05:34:56.948] fflog.path: /var/www/html/clients/1301/video/69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D.mp4.fflog [05:34:56.948] Vidbot :: _next(), _stepIndex:4 of 4 [05:34:56.948] index :: _onStepCompleted_vidbot(), step: 4 [05:34:56.948] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 198.669, output: '/var/www/html/clients/1301/video/69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D.mp4', duration: 36.58 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/1301/video/69FD2BFB-2C1C-1F04-475C-5F55DBCD8C1D.mp4 Media Duration : 00:00:36.579 Generation Time : 00:03:18.669 ---------------------------------------------------------------------------------------------------------------