--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.6.0... --------------------------------------------------------------------------------------------------------------- [02:33:31.301] Vidbot :: start() [02:33:31.301] Vidbot :: _next(), _stepIndex:0 of 4 [02:33:31.301] index :: _onStepStarted_vidbot(), step: 1 [02:33:31.303] Vidbot :: step[0], label:Initializing Core [02:33:31.310] index :: _onStepProgress_vidbot(), percent: 20 [02:33:31.311] Vidbot :: _parse() [02:33:31.312] index :: _onStepProgress_vidbot(), percent: 40 [02:33:31.312] Vidbot :: _validate() [02:33:31.313] index :: _onStepProgress_vidbot(), percent: 60 [02:33:31.313] Vidbot :: _fonts() [02:33:31.313] FabricFontManager :: add(), id: SourceSansPro-Bold [02:33:31.313] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [02:33:31.321] FabricFontManager :: add(), id: SourceSansPro-Light [02:33:31.321] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [02:33:31.322] FabricFontManager :: add(), id: DINOT-Bold [02:33:31.322] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [02:33:31.323] FabricFontManager :: add(), id: DINOT-Light [02:33:31.323] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [02:33:31.324] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [02:33:31.324] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [02:33:31.325] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [02:33:31.325] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [02:33:31.326] index :: _onStepProgress_vidbot(), percent: 80 [02:33:31.326] Vidbot :: _clips() [02:33:31.326] StreamManager :: add(), id:audio_vo, type:audio [02:33:31.327] AudioClip[audio_vo] :: constructor() [02:33:31.327] InputStream[audio_vo] :: constructor() [02:33:31.327] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [02:33:31.330] StreamManager :: add(), id:bg_music, type:audio [02:33:31.330] AudioClip[bg_music] :: constructor() [02:33:31.330] InputStream[bg_music] :: constructor() [02:33:31.330] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [02:33:31.330] StreamManager :: add(), id:intro, type:video [02:33:31.331] VideoStream[intro] :: constructor() [02:33:31.331] InputStream[intro] :: constructor() [02:33:31.331] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'intro', clipId: null } [02:33:31.331] StreamManager :: add(), id:simplefadedisplay, type:canvas [02:33:31.331] CanvasStream[canvas_1702032783660] :: constructor() [02:33:31.331] InputStream[canvas_1702032783660] :: constructor() [02:33:31.406] KenBurnsSlideshow[simplefadedisplay] :: constructor() [02:33:31.406] Overlay[simplefadedisplay] :: constructor() [02:33:31.406] CanvasClip[simplefadedisplay] :: constructor() [02:33:31.406] Clip[simplefadedisplay] :: constructor() [02:33:31.407] clip:"simplefadedisplay" added to stream:"canvas_1702032783660" [02:33:31.407] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1702032783660', clipId: 'simplefadedisplay' } [02:33:31.407] StreamManager :: add(), id:caption, type:canvas [02:33:31.407] RenCaption[caption] :: constructor() [02:33:31.407] Ren[caption] :: constructor() [02:33:31.407] Overlay[caption] :: constructor() [02:33:31.407] CanvasClip[caption] :: constructor() [02:33:31.407] Clip[caption] :: constructor() [02:33:31.407] clip:"caption" added to stream:"canvas_1702032783660" [02:33:31.407] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1702032783660', clipId: 'caption' } [02:33:31.408] StreamManager :: add(), id:outro, type:video [02:33:31.408] VideoStream[outro] :: constructor() [02:33:31.408] InputStream[outro] :: constructor() [02:33:31.408] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'outro', clipId: null } [02:33:31.408] all added... [02:33:31.408] Vidbot :: _next(), _stepIndex:1 of 4 [02:33:31.408] index :: _onStepCompleted_vidbot(), step: 1 [02:33:31.408] index :: _onStepStarted_vidbot(), step: 2 [02:33:31.409] Vidbot :: step[1], label:Initializing Input Streams [02:33:31.409] StreamManager :: init() [02:33:31.409] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.2 } [02:33:31.409] index :: _onStepProgress_vidbot(), percent: 20 [02:33:31.410] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.4 } [02:33:31.410] index :: _onStepProgress_vidbot(), percent: 40 [02:33:31.410] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'intro', progress: 0.6 } [02:33:31.410] index :: _onStepProgress_vidbot(), percent: 60 [02:33:31.410] CanvasStream[canvas_1702032783660] :: _init(), BEGIN [02:33:31.410] i:0, c.id:simplefadedisplay [02:33:31.411] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [02:33:31.411] KenBurnsSlideshow[simplefadedisplay] :: _validate() [02:33:31.411] KenBurnsSlideshow[undefined] :: _validateAnim() [02:33:31.412] KenBurnsSlideshow[undefined] :: _validateTheme() [02:33:31.413] i:1, c.id:caption [02:33:31.413] RenCaption[caption] :: _init() [02:33:31.413] RenCaption[caption] :: _validate() [02:33:31.414] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'outro', progress: 0.8 } [02:33:31.414] index :: _onStepProgress_vidbot(), percent: 80 [02:33:31.415] KenBurnsSlideshow[simplefadedisplay] :: _build() [02:33:31.420] AnimatedImageFrame[aif] :: constructor() [02:33:31.421] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.421] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_1.jpg [02:33:31.432] RenCaption[caption] :: _build() [02:33:31.446] Overlay[caption] :: _animate() [02:33:31.449] CanvasStream[caption] :: _init(), p.then() [02:33:31.470] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.473] AnimatedImageFrame[aif] :: _init(), END [02:33:31.475] AnimatedImageFrame[aif] :: constructor() [02:33:31.476] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.476] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_2.jpg [02:33:31.489] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.490] AnimatedImageFrame[aif] :: _init(), END [02:33:31.491] AnimatedImageFrame[aif] :: constructor() [02:33:31.491] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.491] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_3.jpg [02:33:31.515] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.516] AnimatedImageFrame[aif] :: _init(), END [02:33:31.517] AnimatedImageFrame[aif] :: constructor() [02:33:31.517] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.517] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_4.jpg [02:33:31.528] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.528] AnimatedImageFrame[aif] :: _init(), END [02:33:31.529] AnimatedImageFrame[aif] :: constructor() [02:33:31.529] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.529] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_1.jpg [02:33:31.543] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.544] AnimatedImageFrame[aif] :: _init(), END [02:33:31.544] AnimatedImageFrame[aif] :: constructor() [02:33:31.544] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.544] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_2.jpg [02:33:31.554] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.555] AnimatedImageFrame[aif] :: _init(), END [02:33:31.556] AnimatedImageFrame[aif] :: constructor() [02:33:31.556] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.556] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_3.jpg [02:33:31.568] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.569] AnimatedImageFrame[aif] :: _init(), END [02:33:31.570] AnimatedImageFrame[aif] :: constructor() [02:33:31.570] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.570] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_4.jpg [02:33:31.579] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.580] AnimatedImageFrame[aif] :: _init(), END [02:33:31.581] AnimatedImageFrame[aif] :: constructor() [02:33:31.581] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.581] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_1.jpg [02:33:31.594] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.595] AnimatedImageFrame[aif] :: _init(), END [02:33:31.595] AnimatedImageFrame[aif] :: constructor() [02:33:31.595] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.595] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_2.jpg [02:33:31.605] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.606] AnimatedImageFrame[aif] :: _init(), END [02:33:31.606] AnimatedImageFrame[aif] :: constructor() [02:33:31.607] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.607] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_3.jpg [02:33:31.634] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.635] AnimatedImageFrame[aif] :: _init(), END [02:33:31.636] AnimatedImageFrame[aif] :: constructor() [02:33:31.636] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.636] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_4.jpg [02:33:31.646] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.647] AnimatedImageFrame[aif] :: _init(), END [02:33:31.647] AnimatedImageFrame[aif] :: constructor() [02:33:31.647] AnimatedImageFrame[aif] :: _init(), BEGIN [02:33:31.647] CanvasClip :: LoadImageWithPromise(), src: D7F99E4D-4D42-4B26-251E-1D48642E03B3_1.jpg [02:33:31.662] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:33:31.663] AnimatedImageFrame[aif] :: _init(), END [02:33:31.663] Overlay[simplefadedisplay] :: _animate() [02:33:31.663] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [02:33:31.664] CanvasStream[simplefadedisplay] :: _init(), p.then() [02:33:31.664] CanvasStream[canvas_1702032783660] :: _init(), promise.all.then() [02:33:31.666] CanvasStream[canvas_1702032783660] :: _init(), END [02:33:31.666] StreamMangaer :: init(), stream[canvas_1702032783660].then() [02:33:31.666] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1702032783660', progress: 1 } [02:33:31.666] index :: _onStepProgress_vidbot(), percent: 100 [02:33:31.666] StreamManager :: init(), promise.all.then... [02:33:31.667] Vidbot :: StreamMgr.on( 'INITED' ) [02:33:31.667] Vidbot :: _next(), _stepIndex:2 of 4 [02:33:31.667] index :: _onStepCompleted_vidbot(), step: 2 [02:33:31.667] index :: _onStepStarted_vidbot(), step: 3 [02:33:31.667] Vidbot :: step[2], label:Rendering Canvas Streams [02:33:31.668] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [02:33:31.668] StreamManager :: render() [02:33:31.668] CanvasStream[canvas_1702032783660] :: render() [02:33:31.698] index :: _onStepProgress_vidbot(), percent: 0 [02:33:34.263] index :: _onStepProgress_vidbot(), percent: 5 [02:33:37.276] index :: _onStepProgress_vidbot(), percent: 10 [02:33:40.417] index :: _onStepProgress_vidbot(), percent: 15 [02:33:43.723] index :: _onStepProgress_vidbot(), percent: 20 [02:33:46.575] index :: _onStepProgress_vidbot(), percent: 25 [02:33:49.555] index :: _onStepProgress_vidbot(), percent: 30 [02:33:52.722] index :: _onStepProgress_vidbot(), percent: 35 [02:33:55.844] index :: _onStepProgress_vidbot(), percent: 40 [02:34:07.593] index :: _onStepProgress_vidbot(), percent: 45 [02:34:19.793] index :: _onStepProgress_vidbot(), percent: 50 [02:34:29.766] index :: _onStepProgress_vidbot(), percent: 55 [02:34:38.535] index :: _onStepProgress_vidbot(), percent: 60 [02:34:54.310] index :: _onStepProgress_vidbot(), percent: 65 [02:35:04.417] index :: _onStepProgress_vidbot(), percent: 70 [02:35:15.110] index :: _onStepProgress_vidbot(), percent: 75 [02:35:28.763] index :: _onStepProgress_vidbot(), percent: 80 [02:35:43.943] index :: _onStepProgress_vidbot(), percent: 85 [02:35:55.383] index :: _onStepProgress_vidbot(), percent: 90 [02:36:05.151] index :: _onStepProgress_vidbot(), percent: 95 [02:36:20.096] index :: _onStepProgress_vidbot(), percent: 100 [02:36:20.380] StreamManager :: render(), Promise.all.then... [02:36:20.381] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [02:36:20.381] Vidbot :: _next(), _stepIndex:3 of 4 [02:36:20.381] index :: _onStepCompleted_vidbot(), step: 3 [02:36:20.382] index :: _onStepStarted_vidbot(), step: 4 [02:36:20.383] Vidbot :: step[3], label:Encoding Media [02:36:20.385] VideoStream[intro] :: inputOptions() [02:36:20.386] VideoFilters :: Scale() [02:36:20.386] VideoFilters :: Overlay() [02:36:20.387] CanvasFilters :: Overlay() [02:36:20.387] VideoStream[outro] :: inputOptions() [02:36:20.387] VideoFilters :: Tpad() [02:36:20.387] VideoFilters :: Scale() [02:36:20.387] VideoFilters :: Overlay() [02:36:20.388] AudioStream[audio_vo] :: inputOptions() [02:36:20.388] AudioFilters :: Volume() [02:36:20.388] filter: [4:a]volume=1[4_vol] [02:36:20.388] AudioFilters :: Delay() [02:36:20.388] filter: [4_vol]adelay=28040|28040[4_del] [02:36:20.388] AudioStream[bg_music] :: inputOptions() [02:36:20.388] AudioFilters :: Volume() [02:36:20.388] filter: [5:a]volume=0.25[5_vol] [02:36:20.389] AudioFilters :: FadeOut() [02:36:20.389] filter: [5_vol]afade=t=out:st=38.73:d=1[5_fadeout] [02:36:20.389] AudioFilters :: Delay() [02:36:20.389] filter: [5_fadeout]adelay=28040|28040[5_del] [02:36:20.389] VideoStream[intro] :: inputOptions() [02:36:20.389] AudioFilters :: Volume() [02:36:20.389] filter: [6:a]volume=1[6_vol] [02:36:20.389] AudioFilters :: Delay() [02:36:20.389] filter: [6_vol]adelay=0|0[6_del] [02:36:20.389] VideoStream[outro] :: inputOptions() [02:36:20.389] AudioFilters :: Volume() [02:36:20.389] filter: [7:a]volume=1[7_vol] [02:36:20.390] AudioFilters :: Delay() [02:36:20.390] filter: [7_vol]adelay=66770|66770[7_del] [02:36:20.390] AudioFilters :: Mix() [02:36:20.390] filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [02:36:20.390] mixed filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [02:36:20.393] hang.time: 60 [02:36:20.521] Vidbot :: ffmpeg.on( 'start' ) [02:36:20.521] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=72.87 -to 00:00:28.039 -i file:///var/www/html/clients/9064/library/intro.mp4 -r 30 -i ./tmp [02:36:20.521] /canvas_1702032783660_%05d.png -to 00:00:06.099 -i file:///var/www/html/clients/9064/library/outro.mp4 -to 00:00:38.729 -i file:///var/www/html/client [02:36:20.521] s/9064/audio/D7F99E4D-4D42-4B26-251E-1D48642E03B3.mp3 -to 00:00:38.729 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF11_Funky_1. [02:36:20.521] mp3 -to 00:00:28.039 -i file:///var/www/html/clients/9064/library/intro.mp4 -to 00:00:06.099 -i file:///var/www/html/clients/9064/library/outro.mp4 -y [02:36:20.522] -filter_complex [1:v]scale=w=640:h=360[1_scaled];[0:v][1_scaled]overlay=x=0:y=0:enable='between(t,0,28.04)'[1_out];[1_out][2:v]overlay=x=0:y=0[2_out] [02:36:20.522] ;[3:v]tpad=start_duration=66.72[3_tpad];[3_tpad]scale=w=640:h=360[3_scaled];[2_out][3_scaled]overlay=x=0:y=0:enable='between(t,66.77,72.86999999999999 [02:36:20.522] )'[3_out];[4:a]volume=1[4_vol];[4_vol]adelay=28040|28040[4_del];[5:a]volume=0.25[5_vol];[5_vol]afade=t=out:st=38.73:d=1[5_fadeout];[5_fadeout]adelay=2 [02:36:20.522] 8040|28040[5_del];[6:a]volume=1[6_vol];[6_vol]adelay=0|0[6_del];[7:a]volume=1[7_vol];[7_vol]adelay=66770|66770[7_del];[4_del][5_del][6_del][7_del]amix [02:36:20.522] =inputs=4:duration=longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [3_out] -preset veryfast -crf 18 -movflags frag_keyframe+ [02:36:20.522] empty_moov -pix_fmt yuv420p /var/www/html/clients/9064/video/D7F99E4D-4D42-4B26-251E-1D48642E03B3.mp4 [02:36:21.029] index :: _onStepProgress_vidbot(), percent: -2850622282 [02:36:21.291] index :: _onStepProgress_vidbot(), percent: 0 [02:36:23.303] index :: _onStepProgress_vidbot(), percent: 5 [02:36:25.338] index :: _onStepProgress_vidbot(), percent: 10 [02:36:27.356] index :: _onStepProgress_vidbot(), percent: 15 [02:36:29.373] index :: _onStepProgress_vidbot(), percent: 20 [02:36:30.901] index :: _onStepProgress_vidbot(), percent: 25 [02:36:32.924] index :: _onStepProgress_vidbot(), percent: 30 [02:36:34.946] index :: _onStepProgress_vidbot(), percent: 36 [02:36:36.452] index :: _onStepProgress_vidbot(), percent: 41 [02:36:37.488] index :: _onStepProgress_vidbot(), percent: 45 [02:36:39.505] index :: _onStepProgress_vidbot(), percent: 51 [02:36:40.515] index :: _onStepProgress_vidbot(), percent: 55 [02:36:42.025] index :: _onStepProgress_vidbot(), percent: 61 [02:36:43.536] index :: _onStepProgress_vidbot(), percent: 66 [02:36:45.044] index :: _onStepProgress_vidbot(), percent: 70 [02:36:46.066] index :: _onStepProgress_vidbot(), percent: 75 [02:36:47.583] index :: _onStepProgress_vidbot(), percent: 81 [02:36:48.587] index :: _onStepProgress_vidbot(), percent: 85 [02:36:50.107] index :: _onStepProgress_vidbot(), percent: 91 [02:36:50.597] index :: _onStepProgress_vidbot(), percent: 95 [02:36:50.959] index :: _onStepProgress_vidbot(), percent: 100 [02:36:51.040] Vidbot :: ffmpeg.on( 'end' ), Done! [02:36:51.041] StreamManager :: dispose() [02:36:51.041] CanvasStream[canvas_1702032783660] :: dispose() [02:36:51.067] Vidbot :: fflog.on( 'finish' ) [02:36:51.067] fflog.path: /var/www/html/clients/9064/video/D7F99E4D-4D42-4B26-251E-1D48642E03B3.mp4.fflog [02:36:51.067] Vidbot :: _next(), _stepIndex:4 of 4 [02:36:51.067] index :: _onStepCompleted_vidbot(), step: 4 [02:36:51.067] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 199.784, output: '/var/www/html/clients/9064/video/D7F99E4D-4D42-4B26-251E-1D48642E03B3.mp4', duration: 72.87 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/9064/video/D7F99E4D-4D42-4B26-251E-1D48642E03B3.mp4 Media Duration : 00:01:12.870 Generation Time : 00:03:19.783 ---------------------------------------------------------------------------------------------------------------