--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [18:24:19.718] Vidbot :: start() [18:24:19.719] Vidbot :: _next(), _stepIndex:0 of 4 [18:24:19.719] index :: _onStepStarted_vidbot(), step: 1 [18:24:19.721] Vidbot :: step[0], label:Initializing Core [18:24:19.733] index :: _onStepProgress_vidbot(), percent: 20 [18:24:19.733] Vidbot :: _parse() [18:24:19.735] index :: _onStepProgress_vidbot(), percent: 40 [18:24:19.735] Vidbot :: _validate() [18:24:19.735] index :: _onStepProgress_vidbot(), percent: 60 [18:24:19.736] Vidbot :: _fonts() [18:24:19.736] FabricFontManager :: add(), id: SourceSansPro-Bold [18:24:19.736] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [18:24:19.744] FabricFontManager :: add(), id: SourceSansPro-Light [18:24:19.745] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [18:24:19.745] FabricFontManager :: add(), id: DINOT-Bold [18:24:19.745] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [18:24:19.746] FabricFontManager :: add(), id: DINOT-Light [18:24:19.746] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [18:24:19.747] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [18:24:19.747] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [18:24:19.748] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [18:24:19.748] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [18:24:19.749] index :: _onStepProgress_vidbot(), percent: 80 [18:24:19.749] Vidbot :: _clips() [18:24:19.750] StreamManager :: add(), id:audio_vo, type:audio [18:24:19.750] AudioClip[audio_vo] :: constructor() [18:24:19.750] InputStream[audio_vo] :: constructor() [18:24:19.751] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [18:24:19.753] StreamManager :: add(), id:bg_music, type:audio [18:24:19.753] AudioClip[bg_music] :: constructor() [18:24:19.753] InputStream[bg_music] :: constructor() [18:24:19.754] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [18:24:19.754] StreamManager :: add(), id:simplefadedisplay, type:canvas [18:24:19.754] CanvasStream[canvas_1528440028898] :: constructor() [18:24:19.754] InputStream[canvas_1528440028898] :: constructor() [18:24:19.831] KenBurnsSlideshow[simplefadedisplay] :: constructor() [18:24:19.831] Overlay[simplefadedisplay] :: constructor() [18:24:19.832] CanvasClip[simplefadedisplay] :: constructor() [18:24:19.832] Clip[simplefadedisplay] :: constructor() [18:24:19.832] clip:"simplefadedisplay" added to stream:"canvas_1528440028898" [18:24:19.832] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1528440028898', clipId: 'simplefadedisplay' } [18:24:19.832] StreamManager :: add(), id:caption, type:canvas [18:24:19.832] RenCaption[caption] :: constructor() [18:24:19.833] Ren[caption] :: constructor() [18:24:19.833] Overlay[caption] :: constructor() [18:24:19.833] CanvasClip[caption] :: constructor() [18:24:19.833] Clip[caption] :: constructor() [18:24:19.833] clip:"caption" added to stream:"canvas_1528440028898" [18:24:19.833] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1528440028898', clipId: 'caption' } [18:24:19.833] all added... [18:24:19.833] Vidbot :: _next(), _stepIndex:1 of 4 [18:24:19.833] index :: _onStepCompleted_vidbot(), step: 1 [18:24:19.834] index :: _onStepStarted_vidbot(), step: 2 [18:24:19.834] Vidbot :: step[1], label:Initializing Input Streams [18:24:19.834] StreamManager :: init() [18:24:19.835] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [18:24:19.835] index :: _onStepProgress_vidbot(), percent: 33 [18:24:19.835] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [18:24:19.835] index :: _onStepProgress_vidbot(), percent: 67 [18:24:19.835] CanvasStream[canvas_1528440028898] :: _init(), BEGIN [18:24:19.836] i:0, c.id:simplefadedisplay [18:24:19.836] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [18:24:19.836] KenBurnsSlideshow[simplefadedisplay] :: _validate() [18:24:19.837] KenBurnsSlideshow[undefined] :: _validateAnim() [18:24:19.837] KenBurnsSlideshow[undefined] :: _validateTheme() [18:24:19.838] i:1, c.id:caption [18:24:19.838] RenCaption[caption] :: _init() [18:24:19.839] RenCaption[caption] :: _validate() [18:24:19.840] KenBurnsSlideshow[simplefadedisplay] :: _build() [18:24:19.846] AnimatedImageFrame[aif] :: constructor() [18:24:19.847] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:19.847] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_1.jpg [18:24:19.860] RenCaption[caption] :: _build() [18:24:19.883] Overlay[caption] :: _animate() [18:24:19.886] CanvasStream[caption] :: _init(), p.then() [18:24:19.915] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:19.919] AnimatedImageFrame[aif] :: _init(), END [18:24:19.921] AnimatedImageFrame[aif] :: constructor() [18:24:19.921] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:19.921] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_2.jpg [18:24:19.938] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:19.940] AnimatedImageFrame[aif] :: _init(), END [18:24:19.940] AnimatedImageFrame[aif] :: constructor() [18:24:19.941] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:19.941] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_3.jpg [18:24:19.958] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:19.959] AnimatedImageFrame[aif] :: _init(), END [18:24:19.960] AnimatedImageFrame[aif] :: constructor() [18:24:19.960] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:19.960] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_4.jpg [18:24:19.972] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:19.973] AnimatedImageFrame[aif] :: _init(), END [18:24:19.974] AnimatedImageFrame[aif] :: constructor() [18:24:19.974] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:19.974] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_1.jpg [18:24:19.986] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:19.987] AnimatedImageFrame[aif] :: _init(), END [18:24:19.988] AnimatedImageFrame[aif] :: constructor() [18:24:19.988] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:19.988] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_2.jpg [18:24:19.999] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.000] AnimatedImageFrame[aif] :: _init(), END [18:24:20.001] AnimatedImageFrame[aif] :: constructor() [18:24:20.001] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.001] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_3.jpg [18:24:20.012] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.013] AnimatedImageFrame[aif] :: _init(), END [18:24:20.014] AnimatedImageFrame[aif] :: constructor() [18:24:20.014] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.014] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_4.jpg [18:24:20.026] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.027] AnimatedImageFrame[aif] :: _init(), END [18:24:20.027] AnimatedImageFrame[aif] :: constructor() [18:24:20.027] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.028] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_1.jpg [18:24:20.039] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.040] AnimatedImageFrame[aif] :: _init(), END [18:24:20.040] AnimatedImageFrame[aif] :: constructor() [18:24:20.040] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.040] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_2.jpg [18:24:20.051] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.052] AnimatedImageFrame[aif] :: _init(), END [18:24:20.053] AnimatedImageFrame[aif] :: constructor() [18:24:20.053] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.053] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_3.jpg [18:24:20.065] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.066] AnimatedImageFrame[aif] :: _init(), END [18:24:20.072] AnimatedImageFrame[aif] :: constructor() [18:24:20.072] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.072] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_4.jpg [18:24:20.083] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.084] AnimatedImageFrame[aif] :: _init(), END [18:24:20.085] AnimatedImageFrame[aif] :: constructor() [18:24:20.085] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.085] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_1.jpg [18:24:20.097] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.098] AnimatedImageFrame[aif] :: _init(), END [18:24:20.098] AnimatedImageFrame[aif] :: constructor() [18:24:20.098] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.099] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_2.jpg [18:24:20.110] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.111] AnimatedImageFrame[aif] :: _init(), END [18:24:20.111] AnimatedImageFrame[aif] :: constructor() [18:24:20.111] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.112] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_3.jpg [18:24:20.130] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.131] AnimatedImageFrame[aif] :: _init(), END [18:24:20.132] AnimatedImageFrame[aif] :: constructor() [18:24:20.132] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.132] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_4.jpg [18:24:20.144] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.146] AnimatedImageFrame[aif] :: _init(), END [18:24:20.146] AnimatedImageFrame[aif] :: constructor() [18:24:20.146] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.146] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_1.jpg [18:24:20.158] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.159] AnimatedImageFrame[aif] :: _init(), END [18:24:20.160] AnimatedImageFrame[aif] :: constructor() [18:24:20.160] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.160] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_2.jpg [18:24:20.171] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.172] AnimatedImageFrame[aif] :: _init(), END [18:24:20.173] AnimatedImageFrame[aif] :: constructor() [18:24:20.173] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.173] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_3.jpg [18:24:20.187] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.188] AnimatedImageFrame[aif] :: _init(), END [18:24:20.189] AnimatedImageFrame[aif] :: constructor() [18:24:20.189] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.189] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_4.jpg [18:24:20.199] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.200] AnimatedImageFrame[aif] :: _init(), END [18:24:20.201] AnimatedImageFrame[aif] :: constructor() [18:24:20.201] AnimatedImageFrame[aif] :: _init(), BEGIN [18:24:20.201] CanvasClip :: LoadImageWithPromise(), src: 2563E933-5F8F-CB44-E19F-365FEFA13B60_1.jpg [18:24:20.212] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [18:24:20.213] AnimatedImageFrame[aif] :: _init(), END [18:24:20.213] Overlay[simplefadedisplay] :: _animate() [18:24:20.214] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [18:24:20.214] CanvasStream[simplefadedisplay] :: _init(), p.then() [18:24:20.214] CanvasStream[canvas_1528440028898] :: _init(), promise.all.then() [18:24:20.216] CanvasStream[canvas_1528440028898] :: _init(), END [18:24:20.216] StreamMangaer :: init(), stream[canvas_1528440028898].then() [18:24:20.216] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1528440028898', progress: 1 } [18:24:20.217] index :: _onStepProgress_vidbot(), percent: 100 [18:24:20.217] StreamManager :: init(), promise.all.then... [18:24:20.217] Vidbot :: StreamMgr.on( 'INITED' ) [18:24:20.217] Vidbot :: _next(), _stepIndex:2 of 4 [18:24:20.217] index :: _onStepCompleted_vidbot(), step: 2 [18:24:20.217] index :: _onStepStarted_vidbot(), step: 3 [18:24:20.218] Vidbot :: step[2], label:Rendering Canvas Streams [18:24:20.218] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [18:24:20.218] StreamManager :: render() [18:24:20.219] CanvasStream[canvas_1528440028898] :: render() [18:24:20.249] index :: _onStepProgress_vidbot(), percent: 0 [18:24:31.340] index :: _onStepProgress_vidbot(), percent: 5 [18:24:43.531] index :: _onStepProgress_vidbot(), percent: 10 [18:24:56.445] index :: _onStepProgress_vidbot(), percent: 15 [18:25:09.326] index :: _onStepProgress_vidbot(), percent: 20 [18:25:22.352] index :: _onStepProgress_vidbot(), percent: 25 [18:25:35.062] index :: _onStepProgress_vidbot(), percent: 30 [18:25:47.754] index :: _onStepProgress_vidbot(), percent: 35 [18:26:00.699] index :: _onStepProgress_vidbot(), percent: 40 [18:26:12.786] index :: _onStepProgress_vidbot(), percent: 45 [18:26:25.904] index :: _onStepProgress_vidbot(), percent: 50 [18:26:38.150] index :: _onStepProgress_vidbot(), percent: 55 [18:26:50.899] index :: _onStepProgress_vidbot(), percent: 60 [18:27:03.706] index :: _onStepProgress_vidbot(), percent: 65 [18:27:16.434] index :: _onStepProgress_vidbot(), percent: 70 [18:27:29.681] index :: _onStepProgress_vidbot(), percent: 75 [18:27:40.669] index :: _onStepProgress_vidbot(), percent: 80 [18:27:51.649] index :: _onStepProgress_vidbot(), percent: 85 [18:28:02.935] index :: _onStepProgress_vidbot(), percent: 90 [18:28:13.732] index :: _onStepProgress_vidbot(), percent: 95 [18:28:24.917] index :: _onStepProgress_vidbot(), percent: 100 [18:28:25.859] StreamManager :: render(), Promise.all.then... [18:28:25.859] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [18:28:25.859] Vidbot :: _next(), _stepIndex:3 of 4 [18:28:25.860] index :: _onStepCompleted_vidbot(), step: 3 [18:28:25.860] index :: _onStepStarted_vidbot(), step: 4 [18:28:25.861] Vidbot :: step[3], label:Encoding Media [18:28:25.864] CanvasFilters :: Overlay() [18:28:25.864] AudioStream[audio_vo] :: inputOptions() [18:28:25.865] AudioFilters :: Volume() [18:28:25.865] filter: [2:a]volume=1[2_vol] [18:28:25.865] AudioFilters :: Delay() [18:28:25.865] filter: [2_vol]adelay=0|0[2_del] [18:28:25.865] AudioStream[bg_music] :: inputOptions() [18:28:25.865] AudioFilters :: Volume() [18:28:25.865] filter: [3:a]volume=0.25[3_vol] [18:28:25.865] AudioFilters :: FadeOut() [18:28:25.865] filter: [3_vol]afade=t=out:st=61.55:d=1[3_fadeout] [18:28:25.866] AudioFilters :: Delay() [18:28:25.866] filter: [3_fadeout]adelay=0|0[3_del] [18:28:25.866] AudioFilters :: Mix() [18:28:25.866] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [18:28:25.866] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [18:28:25.869] hang.time: 60 [18:28:25.988] Vidbot :: ffmpeg.on( 'start' ) [18:28:25.988] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=61.55 -r 30 -i ./tmp/canvas_1528440028898_%05d.png -to 00:01:01.549 -i file:///var/www/html/ [18:28:25.989] clients/5717/audio/2563E933-5F8F-CB44-E19F-365FEFA13B60.mp3 -to 00:01:01.549 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF12_Fu [18:28:25.989] nky_2.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 [18:28:25.989] :st=61.55: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 [18:28:25.989] p [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/5717/video/2563E933-5F8F-CB4 [18:28:25.989] 4-E19F-365FEFA13B60.mp4 [18:28:26.140] index :: _onStepProgress_vidbot(), percent: -3374895950 [18:28:26.563] index :: _onStepProgress_vidbot(), percent: 1 [18:28:27.567] index :: _onStepProgress_vidbot(), percent: 7 [18:28:28.586] index :: _onStepProgress_vidbot(), percent: 12 [18:28:29.082] index :: _onStepProgress_vidbot(), percent: 15 [18:28:30.098] index :: _onStepProgress_vidbot(), percent: 20 [18:28:31.103] index :: _onStepProgress_vidbot(), percent: 25 [18:28:32.115] index :: _onStepProgress_vidbot(), percent: 31 [18:28:33.122] index :: _onStepProgress_vidbot(), percent: 36 [18:28:34.140] index :: _onStepProgress_vidbot(), percent: 41 [18:28:35.149] index :: _onStepProgress_vidbot(), percent: 46 [18:28:36.169] index :: _onStepProgress_vidbot(), percent: 50 [18:28:37.674] index :: _onStepProgress_vidbot(), percent: 57 [18:28:38.691] index :: _onStepProgress_vidbot(), percent: 62 [18:28:39.710] index :: _onStepProgress_vidbot(), percent: 66 [18:28:40.713] index :: _onStepProgress_vidbot(), percent: 71 [18:28:41.721] index :: _onStepProgress_vidbot(), percent: 75 [18:28:42.728] index :: _onStepProgress_vidbot(), percent: 80 [18:28:43.728] index :: _onStepProgress_vidbot(), percent: 85 [18:28:44.740] index :: _onStepProgress_vidbot(), percent: 91 [18:28:45.758] index :: _onStepProgress_vidbot(), percent: 97 [18:28:46.226] index :: _onStepProgress_vidbot(), percent: 100 [18:28:46.244] Vidbot :: ffmpeg.on( 'end' ), Done! [18:28:46.244] StreamManager :: dispose() [18:28:46.244] CanvasStream[canvas_1528440028898] :: dispose() [18:28:46.261] Vidbot :: fflog.on( 'finish' ) [18:28:46.261] fflog.path: /var/www/html/clients/5717/video/2563E933-5F8F-CB44-E19F-365FEFA13B60.mp4.fflog [18:28:46.261] Vidbot :: _next(), _stepIndex:4 of 4 [18:28:46.261] index :: _onStepCompleted_vidbot(), step: 4 [18:28:46.261] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 266.562, output: '/var/www/html/clients/5717/video/2563E933-5F8F-CB44-E19F-365FEFA13B60.mp4', duration: 61.55 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/5717/video/2563E933-5F8F-CB44-E19F-365FEFA13B60.mp4 Media Duration : 00:01:01.549 Generation Time : 00:04:26.562 ---------------------------------------------------------------------------------------------------------------