--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.6.0... --------------------------------------------------------------------------------------------------------------- [01:54:26.018] Vidbot :: start() [01:54:26.019] Vidbot :: _next(), _stepIndex:0 of 4 [01:54:26.019] index :: _onStepStarted_vidbot(), step: 1 [01:54:26.020] Vidbot :: step[0], label:Initializing Core [01:54:26.029] index :: _onStepProgress_vidbot(), percent: 20 [01:54:26.029] Vidbot :: _parse() [01:54:26.030] index :: _onStepProgress_vidbot(), percent: 40 [01:54:26.031] Vidbot :: _validate() [01:54:26.031] index :: _onStepProgress_vidbot(), percent: 60 [01:54:26.032] Vidbot :: _fonts() [01:54:26.032] FabricFontManager :: add(), id: SourceSansPro-Bold [01:54:26.032] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [01:54:26.040] FabricFontManager :: add(), id: SourceSansPro-Light [01:54:26.040] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [01:54:26.041] FabricFontManager :: add(), id: DINOT-Bold [01:54:26.041] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [01:54:26.042] FabricFontManager :: add(), id: DINOT-Light [01:54:26.042] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [01:54:26.043] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [01:54:26.043] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [01:54:26.044] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [01:54:26.044] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [01:54:26.045] index :: _onStepProgress_vidbot(), percent: 80 [01:54:26.045] Vidbot :: _clips() [01:54:26.046] StreamManager :: add(), id:audio_vo, type:audio [01:54:26.046] AudioClip[audio_vo] :: constructor() [01:54:26.046] InputStream[audio_vo] :: constructor() [01:54:26.047] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [01:54:26.049] StreamManager :: add(), id:bg_music, type:audio [01:54:26.050] AudioClip[bg_music] :: constructor() [01:54:26.050] InputStream[bg_music] :: constructor() [01:54:26.050] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [01:54:26.050] StreamManager :: add(), id:intro, type:video [01:54:26.050] VideoStream[intro] :: constructor() [01:54:26.050] InputStream[intro] :: constructor() [01:54:26.051] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'intro', clipId: null } [01:54:26.051] StreamManager :: add(), id:simplefadedisplay, type:canvas [01:54:26.051] CanvasStream[canvas_621488799592] :: constructor() [01:54:26.051] InputStream[canvas_621488799592] :: constructor() [01:54:26.132] KenBurnsSlideshow[simplefadedisplay] :: constructor() [01:54:26.132] Overlay[simplefadedisplay] :: constructor() [01:54:26.132] CanvasClip[simplefadedisplay] :: constructor() [01:54:26.133] Clip[simplefadedisplay] :: constructor() [01:54:26.133] clip:"simplefadedisplay" added to stream:"canvas_621488799592" [01:54:26.133] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_621488799592', clipId: 'simplefadedisplay' } [01:54:26.133] StreamManager :: add(), id:caption, type:canvas [01:54:26.133] RenCaption[caption] :: constructor() [01:54:26.133] Ren[caption] :: constructor() [01:54:26.133] Overlay[caption] :: constructor() [01:54:26.134] CanvasClip[caption] :: constructor() [01:54:26.134] Clip[caption] :: constructor() [01:54:26.134] clip:"caption" added to stream:"canvas_621488799592" [01:54:26.134] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_621488799592', clipId: 'caption' } [01:54:26.134] StreamManager :: add(), id:outro, type:video [01:54:26.134] VideoStream[outro] :: constructor() [01:54:26.134] InputStream[outro] :: constructor() [01:54:26.134] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'outro', clipId: null } [01:54:26.134] all added... [01:54:26.134] Vidbot :: _next(), _stepIndex:1 of 4 [01:54:26.135] index :: _onStepCompleted_vidbot(), step: 1 [01:54:26.135] index :: _onStepStarted_vidbot(), step: 2 [01:54:26.135] Vidbot :: step[1], label:Initializing Input Streams [01:54:26.135] StreamManager :: init() [01:54:26.136] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.2 } [01:54:26.136] index :: _onStepProgress_vidbot(), percent: 20 [01:54:26.136] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.4 } [01:54:26.136] index :: _onStepProgress_vidbot(), percent: 40 [01:54:26.136] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'intro', progress: 0.6 } [01:54:26.136] index :: _onStepProgress_vidbot(), percent: 60 [01:54:26.137] CanvasStream[canvas_621488799592] :: _init(), BEGIN [01:54:26.137] i:0, c.id:simplefadedisplay [01:54:26.137] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [01:54:26.138] KenBurnsSlideshow[simplefadedisplay] :: _validate() [01:54:26.138] KenBurnsSlideshow[undefined] :: _validateAnim() [01:54:26.139] KenBurnsSlideshow[undefined] :: _validateTheme() [01:54:26.140] i:1, c.id:caption [01:54:26.140] RenCaption[caption] :: _init() [01:54:26.140] RenCaption[caption] :: _validate() [01:54:26.141] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'outro', progress: 0.8 } [01:54:26.141] index :: _onStepProgress_vidbot(), percent: 80 [01:54:26.142] KenBurnsSlideshow[simplefadedisplay] :: _build() [01:54:26.148] AnimatedImageFrame[aif] :: constructor() [01:54:26.149] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.149] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_1.jpg [01:54:26.161] RenCaption[caption] :: _build() [01:54:26.176] Overlay[caption] :: _animate() [01:54:26.179] CanvasStream[caption] :: _init(), p.then() [01:54:26.198] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.201] AnimatedImageFrame[aif] :: _init(), END [01:54:26.203] AnimatedImageFrame[aif] :: constructor() [01:54:26.203] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.203] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_2.jpg [01:54:26.215] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.217] AnimatedImageFrame[aif] :: _init(), END [01:54:26.217] AnimatedImageFrame[aif] :: constructor() [01:54:26.217] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.218] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_3.jpg [01:54:26.231] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.232] AnimatedImageFrame[aif] :: _init(), END [01:54:26.232] AnimatedImageFrame[aif] :: constructor() [01:54:26.233] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.233] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_4.jpg [01:54:26.243] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.243] AnimatedImageFrame[aif] :: _init(), END [01:54:26.244] AnimatedImageFrame[aif] :: constructor() [01:54:26.244] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.244] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_1.jpg [01:54:26.258] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.259] AnimatedImageFrame[aif] :: _init(), END [01:54:26.260] AnimatedImageFrame[aif] :: constructor() [01:54:26.260] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.260] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_2.jpg [01:54:26.271] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.272] AnimatedImageFrame[aif] :: _init(), END [01:54:26.273] AnimatedImageFrame[aif] :: constructor() [01:54:26.273] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.273] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_3.jpg [01:54:26.287] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.288] AnimatedImageFrame[aif] :: _init(), END [01:54:26.288] AnimatedImageFrame[aif] :: constructor() [01:54:26.288] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.288] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_4.jpg [01:54:26.298] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.299] AnimatedImageFrame[aif] :: _init(), END [01:54:26.300] AnimatedImageFrame[aif] :: constructor() [01:54:26.300] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.300] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_1.jpg [01:54:26.314] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.315] AnimatedImageFrame[aif] :: _init(), END [01:54:26.316] AnimatedImageFrame[aif] :: constructor() [01:54:26.316] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.316] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_2.jpg [01:54:26.327] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.328] AnimatedImageFrame[aif] :: _init(), END [01:54:26.329] AnimatedImageFrame[aif] :: constructor() [01:54:26.329] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.329] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_3.jpg [01:54:26.342] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.343] AnimatedImageFrame[aif] :: _init(), END [01:54:26.343] AnimatedImageFrame[aif] :: constructor() [01:54:26.343] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.343] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_4.jpg [01:54:26.354] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.355] AnimatedImageFrame[aif] :: _init(), END [01:54:26.355] AnimatedImageFrame[aif] :: constructor() [01:54:26.355] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.355] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_1.jpg [01:54:26.370] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.371] AnimatedImageFrame[aif] :: _init(), END [01:54:26.371] AnimatedImageFrame[aif] :: constructor() [01:54:26.371] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.371] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_2.jpg [01:54:26.382] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.383] AnimatedImageFrame[aif] :: _init(), END [01:54:26.383] AnimatedImageFrame[aif] :: constructor() [01:54:26.383] AnimatedImageFrame[aif] :: _init(), BEGIN [01:54:26.383] CanvasClip :: LoadImageWithPromise(), src: 10745508-A247-072B-6886-E91B7E03D078_3.jpg [01:54:26.396] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:54:26.397] AnimatedImageFrame[aif] :: _init(), END [01:54:26.397] Overlay[simplefadedisplay] :: _animate() [01:54:26.398] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [01:54:26.398] CanvasStream[simplefadedisplay] :: _init(), p.then() [01:54:26.398] CanvasStream[canvas_621488799592] :: _init(), promise.all.then() [01:54:26.400] CanvasStream[canvas_621488799592] :: _init(), END [01:54:26.400] StreamMangaer :: init(), stream[canvas_621488799592].then() [01:54:26.400] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_621488799592', progress: 1 } [01:54:26.400] index :: _onStepProgress_vidbot(), percent: 100 [01:54:26.401] StreamManager :: init(), promise.all.then... [01:54:26.401] Vidbot :: StreamMgr.on( 'INITED' ) [01:54:26.401] Vidbot :: _next(), _stepIndex:2 of 4 [01:54:26.401] index :: _onStepCompleted_vidbot(), step: 2 [01:54:26.401] index :: _onStepStarted_vidbot(), step: 3 [01:54:26.401] Vidbot :: step[2], label:Rendering Canvas Streams [01:54:26.402] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [01:54:26.402] StreamManager :: render() [01:54:26.402] CanvasStream[canvas_621488799592] :: render() [01:54:26.433] index :: _onStepProgress_vidbot(), percent: 0 [01:54:28.966] index :: _onStepProgress_vidbot(), percent: 5 [01:54:31.734] index :: _onStepProgress_vidbot(), percent: 10 [01:54:34.612] index :: _onStepProgress_vidbot(), percent: 15 [01:54:37.936] index :: _onStepProgress_vidbot(), percent: 20 [01:54:41.070] index :: _onStepProgress_vidbot(), percent: 25 [01:54:44.125] index :: _onStepProgress_vidbot(), percent: 30 [01:54:47.139] index :: _onStepProgress_vidbot(), percent: 35 [01:54:54.580] index :: _onStepProgress_vidbot(), percent: 40 [01:55:10.881] index :: _onStepProgress_vidbot(), percent: 45 [01:55:22.376] index :: _onStepProgress_vidbot(), percent: 50 [01:55:31.969] index :: _onStepProgress_vidbot(), percent: 55 [01:55:52.329] index :: _onStepProgress_vidbot(), percent: 60 [01:56:04.671] index :: _onStepProgress_vidbot(), percent: 65 [01:56:14.534] index :: _onStepProgress_vidbot(), percent: 70 [01:56:32.600] index :: _onStepProgress_vidbot(), percent: 75 [01:56:47.659] index :: _onStepProgress_vidbot(), percent: 80 [01:56:58.902] index :: _onStepProgress_vidbot(), percent: 85 [01:57:14.015] index :: _onStepProgress_vidbot(), percent: 90 [01:57:30.338] index :: _onStepProgress_vidbot(), percent: 95 [01:57:41.100] index :: _onStepProgress_vidbot(), percent: 100 [01:57:41.453] StreamManager :: render(), Promise.all.then... [01:57:41.453] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [01:57:41.454] Vidbot :: _next(), _stepIndex:3 of 4 [01:57:41.454] index :: _onStepCompleted_vidbot(), step: 3 [01:57:41.455] index :: _onStepStarted_vidbot(), step: 4 [01:57:41.455] Vidbot :: step[3], label:Encoding Media [01:57:41.458] VideoStream[intro] :: inputOptions() [01:57:41.458] VideoFilters :: Scale() [01:57:41.459] VideoFilters :: Overlay() [01:57:41.459] CanvasFilters :: Overlay() [01:57:41.460] VideoStream[outro] :: inputOptions() [01:57:41.460] VideoFilters :: Tpad() [01:57:41.460] VideoFilters :: Scale() [01:57:41.460] VideoFilters :: Overlay() [01:57:41.460] AudioStream[audio_vo] :: inputOptions() [01:57:41.461] AudioFilters :: Volume() [01:57:41.461] filter: [4:a]volume=1[4_vol] [01:57:41.461] AudioFilters :: Delay() [01:57:41.461] filter: [4_vol]adelay=28040|28040[4_del] [01:57:41.461] AudioStream[bg_music] :: inputOptions() [01:57:41.461] AudioFilters :: Volume() [01:57:41.461] filter: [5:a]volume=0.25[5_vol] [01:57:41.461] AudioFilters :: FadeOut() [01:57:41.462] filter: [5_vol]afade=t=out:st=44.41:d=1[5_fadeout] [01:57:41.462] AudioFilters :: Delay() [01:57:41.462] filter: [5_fadeout]adelay=28040|28040[5_del] [01:57:41.462] VideoStream[intro] :: inputOptions() [01:57:41.462] AudioFilters :: Volume() [01:57:41.462] filter: [6:a]volume=1[6_vol] [01:57:41.462] AudioFilters :: Delay() [01:57:41.462] filter: [6_vol]adelay=0|0[6_del] [01:57:41.462] VideoStream[outro] :: inputOptions() [01:57:41.462] AudioFilters :: Volume() [01:57:41.462] filter: [7:a]volume=1[7_vol] [01:57:41.462] AudioFilters :: Delay() [01:57:41.462] filter: [7_vol]adelay=72450|72450[7_del] [01:57:41.463] AudioFilters :: Mix() [01:57:41.463] filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [01:57:41.463] mixed filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [01:57:41.465] hang.time: 60 [01:57:41.586] Vidbot :: ffmpeg.on( 'start' ) [01:57:41.587] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=78.55 -to 00:00:28.039 -i file:///var/www/html/clients/9064/library/intro.mp4 -r 30 -i ./tmp [01:57:41.587] /canvas_621488799592_%05d.png -to 00:00:06.099 -i file:///var/www/html/clients/9064/library/outro.mp4 -to 00:00:44.409 -i file:///var/www/html/clients [01:57:41.587] /9064/audio/10745508-A247-072B-6886-E91B7E03D078.mp3 -to 00:00:44.409 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Jazz_30.mp3 -t [01:57:41.587] o 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 -filt [01:57:41.587] er_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];[3:v] [01:57:41.587] tpad=start_duration=72.4[3_tpad];[3_tpad]scale=w=640:h=360[3_scaled];[2_out][3_scaled]overlay=x=0:y=0:enable='between(t,72.45,78.55)'[3_out];[4:a]volu [01:57:41.587] me=1[4_vol];[4_vol]adelay=28040|28040[4_del];[5:a]volume=0.25[5_vol];[5_vol]afade=t=out:st=44.41:d=1[5_fadeout];[5_fadeout]adelay=28040|28040[5_del];[ [01:57:41.587] 6:a]volume=1[6_vol];[6_vol]adelay=0|0[6_del];[7:a]volume=1[7_vol];[7_vol]adelay=72450|72450[7_del];[4_del][5_del][6_del][7_del]amix=inputs=4:duration= [01:57:41.587] longest[a_out] -acodec aac -vcodec libx264 -r 30 -f mp4 -map [a_out] -map [3_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt [01:57:41.587] yuv420p /var/www/html/clients/9064/video/10745508-A247-072B-6886-E91B7E03D078.mp4 [01:57:42.182] index :: _onStepProgress_vidbot(), percent: -2644491989 [01:57:42.442] index :: _onStepProgress_vidbot(), percent: 0 [01:57:44.967] index :: _onStepProgress_vidbot(), percent: 5 [01:57:47.486] index :: _onStepProgress_vidbot(), percent: 10 [01:57:49.538] index :: _onStepProgress_vidbot(), percent: 15 [01:57:51.502] index :: _onStepProgress_vidbot(), percent: 20 [01:57:53.510] index :: _onStepProgress_vidbot(), percent: 26 [01:57:55.017] index :: _onStepProgress_vidbot(), percent: 31 [01:57:56.030] index :: _onStepProgress_vidbot(), percent: 35 [01:57:57.553] index :: _onStepProgress_vidbot(), percent: 41 [01:57:58.581] index :: _onStepProgress_vidbot(), percent: 45 [01:57:59.574] index :: _onStepProgress_vidbot(), percent: 50 [01:58:01.084] index :: _onStepProgress_vidbot(), percent: 57 [01:58:02.095] index :: _onStepProgress_vidbot(), percent: 60 [01:58:03.605] index :: _onStepProgress_vidbot(), percent: 66 [01:58:04.610] index :: _onStepProgress_vidbot(), percent: 71 [01:58:05.623] index :: _onStepProgress_vidbot(), percent: 75 [01:58:07.130] index :: _onStepProgress_vidbot(), percent: 81 [01:58:08.650] index :: _onStepProgress_vidbot(), percent: 86 [01:58:09.645] index :: _onStepProgress_vidbot(), percent: 90 [01:58:10.653] index :: _onStepProgress_vidbot(), percent: 96 [01:58:11.071] index :: _onStepProgress_vidbot(), percent: 100 [01:58:11.119] Vidbot :: ffmpeg.on( 'end' ), Done! [01:58:11.119] StreamManager :: dispose() [01:58:11.120] CanvasStream[canvas_621488799592] :: dispose() [01:58:11.125] Vidbot :: fflog.on( 'finish' ) [01:58:11.125] fflog.path: /var/www/html/clients/9064/video/10745508-A247-072B-6886-E91B7E03D078.mp4.fflog [01:58:11.125] Vidbot :: _next(), _stepIndex:4 of 4 [01:58:11.125] index :: _onStepCompleted_vidbot(), step: 4 [01:58:11.126] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 225.127, output: '/var/www/html/clients/9064/video/10745508-A247-072B-6886-E91B7E03D078.mp4', duration: 78.55 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/9064/video/10745508-A247-072B-6886-E91B7E03D078.mp4 Media Duration : 00:01:18.549 Generation Time : 00:03:45.127 ---------------------------------------------------------------------------------------------------------------