--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [02:02:17.379] Vidbot :: start() [02:02:17.379] Vidbot :: _next(), _stepIndex:0 of 4 [02:02:17.380] index :: _onStepStarted_vidbot(), step: 1 [02:02:17.381] Vidbot :: step[0], label:Initializing Core [02:02:17.399] index :: _onStepProgress_vidbot(), percent: 20 [02:02:17.399] Vidbot :: _parse() [02:02:17.401] index :: _onStepProgress_vidbot(), percent: 40 [02:02:17.401] Vidbot :: _validate() [02:02:17.402] index :: _onStepProgress_vidbot(), percent: 60 [02:02:17.402] Vidbot :: _fonts() [02:02:17.402] FabricFontManager :: add(), id: SourceSansPro-Bold [02:02:17.402] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [02:02:17.410] FabricFontManager :: add(), id: SourceSansPro-Light [02:02:17.411] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [02:02:17.411] FabricFontManager :: add(), id: DINOT-Bold [02:02:17.412] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [02:02:17.412] FabricFontManager :: add(), id: DINOT-Light [02:02:17.412] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [02:02:17.413] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [02:02:17.413] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [02:02:17.414] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [02:02:17.414] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [02:02:17.415] index :: _onStepProgress_vidbot(), percent: 80 [02:02:17.415] Vidbot :: _clips() [02:02:17.416] StreamManager :: add(), id:audio_vo, type:audio [02:02:17.416] AudioClip[audio_vo] :: constructor() [02:02:17.416] InputStream[audio_vo] :: constructor() [02:02:17.417] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [02:02:17.419] StreamManager :: add(), id:bg_music, type:audio [02:02:17.419] AudioClip[bg_music] :: constructor() [02:02:17.419] InputStream[bg_music] :: constructor() [02:02:17.420] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [02:02:17.420] StreamManager :: add(), id:simplefadedisplay, type:canvas [02:02:17.420] CanvasStream[canvas_1470791341155] :: constructor() [02:02:17.420] InputStream[canvas_1470791341155] :: constructor() [02:02:17.505] KenBurnsSlideshow[simplefadedisplay] :: constructor() [02:02:17.506] Overlay[simplefadedisplay] :: constructor() [02:02:17.506] CanvasClip[simplefadedisplay] :: constructor() [02:02:17.506] Clip[simplefadedisplay] :: constructor() [02:02:17.506] clip:"simplefadedisplay" added to stream:"canvas_1470791341155" [02:02:17.506] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1470791341155', clipId: 'simplefadedisplay' } [02:02:17.506] StreamManager :: add(), id:caption, type:canvas [02:02:17.507] RenCaption[caption] :: constructor() [02:02:17.507] Ren[caption] :: constructor() [02:02:17.507] Overlay[caption] :: constructor() [02:02:17.507] CanvasClip[caption] :: constructor() [02:02:17.507] Clip[caption] :: constructor() [02:02:17.507] clip:"caption" added to stream:"canvas_1470791341155" [02:02:17.507] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1470791341155', clipId: 'caption' } [02:02:17.507] StreamManager :: add(), id:options, type:canvas [02:02:17.508] RenOptions[options] :: constructor() [02:02:17.508] Ren[options] :: constructor() [02:02:17.508] Overlay[options] :: constructor() [02:02:17.508] CanvasClip[options] :: constructor() [02:02:17.508] Clip[options] :: constructor() [02:02:17.508] clip:"options" added to stream:"canvas_1470791341155" [02:02:17.508] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1470791341155', clipId: 'options' } [02:02:17.508] StreamManager :: add(), id:map, type:canvas [02:02:17.508] RenMap[map] :: constructor() [02:02:17.508] Ren[map] :: constructor() [02:02:17.508] Overlay[map] :: constructor() [02:02:17.508] CanvasClip[map] :: constructor() [02:02:17.509] Clip[map] :: constructor() [02:02:17.509] clip:"map" added to stream:"canvas_1470791341155" [02:02:17.509] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1470791341155', clipId: 'map' } [02:02:17.509] all added... [02:02:17.509] Vidbot :: _next(), _stepIndex:1 of 4 [02:02:17.509] index :: _onStepCompleted_vidbot(), step: 1 [02:02:17.510] index :: _onStepStarted_vidbot(), step: 2 [02:02:17.510] Vidbot :: step[1], label:Initializing Input Streams [02:02:17.510] StreamManager :: init() [02:02:17.511] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [02:02:17.511] index :: _onStepProgress_vidbot(), percent: 33 [02:02:17.511] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [02:02:17.511] index :: _onStepProgress_vidbot(), percent: 67 [02:02:17.512] CanvasStream[canvas_1470791341155] :: _init(), BEGIN [02:02:17.512] i:0, c.id:simplefadedisplay [02:02:17.512] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [02:02:17.512] KenBurnsSlideshow[simplefadedisplay] :: _validate() [02:02:17.513] KenBurnsSlideshow[undefined] :: _validateAnim() [02:02:17.513] KenBurnsSlideshow[undefined] :: _validateTheme() [02:02:17.514] i:1, c.id:caption [02:02:17.515] RenCaption[caption] :: _init() [02:02:17.515] RenCaption[caption] :: _validate() [02:02:17.516] i:2, c.id:options [02:02:17.516] RenPrice[options] :: _init() [02:02:17.517] RenOptions[options] :: _validate() [02:02:17.517] i:3, c.id:map [02:02:17.518] RenMap[map] :: _init() [02:02:17.518] RenMap[map] :: _validate() [02:02:17.519] KenBurnsSlideshow[simplefadedisplay] :: _build() [02:02:17.535] AnimatedImageFrame[aif] :: constructor() [02:02:17.536] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.536] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_1.jpg [02:02:17.550] RenCaption[caption] :: _build() [02:02:17.565] RenOptions[options] :: _assets() [02:02:17.566] CanvasClip :: LoadSVGFromStringWithPromise() [02:02:17.595] CanvasClip :: LoadSVGFromString(), loaded [02:02:17.597] RenMap[map] :: _assets() [02:02:17.597] CanvasClip :: LoadSVGFromStringWithPromise() [02:02:17.608] CanvasClip :: LoadSVGFromString(), loaded [02:02:17.610] CanvasClip :: LoadImageWithPromise(), src: map_360.jpg [02:02:17.613] Overlay[caption] :: _animate() [02:02:17.617] RenOptions[options] :: _build() [02:02:17.731] CanvasStream[caption] :: _init(), p.then() [02:02:17.731] RenOptions[options] :: _animate() [02:02:17.731] Overlay[options] :: _animate() [02:02:17.733] CanvasStream[options] :: _init(), p.then() [02:02:17.761] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.765] AnimatedImageFrame[aif] :: _init(), END [02:02:17.767] AnimatedImageFrame[aif] :: constructor() [02:02:17.767] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.767] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_2.jpg [02:02:17.779] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.781] RenMap[map] :: _build() [02:02:17.799] Overlay[map] :: _animate() [02:02:17.799] CanvasStream[map] :: _init(), p.then() [02:02:17.821] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.822] AnimatedImageFrame[aif] :: _init(), END [02:02:17.823] AnimatedImageFrame[aif] :: constructor() [02:02:17.823] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.823] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_3.jpg [02:02:17.846] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.847] AnimatedImageFrame[aif] :: _init(), END [02:02:17.848] AnimatedImageFrame[aif] :: constructor() [02:02:17.848] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.848] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_4.jpg [02:02:17.870] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.871] AnimatedImageFrame[aif] :: _init(), END [02:02:17.871] AnimatedImageFrame[aif] :: constructor() [02:02:17.871] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.871] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_5.jpg [02:02:17.893] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.894] AnimatedImageFrame[aif] :: _init(), END [02:02:17.895] AnimatedImageFrame[aif] :: constructor() [02:02:17.895] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.895] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_1.jpg [02:02:17.917] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.918] AnimatedImageFrame[aif] :: _init(), END [02:02:17.918] AnimatedImageFrame[aif] :: constructor() [02:02:17.918] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.918] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_2.jpg [02:02:17.940] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.941] AnimatedImageFrame[aif] :: _init(), END [02:02:17.942] AnimatedImageFrame[aif] :: constructor() [02:02:17.942] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.942] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_3.jpg [02:02:17.963] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.964] AnimatedImageFrame[aif] :: _init(), END [02:02:17.964] AnimatedImageFrame[aif] :: constructor() [02:02:17.964] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.965] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_4.jpg [02:02:17.987] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:17.988] AnimatedImageFrame[aif] :: _init(), END [02:02:17.989] AnimatedImageFrame[aif] :: constructor() [02:02:17.989] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:17.989] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_5.jpg [02:02:18.012] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:18.013] AnimatedImageFrame[aif] :: _init(), END [02:02:18.013] AnimatedImageFrame[aif] :: constructor() [02:02:18.013] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:18.014] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_1.jpg [02:02:18.033] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:18.035] AnimatedImageFrame[aif] :: _init(), END [02:02:18.035] AnimatedImageFrame[aif] :: constructor() [02:02:18.035] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:18.035] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_2.jpg [02:02:18.056] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:18.057] AnimatedImageFrame[aif] :: _init(), END [02:02:18.057] AnimatedImageFrame[aif] :: constructor() [02:02:18.057] AnimatedImageFrame[aif] :: _init(), BEGIN [02:02:18.057] CanvasClip :: LoadImageWithPromise(), src: 0ED9D293-2D9A-0969-CCAC-659E4DC86CD5_3.jpg [02:02:18.077] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:02:18.078] AnimatedImageFrame[aif] :: _init(), END [02:02:18.079] Overlay[simplefadedisplay] :: _animate() [02:02:18.079] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [02:02:18.079] CanvasStream[simplefadedisplay] :: _init(), p.then() [02:02:18.080] CanvasStream[canvas_1470791341155] :: _init(), promise.all.then() [02:02:18.082] CanvasStream[canvas_1470791341155] :: _init(), END [02:02:18.083] StreamMangaer :: init(), stream[canvas_1470791341155].then() [02:02:18.083] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1470791341155', progress: 1 } [02:02:18.083] index :: _onStepProgress_vidbot(), percent: 100 [02:02:18.083] StreamManager :: init(), promise.all.then... [02:02:18.083] Vidbot :: StreamMgr.on( 'INITED' ) [02:02:18.083] Vidbot :: _next(), _stepIndex:2 of 4 [02:02:18.083] index :: _onStepCompleted_vidbot(), step: 2 [02:02:18.084] index :: _onStepStarted_vidbot(), step: 3 [02:02:18.084] Vidbot :: step[2], label:Rendering Canvas Streams [02:02:18.084] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [02:02:18.084] StreamManager :: render() [02:02:18.085] CanvasStream[canvas_1470791341155] :: render() [02:02:18.121] index :: _onStepProgress_vidbot(), percent: 0 [02:02:32.665] index :: _onStepProgress_vidbot(), percent: 5 [02:02:47.136] index :: _onStepProgress_vidbot(), percent: 10 [02:03:00.256] index :: _onStepProgress_vidbot(), percent: 15 [02:03:13.656] index :: _onStepProgress_vidbot(), percent: 20 [02:03:26.047] index :: _onStepProgress_vidbot(), percent: 25 [02:03:41.686] index :: _onStepProgress_vidbot(), percent: 30 [02:03:53.639] index :: _onStepProgress_vidbot(), percent: 35 [02:04:07.449] index :: _onStepProgress_vidbot(), percent: 40 [02:04:19.948] index :: _onStepProgress_vidbot(), percent: 45 [02:04:36.316] index :: _onStepProgress_vidbot(), percent: 50 [02:04:47.575] index :: _onStepProgress_vidbot(), percent: 55 [02:04:58.693] index :: _onStepProgress_vidbot(), percent: 60 [02:05:09.899] index :: _onStepProgress_vidbot(), percent: 65 [02:05:21.181] index :: _onStepProgress_vidbot(), percent: 70 [02:05:33.170] index :: _onStepProgress_vidbot(), percent: 75 [02:05:47.133] index :: _onStepProgress_vidbot(), percent: 80 [02:06:01.332] index :: _onStepProgress_vidbot(), percent: 85 [02:06:15.049] index :: _onStepProgress_vidbot(), percent: 90 [02:06:26.633] index :: _onStepProgress_vidbot(), percent: 95 [02:06:35.368] index :: _onStepProgress_vidbot(), percent: 100 [02:06:36.058] StreamManager :: render(), Promise.all.then... [02:06:36.059] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [02:06:36.059] Vidbot :: _next(), _stepIndex:3 of 4 [02:06:36.059] index :: _onStepCompleted_vidbot(), step: 3 [02:06:36.060] index :: _onStepStarted_vidbot(), step: 4 [02:06:36.061] Vidbot :: step[3], label:Encoding Media [02:06:36.063] CanvasFilters :: Overlay() [02:06:36.064] AudioStream[audio_vo] :: inputOptions() [02:06:36.064] AudioFilters :: Volume() [02:06:36.064] filter: [2:a]volume=1[2_vol] [02:06:36.064] AudioFilters :: Delay() [02:06:36.064] filter: [2_vol]adelay=0|0[2_del] [02:06:36.064] AudioStream[bg_music] :: inputOptions() [02:06:36.064] AudioFilters :: Volume() [02:06:36.065] filter: [3:a]volume=0.20[3_vol] [02:06:36.065] AudioFilters :: FadeOut() [02:06:36.065] filter: [3_vol]afade=t=out:st=36.1:d=1[3_fadeout] [02:06:36.065] AudioFilters :: Delay() [02:06:36.065] filter: [3_fadeout]adelay=0|0[3_del] [02:06:36.065] AudioFilters :: Mix() [02:06:36.065] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [02:06:36.065] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [02:06:36.068] hang.time: 60 [02:06:36.169] Vidbot :: ffmpeg.on( 'start' ) [02:06:36.170] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=39.1 -r 30 -i ./tmp/canvas_1470791341155_%05d.png -to 00:00:39.100 -i file:///var/www/html/c [02:06:36.170] lients/16967/audio/0ED9D293-2D9A-0969-CCAC-659E4DC86CD5.mp3 -to 00:00:36.100 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Jazz-4. [02:06:36.170] 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.20[3_vol];[3_vol]afade=t=out:st=36 [02:06:36.170] .1: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_ou [02:06:36.170] t] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/16967/video/0ED9D293-2D9A-0969-CCAC [02:06:36.170] -659E4DC86CD5.mp4 [02:06:36.353] index :: _onStepProgress_vidbot(), percent: -5312655901 [02:06:36.781] index :: _onStepProgress_vidbot(), percent: 3 [02:06:37.284] index :: _onStepProgress_vidbot(), percent: 6 [02:06:37.796] index :: _onStepProgress_vidbot(), percent: 10 [02:06:38.301] index :: _onStepProgress_vidbot(), percent: 15 [02:06:39.313] index :: _onStepProgress_vidbot(), percent: 24 [02:06:39.815] index :: _onStepProgress_vidbot(), percent: 29 [02:06:40.345] index :: _onStepProgress_vidbot(), percent: 33 [02:06:40.849] index :: _onStepProgress_vidbot(), percent: 37 [02:06:41.351] index :: _onStepProgress_vidbot(), percent: 42 [02:06:41.851] index :: _onStepProgress_vidbot(), percent: 46 [02:06:42.353] index :: _onStepProgress_vidbot(), percent: 51 [02:06:42.854] index :: _onStepProgress_vidbot(), percent: 55 [02:06:44.370] index :: _onStepProgress_vidbot(), percent: 63 [02:06:44.872] index :: _onStepProgress_vidbot(), percent: 68 [02:06:45.674] index :: _onStepProgress_vidbot(), percent: 73 [02:06:45.885] index :: _onStepProgress_vidbot(), percent: 80 [02:06:46.387] index :: _onStepProgress_vidbot(), percent: 87 [02:06:46.888] index :: _onStepProgress_vidbot(), percent: 92 [02:06:47.222] index :: _onStepProgress_vidbot(), percent: 100 [02:06:47.245] Vidbot :: ffmpeg.on( 'end' ), Done! [02:06:47.246] StreamManager :: dispose() [02:06:47.246] CanvasStream[canvas_1470791341155] :: dispose() [02:06:47.251] Vidbot :: fflog.on( 'finish' ) [02:06:47.251] fflog.path: /var/www/html/clients/16967/video/0ED9D293-2D9A-0969-CCAC-659E4DC86CD5.mp4.fflog [02:06:47.251] Vidbot :: _next(), _stepIndex:4 of 4 [02:06:47.251] index :: _onStepCompleted_vidbot(), step: 4 [02:06:47.252] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 269.9, output: '/var/www/html/clients/16967/video/0ED9D293-2D9A-0969-CCAC-659E4DC86CD5.mp4', duration: 39.1 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/16967/video/0ED9D293-2D9A-0969-CCAC-659E4DC86CD5.mp4 Media Duration : 00:00:39.100 Generation Time : 00:04:29.899 ---------------------------------------------------------------------------------------------------------------