--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [16:42:53.961] Vidbot :: start() [16:42:53.961] Vidbot :: _next(), _stepIndex:0 of 4 [16:42:53.962] index :: _onStepStarted_vidbot(), step: 1 [16:42:53.963] Vidbot :: step[0], label:Initializing Core [16:42:53.972] index :: _onStepProgress_vidbot(), percent: 20 [16:42:53.973] Vidbot :: _parse() [16:42:53.974] index :: _onStepProgress_vidbot(), percent: 40 [16:42:53.974] Vidbot :: _validate() [16:42:53.975] index :: _onStepProgress_vidbot(), percent: 60 [16:42:53.975] Vidbot :: _fonts() [16:42:53.976] FabricFontManager :: add(), id: SourceSansPro-Bold [16:42:53.976] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [16:42:53.985] FabricFontManager :: add(), id: SourceSansPro-Light [16:42:53.985] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [16:42:53.986] FabricFontManager :: add(), id: DINOT-Bold [16:42:53.986] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [16:42:53.987] FabricFontManager :: add(), id: DINOT-Light [16:42:53.987] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [16:42:53.988] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [16:42:53.988] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [16:42:53.989] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [16:42:53.989] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [16:42:53.990] index :: _onStepProgress_vidbot(), percent: 80 [16:42:53.990] Vidbot :: _clips() [16:42:53.991] StreamManager :: add(), id:audio_vo, type:audio [16:42:53.991] AudioClip[audio_vo] :: constructor() [16:42:53.991] InputStream[audio_vo] :: constructor() [16:42:53.991] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [16:42:53.994] StreamManager :: add(), id:bg_music, type:audio [16:42:53.994] AudioClip[bg_music] :: constructor() [16:42:53.994] InputStream[bg_music] :: constructor() [16:42:53.995] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [16:42:53.995] StreamManager :: add(), id:intro, type:video [16:42:53.995] VideoStream[intro] :: constructor() [16:42:53.995] InputStream[intro] :: constructor() [16:42:53.995] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'intro', clipId: null } [16:42:53.995] StreamManager :: add(), id:simplefadedisplay, type:canvas [16:42:53.996] CanvasStream[canvas_31357543892] :: constructor() [16:42:53.996] InputStream[canvas_31357543892] :: constructor() [16:42:54.076] KenBurnsSlideshow[simplefadedisplay] :: constructor() [16:42:54.077] Overlay[simplefadedisplay] :: constructor() [16:42:54.077] CanvasClip[simplefadedisplay] :: constructor() [16:42:54.077] Clip[simplefadedisplay] :: constructor() [16:42:54.077] clip:"simplefadedisplay" added to stream:"canvas_31357543892" [16:42:54.077] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_31357543892', clipId: 'simplefadedisplay' } [16:42:54.077] StreamManager :: add(), id:caption, type:canvas [16:42:54.078] RenCaption[caption] :: constructor() [16:42:54.078] Ren[caption] :: constructor() [16:42:54.078] Overlay[caption] :: constructor() [16:42:54.078] CanvasClip[caption] :: constructor() [16:42:54.078] Clip[caption] :: constructor() [16:42:54.078] clip:"caption" added to stream:"canvas_31357543892" [16:42:54.078] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_31357543892', clipId: 'caption' } [16:42:54.078] StreamManager :: add(), id:outro, type:video [16:42:54.078] VideoStream[outro] :: constructor() [16:42:54.078] InputStream[outro] :: constructor() [16:42:54.078] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'outro', clipId: null } [16:42:54.079] all added... [16:42:54.079] Vidbot :: _next(), _stepIndex:1 of 4 [16:42:54.079] index :: _onStepCompleted_vidbot(), step: 1 [16:42:54.079] index :: _onStepStarted_vidbot(), step: 2 [16:42:54.079] Vidbot :: step[1], label:Initializing Input Streams [16:42:54.080] StreamManager :: init() [16:42:54.080] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.2 } [16:42:54.081] index :: _onStepProgress_vidbot(), percent: 20 [16:42:54.081] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.4 } [16:42:54.081] index :: _onStepProgress_vidbot(), percent: 40 [16:42:54.081] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'intro', progress: 0.6 } [16:42:54.081] index :: _onStepProgress_vidbot(), percent: 60 [16:42:54.081] CanvasStream[canvas_31357543892] :: _init(), BEGIN [16:42:54.082] i:0, c.id:simplefadedisplay [16:42:54.082] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [16:42:54.082] KenBurnsSlideshow[simplefadedisplay] :: _validate() [16:42:54.083] KenBurnsSlideshow[undefined] :: _validateAnim() [16:42:54.083] KenBurnsSlideshow[undefined] :: _validateTheme() [16:42:54.084] i:1, c.id:caption [16:42:54.084] RenCaption[caption] :: _init() [16:42:54.084] RenCaption[caption] :: _validate() [16:42:54.085] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'outro', progress: 0.8 } [16:42:54.086] index :: _onStepProgress_vidbot(), percent: 80 [16:42:54.086] KenBurnsSlideshow[simplefadedisplay] :: _build() [16:42:54.092] AnimatedImageFrame[aif] :: constructor() [16:42:54.093] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.093] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_1.jpg [16:42:54.106] RenCaption[caption] :: _build() [16:42:54.123] Overlay[caption] :: _animate() [16:42:54.126] CanvasStream[caption] :: _init(), p.then() [16:42:54.153] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.157] AnimatedImageFrame[aif] :: _init(), END [16:42:54.158] AnimatedImageFrame[aif] :: constructor() [16:42:54.159] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.159] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_2.jpg [16:42:54.190] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.192] AnimatedImageFrame[aif] :: _init(), END [16:42:54.192] AnimatedImageFrame[aif] :: constructor() [16:42:54.193] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.193] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_3.jpg [16:42:54.219] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.221] AnimatedImageFrame[aif] :: _init(), END [16:42:54.221] AnimatedImageFrame[aif] :: constructor() [16:42:54.222] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.222] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_4.jpg [16:42:54.246] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.248] AnimatedImageFrame[aif] :: _init(), END [16:42:54.248] AnimatedImageFrame[aif] :: constructor() [16:42:54.249] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.249] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_1.jpg [16:42:54.272] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.273] AnimatedImageFrame[aif] :: _init(), END [16:42:54.274] AnimatedImageFrame[aif] :: constructor() [16:42:54.274] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.274] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_2.jpg [16:42:54.297] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.298] AnimatedImageFrame[aif] :: _init(), END [16:42:54.299] AnimatedImageFrame[aif] :: constructor() [16:42:54.299] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.299] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_3.jpg [16:42:54.321] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.323] AnimatedImageFrame[aif] :: _init(), END [16:42:54.323] AnimatedImageFrame[aif] :: constructor() [16:42:54.323] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.323] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_4.jpg [16:42:54.345] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.347] AnimatedImageFrame[aif] :: _init(), END [16:42:54.347] AnimatedImageFrame[aif] :: constructor() [16:42:54.347] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.348] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_1.jpg [16:42:54.372] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.374] AnimatedImageFrame[aif] :: _init(), END [16:42:54.374] AnimatedImageFrame[aif] :: constructor() [16:42:54.374] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.375] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_2.jpg [16:42:54.396] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.397] AnimatedImageFrame[aif] :: _init(), END [16:42:54.398] AnimatedImageFrame[aif] :: constructor() [16:42:54.398] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.398] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_3.jpg [16:42:54.420] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.421] AnimatedImageFrame[aif] :: _init(), END [16:42:54.422] AnimatedImageFrame[aif] :: constructor() [16:42:54.422] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.422] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_4.jpg [16:42:54.444] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.445] AnimatedImageFrame[aif] :: _init(), END [16:42:54.446] AnimatedImageFrame[aif] :: constructor() [16:42:54.446] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.446] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_1.jpg [16:42:54.468] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.470] AnimatedImageFrame[aif] :: _init(), END [16:42:54.470] AnimatedImageFrame[aif] :: constructor() [16:42:54.470] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.471] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_2.jpg [16:42:54.495] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.496] AnimatedImageFrame[aif] :: _init(), END [16:42:54.497] AnimatedImageFrame[aif] :: constructor() [16:42:54.497] AnimatedImageFrame[aif] :: _init(), BEGIN [16:42:54.497] CanvasClip :: LoadImageWithPromise(), src: 79230333-A230-B777-8D19-0CC9503CD608_3.jpg [16:42:54.524] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [16:42:54.525] AnimatedImageFrame[aif] :: _init(), END [16:42:54.526] Overlay[simplefadedisplay] :: _animate() [16:42:54.526] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [16:42:54.526] CanvasStream[simplefadedisplay] :: _init(), p.then() [16:42:54.526] CanvasStream[canvas_31357543892] :: _init(), promise.all.then() [16:42:54.528] CanvasStream[canvas_31357543892] :: _init(), END [16:42:54.529] StreamMangaer :: init(), stream[canvas_31357543892].then() [16:42:54.529] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_31357543892', progress: 1 } [16:42:54.529] index :: _onStepProgress_vidbot(), percent: 100 [16:42:54.529] StreamManager :: init(), promise.all.then... [16:42:54.529] Vidbot :: StreamMgr.on( 'INITED' ) [16:42:54.529] Vidbot :: _next(), _stepIndex:2 of 4 [16:42:54.529] index :: _onStepCompleted_vidbot(), step: 2 [16:42:54.530] index :: _onStepStarted_vidbot(), step: 3 [16:42:54.530] Vidbot :: step[2], label:Rendering Canvas Streams [16:42:54.530] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [16:42:54.530] StreamManager :: render() [16:42:54.531] CanvasStream[canvas_31357543892] :: render() [16:42:54.565] index :: _onStepProgress_vidbot(), percent: 0 [16:42:56.481] index :: _onStepProgress_vidbot(), percent: 5 [16:42:58.551] index :: _onStepProgress_vidbot(), percent: 10 [16:43:07.950] index :: _onStepProgress_vidbot(), percent: 15 [16:43:22.526] index :: _onStepProgress_vidbot(), percent: 20 [16:43:37.726] index :: _onStepProgress_vidbot(), percent: 25 [16:43:53.265] index :: _onStepProgress_vidbot(), percent: 30 [16:44:09.625] index :: _onStepProgress_vidbot(), percent: 35 [16:44:26.816] index :: _onStepProgress_vidbot(), percent: 40 [16:44:43.359] index :: _onStepProgress_vidbot(), percent: 45 [16:44:58.674] index :: _onStepProgress_vidbot(), percent: 50 [16:45:14.884] index :: _onStepProgress_vidbot(), percent: 55 [16:45:31.276] index :: _onStepProgress_vidbot(), percent: 60 [16:45:47.641] index :: _onStepProgress_vidbot(), percent: 65 [16:46:03.820] index :: _onStepProgress_vidbot(), percent: 70 [16:46:20.281] index :: _onStepProgress_vidbot(), percent: 75 [16:46:36.757] index :: _onStepProgress_vidbot(), percent: 80 [16:46:53.077] index :: _onStepProgress_vidbot(), percent: 85 [16:47:09.541] index :: _onStepProgress_vidbot(), percent: 90 [16:47:25.524] index :: _onStepProgress_vidbot(), percent: 95 [16:47:32.212] index :: _onStepProgress_vidbot(), percent: 100 [16:47:32.444] StreamManager :: render(), Promise.all.then... [16:47:32.445] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [16:47:32.445] Vidbot :: _next(), _stepIndex:3 of 4 [16:47:32.445] index :: _onStepCompleted_vidbot(), step: 3 [16:47:32.446] index :: _onStepStarted_vidbot(), step: 4 [16:47:32.447] Vidbot :: step[3], label:Encoding Media [16:47:32.450] VideoStream[intro] :: inputOptions() [16:47:32.450] VideoFilters :: Scale() [16:47:32.451] VideoFilters :: Overlay() [16:47:32.452] CanvasFilters :: Overlay() [16:47:32.452] VideoStream[outro] :: inputOptions() [16:47:32.452] VideoFilters :: Tpad() [16:47:32.452] VideoFilters :: Scale() [16:47:32.452] VideoFilters :: Overlay() [16:47:32.453] AudioStream[audio_vo] :: inputOptions() [16:47:32.453] AudioFilters :: Volume() [16:47:32.453] filter: [4:a]volume=1[4_vol] [16:47:32.453] AudioFilters :: Delay() [16:47:32.453] filter: [4_vol]adelay=6010|6010[4_del] [16:47:32.453] AudioStream[bg_music] :: inputOptions() [16:47:32.454] AudioFilters :: Volume() [16:47:32.454] filter: [5:a]volume=0.25[5_vol] [16:47:32.454] AudioFilters :: FadeOut() [16:47:32.454] filter: [5_vol]afade=t=out:st=43.44:d=1[5_fadeout] [16:47:32.454] AudioFilters :: Delay() [16:47:32.454] filter: [5_fadeout]adelay=6010|6010[5_del] [16:47:32.454] VideoStream[intro] :: inputOptions() [16:47:32.454] AudioFilters :: Volume() [16:47:32.454] filter: [6:a]volume=1[6_vol] [16:47:32.454] AudioFilters :: Delay() [16:47:32.455] filter: [6_vol]adelay=0|0[6_del] [16:47:32.455] VideoStream[outro] :: inputOptions() [16:47:32.455] AudioFilters :: Volume() [16:47:32.455] filter: [7:a]volume=1[7_vol] [16:47:32.455] AudioFilters :: Delay() [16:47:32.455] filter: [7_vol]adelay=49450|49450[7_del] [16:47:32.455] AudioFilters :: Mix() [16:47:32.455] filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [16:47:32.455] mixed filter: [4_del][5_del][6_del][7_del]amix=inputs=4:duration=longest[a_out] [16:47:32.458] hang.time: 60 [16:47:32.576] Vidbot :: ffmpeg.on( 'start' ) [16:47:32.576] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=58.46 -to 00:00:06.009 -i file:///var/www/html/clients/3034/library/intro.mp4 -r 30 -i ./tmp [16:47:32.576] /canvas_31357543892_%05d.png -to 00:00:09.009 -i file:///var/www/html/clients/3034/library/outro.mp4 -to 00:00:43.439 -i file:///var/www/html/clients/ [16:47:32.577] 3034/audio/79230333-A230-B777-8D19-0CC9503CD608.mp3 -to 00:00:43.439 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF7_Rock_Countr [16:47:32.577] y.mp3 -to 00:00:06.009 -i file:///var/www/html/clients/3034/library/intro.mp4 -to 00:00:09.009 -i file:///var/www/html/clients/3034/library/outro.mp4 [16:47:32.577] -y -filter_complex [1:v]scale=w=640:h=360[1_scaled];[0:v][1_scaled]overlay=x=0:y=0:enable='between(t,0,6.01)'[1_out];[1_out][2:v]overlay=x=0:y=0[2_out [16:47:32.577] ];[3:v]tpad=start_duration=49.400000000000006[3_tpad];[3_tpad]scale=w=640:h=360[3_scaled];[2_out][3_scaled]overlay=x=0:y=0:enable='between(t,49.45,58. [16:47:32.577] 46)'[3_out];[4:a]volume=1[4_vol];[4_vol]adelay=6010|6010[4_del];[5:a]volume=0.25[5_vol];[5_vol]afade=t=out:st=43.44:d=1[5_fadeout];[5_fadeout]adelay=6 [16:47:32.577] 010|6010[5_del];[6:a]volume=1[6_vol];[6_vol]adelay=0|0[6_del];[7:a]volume=1[7_vol];[7_vol]adelay=49450|49450[7_del];[4_del][5_del][6_del][7_del]amix=i [16:47:32.577] nputs=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+em [16:47:32.577] pty_moov -pix_fmt yuv420p /var/www/html/clients/3034/video/79230333-A230-B777-8D19-0CC9503CD608.mp4 [16:47:32.897] index :: _onStepProgress_vidbot(), percent: -3553281658 [16:47:33.262] index :: _onStepProgress_vidbot(), percent: 1 [16:47:34.781] index :: _onStepProgress_vidbot(), percent: 6 [16:47:36.298] index :: _onStepProgress_vidbot(), percent: 11 [16:47:37.307] index :: _onStepProgress_vidbot(), percent: 15 [16:47:38.312] index :: _onStepProgress_vidbot(), percent: 20 [16:47:39.828] index :: _onStepProgress_vidbot(), percent: 26 [16:47:40.833] index :: _onStepProgress_vidbot(), percent: 32 [16:47:41.838] index :: _onStepProgress_vidbot(), percent: 37 [16:47:42.848] index :: _onStepProgress_vidbot(), percent: 41 [16:47:43.865] index :: _onStepProgress_vidbot(), percent: 46 [16:47:44.876] index :: _onStepProgress_vidbot(), percent: 51 [16:47:45.884] index :: _onStepProgress_vidbot(), percent: 56 [16:47:46.900] index :: _onStepProgress_vidbot(), percent: 61 [16:47:47.921] index :: _onStepProgress_vidbot(), percent: 66 [16:47:48.922] index :: _onStepProgress_vidbot(), percent: 71 [16:47:49.924] index :: _onStepProgress_vidbot(), percent: 76 [16:47:50.931] index :: _onStepProgress_vidbot(), percent: 81 [16:47:51.938] index :: _onStepProgress_vidbot(), percent: 88 [16:47:52.448] index :: _onStepProgress_vidbot(), percent: 95 [16:47:52.965] index :: _onStepProgress_vidbot(), percent: 100 [16:47:53.004] Vidbot :: ffmpeg.on( 'end' ), Done! [16:47:53.004] StreamManager :: dispose() [16:47:53.005] CanvasStream[canvas_31357543892] :: dispose() [16:47:53.010] Vidbot :: fflog.on( 'finish' ) [16:47:53.010] fflog.path: /var/www/html/clients/3034/video/79230333-A230-B777-8D19-0CC9503CD608.mp4.fflog [16:47:53.010] Vidbot :: _next(), _stepIndex:4 of 4 [16:47:53.010] index :: _onStepCompleted_vidbot(), step: 4 [16:47:53.010] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 299.069, output: '/var/www/html/clients/3034/video/79230333-A230-B777-8D19-0CC9503CD608.mp4', duration: 58.46 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/3034/video/79230333-A230-B777-8D19-0CC9503CD608.mp4 Media Duration : 00:00:58.460 Generation Time : 00:04:59.069 ---------------------------------------------------------------------------------------------------------------