--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [22:07:04.239] Vidbot :: start() [22:07:04.240] Vidbot :: _next(), _stepIndex:0 of 4 [22:07:04.240] index :: _onStepStarted_vidbot(), step: 1 [22:07:04.241] Vidbot :: step[0], label:Initializing Core [22:07:04.249] index :: _onStepProgress_vidbot(), percent: 20 [22:07:04.249] Vidbot :: _parse() [22:07:04.250] index :: _onStepProgress_vidbot(), percent: 40 [22:07:04.250] Vidbot :: _validate() [22:07:04.251] index :: _onStepProgress_vidbot(), percent: 60 [22:07:04.251] Vidbot :: _fonts() [22:07:04.252] FabricFontManager :: add(), id: SourceSansPro-Bold [22:07:04.252] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [22:07:04.260] FabricFontManager :: add(), id: SourceSansPro-Light [22:07:04.260] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [22:07:04.261] FabricFontManager :: add(), id: DINOT-Bold [22:07:04.261] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [22:07:04.261] FabricFontManager :: add(), id: DINOT-Light [22:07:04.262] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [22:07:04.262] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [22:07:04.262] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [22:07:04.263] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [22:07:04.263] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [22:07:04.264] index :: _onStepProgress_vidbot(), percent: 80 [22:07:04.264] Vidbot :: _clips() [22:07:04.265] StreamManager :: add(), id:audio_vo, type:audio [22:07:04.265] AudioClip[audio_vo] :: constructor() [22:07:04.266] InputStream[audio_vo] :: constructor() [22:07:04.266] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [22:07:04.268] StreamManager :: add(), id:bg_music, type:audio [22:07:04.268] AudioClip[bg_music] :: constructor() [22:07:04.269] InputStream[bg_music] :: constructor() [22:07:04.269] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [22:07:04.269] StreamManager :: add(), id:simplefadedisplay, type:canvas [22:07:04.269] CanvasStream[canvas_1361133138481] :: constructor() [22:07:04.269] InputStream[canvas_1361133138481] :: constructor() [22:07:04.345] KenBurnsSlideshow[simplefadedisplay] :: constructor() [22:07:04.345] Overlay[simplefadedisplay] :: constructor() [22:07:04.345] CanvasClip[simplefadedisplay] :: constructor() [22:07:04.345] Clip[simplefadedisplay] :: constructor() [22:07:04.345] clip:"simplefadedisplay" added to stream:"canvas_1361133138481" [22:07:04.345] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1361133138481', clipId: 'simplefadedisplay' } [22:07:04.345] StreamManager :: add(), id:caption, type:canvas [22:07:04.346] RenCaption[caption] :: constructor() [22:07:04.346] Ren[caption] :: constructor() [22:07:04.346] Overlay[caption] :: constructor() [22:07:04.346] CanvasClip[caption] :: constructor() [22:07:04.346] Clip[caption] :: constructor() [22:07:04.346] clip:"caption" added to stream:"canvas_1361133138481" [22:07:04.346] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1361133138481', clipId: 'caption' } [22:07:04.346] all added... [22:07:04.346] Vidbot :: _next(), _stepIndex:1 of 4 [22:07:04.346] index :: _onStepCompleted_vidbot(), step: 1 [22:07:04.347] index :: _onStepStarted_vidbot(), step: 2 [22:07:04.347] Vidbot :: step[1], label:Initializing Input Streams [22:07:04.347] StreamManager :: init() [22:07:04.348] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [22:07:04.348] index :: _onStepProgress_vidbot(), percent: 33 [22:07:04.348] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [22:07:04.348] index :: _onStepProgress_vidbot(), percent: 67 [22:07:04.348] CanvasStream[canvas_1361133138481] :: _init(), BEGIN [22:07:04.349] i:0, c.id:simplefadedisplay [22:07:04.349] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [22:07:04.349] KenBurnsSlideshow[simplefadedisplay] :: _validate() [22:07:04.350] KenBurnsSlideshow[undefined] :: _validateAnim() [22:07:04.350] KenBurnsSlideshow[undefined] :: _validateTheme() [22:07:04.351] i:1, c.id:caption [22:07:04.351] RenCaption[caption] :: _init() [22:07:04.352] RenCaption[caption] :: _validate() [22:07:04.353] KenBurnsSlideshow[simplefadedisplay] :: _build() [22:07:04.358] AnimatedImageFrame[aif] :: constructor() [22:07:04.359] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.359] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_1.jpg [22:07:04.370] RenCaption[caption] :: _build() [22:07:04.386] Overlay[caption] :: _animate() [22:07:04.388] CanvasStream[caption] :: _init(), p.then() [22:07:04.410] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.413] AnimatedImageFrame[aif] :: _init(), END [22:07:04.414] AnimatedImageFrame[aif] :: constructor() [22:07:04.415] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.415] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_2.jpg [22:07:04.435] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.436] AnimatedImageFrame[aif] :: _init(), END [22:07:04.437] AnimatedImageFrame[aif] :: constructor() [22:07:04.437] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.437] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_3.jpg [22:07:04.456] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.457] AnimatedImageFrame[aif] :: _init(), END [22:07:04.457] AnimatedImageFrame[aif] :: constructor() [22:07:04.457] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.457] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_4.jpg [22:07:04.475] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.476] AnimatedImageFrame[aif] :: _init(), END [22:07:04.476] AnimatedImageFrame[aif] :: constructor() [22:07:04.476] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.476] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_5.jpg [22:07:04.498] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.499] AnimatedImageFrame[aif] :: _init(), END [22:07:04.499] AnimatedImageFrame[aif] :: constructor() [22:07:04.499] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.499] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_6.jpg [22:07:04.514] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.515] AnimatedImageFrame[aif] :: _init(), END [22:07:04.515] AnimatedImageFrame[aif] :: constructor() [22:07:04.515] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.515] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_7.jpg [22:07:04.534] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.534] AnimatedImageFrame[aif] :: _init(), END [22:07:04.535] AnimatedImageFrame[aif] :: constructor() [22:07:04.535] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.535] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_8.jpg [22:07:04.552] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.553] AnimatedImageFrame[aif] :: _init(), END [22:07:04.553] AnimatedImageFrame[aif] :: constructor() [22:07:04.553] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.553] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_9.jpg [22:07:04.570] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.570] AnimatedImageFrame[aif] :: _init(), END [22:07:04.571] AnimatedImageFrame[aif] :: constructor() [22:07:04.571] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.571] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_10.jpg [22:07:04.588] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.588] AnimatedImageFrame[aif] :: _init(), END [22:07:04.589] AnimatedImageFrame[aif] :: constructor() [22:07:04.589] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.589] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_11.jpg [22:07:04.606] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.607] AnimatedImageFrame[aif] :: _init(), END [22:07:04.608] AnimatedImageFrame[aif] :: constructor() [22:07:04.608] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.608] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_12.jpg [22:07:04.626] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.626] AnimatedImageFrame[aif] :: _init(), END [22:07:04.627] AnimatedImageFrame[aif] :: constructor() [22:07:04.627] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.627] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_13.jpg [22:07:04.646] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.646] AnimatedImageFrame[aif] :: _init(), END [22:07:04.647] AnimatedImageFrame[aif] :: constructor() [22:07:04.647] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.647] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_14.jpg [22:07:04.665] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.666] AnimatedImageFrame[aif] :: _init(), END [22:07:04.666] AnimatedImageFrame[aif] :: constructor() [22:07:04.666] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.666] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_15.jpg [22:07:04.683] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.684] AnimatedImageFrame[aif] :: _init(), END [22:07:04.685] AnimatedImageFrame[aif] :: constructor() [22:07:04.685] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.685] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_16.jpg [22:07:04.702] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.703] AnimatedImageFrame[aif] :: _init(), END [22:07:04.703] AnimatedImageFrame[aif] :: constructor() [22:07:04.703] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.704] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_17.jpg [22:07:04.721] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.722] AnimatedImageFrame[aif] :: _init(), END [22:07:04.723] AnimatedImageFrame[aif] :: constructor() [22:07:04.723] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.723] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_18.jpg [22:07:04.742] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.742] AnimatedImageFrame[aif] :: _init(), END [22:07:04.743] AnimatedImageFrame[aif] :: constructor() [22:07:04.743] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.743] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_19.jpg [22:07:04.762] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.763] AnimatedImageFrame[aif] :: _init(), END [22:07:04.763] AnimatedImageFrame[aif] :: constructor() [22:07:04.764] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.764] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_20.jpg [22:07:04.780] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.780] AnimatedImageFrame[aif] :: _init(), END [22:07:04.781] AnimatedImageFrame[aif] :: constructor() [22:07:04.781] AnimatedImageFrame[aif] :: _init(), BEGIN [22:07:04.781] CanvasClip :: LoadImageWithPromise(), src: 666CB58C-2582-5805-2DF8-3EB4111AEECB_1.jpg [22:07:04.798] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:07:04.798] AnimatedImageFrame[aif] :: _init(), END [22:07:04.798] Overlay[simplefadedisplay] :: _animate() [22:07:04.799] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [22:07:04.799] CanvasStream[simplefadedisplay] :: _init(), p.then() [22:07:04.799] CanvasStream[canvas_1361133138481] :: _init(), promise.all.then() [22:07:04.801] CanvasStream[canvas_1361133138481] :: _init(), END [22:07:04.801] StreamMangaer :: init(), stream[canvas_1361133138481].then() [22:07:04.802] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1361133138481', progress: 1 } [22:07:04.802] index :: _onStepProgress_vidbot(), percent: 100 [22:07:04.802] StreamManager :: init(), promise.all.then... [22:07:04.802] Vidbot :: StreamMgr.on( 'INITED' ) [22:07:04.802] Vidbot :: _next(), _stepIndex:2 of 4 [22:07:04.802] index :: _onStepCompleted_vidbot(), step: 2 [22:07:04.802] index :: _onStepStarted_vidbot(), step: 3 [22:07:04.803] Vidbot :: step[2], label:Rendering Canvas Streams [22:07:04.803] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [22:07:04.803] StreamManager :: render() [22:07:04.804] CanvasStream[canvas_1361133138481] :: render() [22:07:04.834] index :: _onStepProgress_vidbot(), percent: 0 [22:07:21.435] index :: _onStepProgress_vidbot(), percent: 5 [22:07:40.908] index :: _onStepProgress_vidbot(), percent: 10 [22:08:01.202] index :: _onStepProgress_vidbot(), percent: 15 [22:08:23.931] index :: _onStepProgress_vidbot(), percent: 20 [22:08:39.862] index :: _onStepProgress_vidbot(), percent: 25 [22:08:57.038] index :: _onStepProgress_vidbot(), percent: 30 [22:09:16.729] index :: _onStepProgress_vidbot(), percent: 35 [22:09:35.621] index :: _onStepProgress_vidbot(), percent: 40 [22:09:56.136] index :: _onStepProgress_vidbot(), percent: 45 [22:10:16.284] index :: _onStepProgress_vidbot(), percent: 50 [22:10:36.729] index :: _onStepProgress_vidbot(), percent: 55 [22:10:57.456] index :: _onStepProgress_vidbot(), percent: 60 [22:11:20.122] index :: _onStepProgress_vidbot(), percent: 65 [22:11:42.121] index :: _onStepProgress_vidbot(), percent: 70 [22:12:04.110] index :: _onStepProgress_vidbot(), percent: 75 [22:12:26.447] index :: _onStepProgress_vidbot(), percent: 80 [22:12:48.115] index :: _onStepProgress_vidbot(), percent: 85 [22:13:08.845] index :: _onStepProgress_vidbot(), percent: 90 [22:13:27.171] index :: _onStepProgress_vidbot(), percent: 95 [22:13:46.528] index :: _onStepProgress_vidbot(), percent: 100 [22:13:48.240] StreamManager :: render(), Promise.all.then... [22:13:48.240] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [22:13:48.241] Vidbot :: _next(), _stepIndex:3 of 4 [22:13:48.241] index :: _onStepCompleted_vidbot(), step: 3 [22:13:48.242] index :: _onStepStarted_vidbot(), step: 4 [22:13:48.243] Vidbot :: step[3], label:Encoding Media [22:13:48.245] CanvasFilters :: Overlay() [22:13:48.245] AudioStream[audio_vo] :: inputOptions() [22:13:48.246] AudioFilters :: Volume() [22:13:48.246] filter: [2:a]volume=1[2_vol] [22:13:48.246] AudioFilters :: Delay() [22:13:48.246] filter: [2_vol]adelay=0|0[2_del] [22:13:48.246] AudioStream[bg_music] :: inputOptions() [22:13:48.246] AudioFilters :: Volume() [22:13:48.246] filter: [3:a]volume=0.25[3_vol] [22:13:48.246] AudioFilters :: FadeOut() [22:13:48.246] filter: [3_vol]afade=t=out:st=61.39:d=1[3_fadeout] [22:13:48.247] AudioFilters :: Delay() [22:13:48.247] filter: [3_fadeout]adelay=0|0[3_del] [22:13:48.247] AudioFilters :: Mix() [22:13:48.247] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [22:13:48.247] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [22:13:48.249] hang.time: 60 [22:13:48.345] Vidbot :: ffmpeg.on( 'start' ) [22:13:48.345] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=61.39 -r 30 -i ./tmp/canvas_1361133138481_%05d.png -to 00:01:01.390 -i file:///var/www/html/ [22:13:48.345] clients/10231/audio/666CB58C-2582-5805-2DF8-3EB4111AEECB.mp3 -to 00:01:01.390 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Jazz-2 [22:13:48.345] .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:st=6 [22:13:48.345] 1.39: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_ [22:13:48.345] out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/10231/video/666CB58C-2582-5805-2D [22:13:48.345] F8-3EB4111AEECB.mp4 [22:13:48.517] index :: _onStepProgress_vidbot(), percent: -3383691900 [22:13:48.945] index :: _onStepProgress_vidbot(), percent: 2 [22:13:49.951] index :: _onStepProgress_vidbot(), percent: 7 [22:13:50.957] index :: _onStepProgress_vidbot(), percent: 11 [22:13:51.963] index :: _onStepProgress_vidbot(), percent: 16 [22:13:52.969] index :: _onStepProgress_vidbot(), percent: 21 [22:13:53.984] index :: _onStepProgress_vidbot(), percent: 25 [22:13:55.004] index :: _onStepProgress_vidbot(), percent: 30 [22:13:56.509] index :: _onStepProgress_vidbot(), percent: 37 [22:13:57.522] index :: _onStepProgress_vidbot(), percent: 42 [22:13:58.022] index :: _onStepProgress_vidbot(), percent: 46 [22:13:59.030] index :: _onStepProgress_vidbot(), percent: 52 [22:13:59.534] index :: _onStepProgress_vidbot(), percent: 56 [22:14:00.039] index :: _onStepProgress_vidbot(), percent: 60 [22:14:01.042] index :: _onStepProgress_vidbot(), percent: 66 [22:14:02.044] index :: _onStepProgress_vidbot(), percent: 71 [22:14:03.054] index :: _onStepProgress_vidbot(), percent: 77 [22:14:03.563] index :: _onStepProgress_vidbot(), percent: 80 [22:14:04.573] index :: _onStepProgress_vidbot(), percent: 86 [22:14:05.576] index :: _onStepProgress_vidbot(), percent: 91 [22:14:06.591] index :: _onStepProgress_vidbot(), percent: 97 [22:14:07.141] index :: _onStepProgress_vidbot(), percent: 100 [22:14:07.167] Vidbot :: ffmpeg.on( 'end' ), Done! [22:14:07.167] StreamManager :: dispose() [22:14:07.168] CanvasStream[canvas_1361133138481] :: dispose() [22:14:07.172] Vidbot :: fflog.on( 'finish' ) [22:14:07.173] fflog.path: /var/www/html/clients/10231/video/666CB58C-2582-5805-2DF8-3EB4111AEECB.mp4.fflog [22:14:07.173] Vidbot :: _next(), _stepIndex:4 of 4 [22:14:07.173] index :: _onStepCompleted_vidbot(), step: 4 [22:14:07.173] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 422.952, output: '/var/www/html/clients/10231/video/666CB58C-2582-5805-2DF8-3EB4111AEECB.mp4', duration: 61.39 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/10231/video/666CB58C-2582-5805-2DF8-3EB4111AEECB.mp4 Media Duration : 00:01:01.390 Generation Time : 00:07:02.951 ---------------------------------------------------------------------------------------------------------------