--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [02:44:37.198] Vidbot :: start() [02:44:37.198] Vidbot :: _next(), _stepIndex:0 of 4 [02:44:37.199] index :: _onStepStarted_vidbot(), step: 1 [02:44:37.200] Vidbot :: step[0], label:Initializing Core [02:44:37.208] index :: _onStepProgress_vidbot(), percent: 20 [02:44:37.208] Vidbot :: _parse() [02:44:37.209] index :: _onStepProgress_vidbot(), percent: 40 [02:44:37.210] Vidbot :: _validate() [02:44:37.210] index :: _onStepProgress_vidbot(), percent: 60 [02:44:37.210] Vidbot :: _fonts() [02:44:37.211] FabricFontManager :: add(), id: SourceSansPro-Bold [02:44:37.211] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [02:44:37.219] FabricFontManager :: add(), id: SourceSansPro-Light [02:44:37.219] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [02:44:37.220] FabricFontManager :: add(), id: DINOT-Bold [02:44:37.220] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [02:44:37.221] FabricFontManager :: add(), id: DINOT-Light [02:44:37.221] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [02:44:37.221] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [02:44:37.221] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [02:44:37.222] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [02:44:37.222] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [02:44:37.223] index :: _onStepProgress_vidbot(), percent: 80 [02:44:37.223] Vidbot :: _clips() [02:44:37.224] StreamManager :: add(), id:audio_vo, type:audio [02:44:37.224] AudioClip[audio_vo] :: constructor() [02:44:37.224] InputStream[audio_vo] :: constructor() [02:44:37.224] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [02:44:37.227] StreamManager :: add(), id:bg_music, type:audio [02:44:37.227] AudioClip[bg_music] :: constructor() [02:44:37.227] InputStream[bg_music] :: constructor() [02:44:37.227] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [02:44:37.227] StreamManager :: add(), id:simplefadedisplay, type:canvas [02:44:37.228] CanvasStream[canvas_1213546242458] :: constructor() [02:44:37.228] InputStream[canvas_1213546242458] :: constructor() [02:44:37.301] KenBurnsSlideshow[simplefadedisplay] :: constructor() [02:44:37.302] Overlay[simplefadedisplay] :: constructor() [02:44:37.302] CanvasClip[simplefadedisplay] :: constructor() [02:44:37.302] Clip[simplefadedisplay] :: constructor() [02:44:37.302] clip:"simplefadedisplay" added to stream:"canvas_1213546242458" [02:44:37.302] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1213546242458', clipId: 'simplefadedisplay' } [02:44:37.302] StreamManager :: add(), id:caption, type:canvas [02:44:37.302] RenCaption[caption] :: constructor() [02:44:37.303] Ren[caption] :: constructor() [02:44:37.303] Overlay[caption] :: constructor() [02:44:37.303] CanvasClip[caption] :: constructor() [02:44:37.303] Clip[caption] :: constructor() [02:44:37.303] clip:"caption" added to stream:"canvas_1213546242458" [02:44:37.303] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1213546242458', clipId: 'caption' } [02:44:37.303] all added... [02:44:37.303] Vidbot :: _next(), _stepIndex:1 of 4 [02:44:37.303] index :: _onStepCompleted_vidbot(), step: 1 [02:44:37.304] index :: _onStepStarted_vidbot(), step: 2 [02:44:37.304] Vidbot :: step[1], label:Initializing Input Streams [02:44:37.304] StreamManager :: init() [02:44:37.305] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [02:44:37.305] index :: _onStepProgress_vidbot(), percent: 33 [02:44:37.305] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [02:44:37.305] index :: _onStepProgress_vidbot(), percent: 67 [02:44:37.305] CanvasStream[canvas_1213546242458] :: _init(), BEGIN [02:44:37.306] i:0, c.id:simplefadedisplay [02:44:37.306] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [02:44:37.306] KenBurnsSlideshow[simplefadedisplay] :: _validate() [02:44:37.307] KenBurnsSlideshow[undefined] :: _validateAnim() [02:44:37.307] KenBurnsSlideshow[undefined] :: _validateTheme() [02:44:37.308] i:1, c.id:caption [02:44:37.308] RenCaption[caption] :: _init() [02:44:37.309] RenCaption[caption] :: _validate() [02:44:37.310] KenBurnsSlideshow[simplefadedisplay] :: _build() [02:44:37.316] AnimatedImageFrame[aif] :: constructor() [02:44:37.317] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.317] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_1.jpg [02:44:37.329] RenCaption[caption] :: _build() [02:44:37.347] Overlay[caption] :: _animate() [02:44:37.350] CanvasStream[caption] :: _init(), p.then() [02:44:37.380] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.384] AnimatedImageFrame[aif] :: _init(), END [02:44:37.386] AnimatedImageFrame[aif] :: constructor() [02:44:37.386] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.387] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_2.jpg [02:44:37.415] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.417] AnimatedImageFrame[aif] :: _init(), END [02:44:37.418] AnimatedImageFrame[aif] :: constructor() [02:44:37.418] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.418] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_3.jpg [02:44:37.442] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.444] AnimatedImageFrame[aif] :: _init(), END [02:44:37.445] AnimatedImageFrame[aif] :: constructor() [02:44:37.445] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.445] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_4.jpg [02:44:37.469] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.470] AnimatedImageFrame[aif] :: _init(), END [02:44:37.471] AnimatedImageFrame[aif] :: constructor() [02:44:37.471] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.471] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_1.jpg [02:44:37.494] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.495] AnimatedImageFrame[aif] :: _init(), END [02:44:37.495] AnimatedImageFrame[aif] :: constructor() [02:44:37.495] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.495] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_2.jpg [02:44:37.521] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.523] AnimatedImageFrame[aif] :: _init(), END [02:44:37.523] AnimatedImageFrame[aif] :: constructor() [02:44:37.524] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.524] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_3.jpg [02:44:37.547] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.548] AnimatedImageFrame[aif] :: _init(), END [02:44:37.548] AnimatedImageFrame[aif] :: constructor() [02:44:37.548] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.548] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_4.jpg [02:44:37.576] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.576] AnimatedImageFrame[aif] :: _init(), END [02:44:37.577] AnimatedImageFrame[aif] :: constructor() [02:44:37.577] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.577] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_1.jpg [02:44:37.599] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.600] AnimatedImageFrame[aif] :: _init(), END [02:44:37.600] AnimatedImageFrame[aif] :: constructor() [02:44:37.601] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.601] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_2.jpg [02:44:37.623] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.624] AnimatedImageFrame[aif] :: _init(), END [02:44:37.624] AnimatedImageFrame[aif] :: constructor() [02:44:37.624] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.624] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_3.jpg [02:44:37.647] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.647] AnimatedImageFrame[aif] :: _init(), END [02:44:37.648] AnimatedImageFrame[aif] :: constructor() [02:44:37.648] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.648] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_4.jpg [02:44:37.670] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.671] AnimatedImageFrame[aif] :: _init(), END [02:44:37.671] AnimatedImageFrame[aif] :: constructor() [02:44:37.672] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.672] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_1.jpg [02:44:37.695] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.696] AnimatedImageFrame[aif] :: _init(), END [02:44:37.696] AnimatedImageFrame[aif] :: constructor() [02:44:37.697] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.697] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_2.jpg [02:44:37.720] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.721] AnimatedImageFrame[aif] :: _init(), END [02:44:37.721] AnimatedImageFrame[aif] :: constructor() [02:44:37.721] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.722] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_3.jpg [02:44:37.744] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.745] AnimatedImageFrame[aif] :: _init(), END [02:44:37.746] AnimatedImageFrame[aif] :: constructor() [02:44:37.746] AnimatedImageFrame[aif] :: _init(), BEGIN [02:44:37.746] CanvasClip :: LoadImageWithPromise(), src: 3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C_4.jpg [02:44:37.768] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [02:44:37.769] AnimatedImageFrame[aif] :: _init(), END [02:44:37.770] Overlay[simplefadedisplay] :: _animate() [02:44:37.770] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [02:44:37.770] CanvasStream[simplefadedisplay] :: _init(), p.then() [02:44:37.771] CanvasStream[canvas_1213546242458] :: _init(), promise.all.then() [02:44:37.773] CanvasStream[canvas_1213546242458] :: _init(), END [02:44:37.773] StreamMangaer :: init(), stream[canvas_1213546242458].then() [02:44:37.773] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1213546242458', progress: 1 } [02:44:37.773] index :: _onStepProgress_vidbot(), percent: 100 [02:44:37.773] StreamManager :: init(), promise.all.then... [02:44:37.773] Vidbot :: StreamMgr.on( 'INITED' ) [02:44:37.774] Vidbot :: _next(), _stepIndex:2 of 4 [02:44:37.774] index :: _onStepCompleted_vidbot(), step: 2 [02:44:37.774] index :: _onStepStarted_vidbot(), step: 3 [02:44:37.774] Vidbot :: step[2], label:Rendering Canvas Streams [02:44:37.774] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [02:44:37.774] StreamManager :: render() [02:44:37.775] CanvasStream[canvas_1213546242458] :: render() [02:44:37.836] index :: _onStepProgress_vidbot(), percent: 0 [02:44:56.183] index :: _onStepProgress_vidbot(), percent: 5 [02:45:14.576] index :: _onStepProgress_vidbot(), percent: 10 [02:45:33.557] index :: _onStepProgress_vidbot(), percent: 15 [02:45:54.308] index :: _onStepProgress_vidbot(), percent: 20 [02:46:15.748] index :: _onStepProgress_vidbot(), percent: 25 [02:46:37.330] index :: _onStepProgress_vidbot(), percent: 30 [02:46:57.411] index :: _onStepProgress_vidbot(), percent: 35 [02:47:15.876] index :: _onStepProgress_vidbot(), percent: 40 [02:47:33.270] index :: _onStepProgress_vidbot(), percent: 45 [02:47:52.544] index :: _onStepProgress_vidbot(), percent: 50 [02:48:11.150] index :: _onStepProgress_vidbot(), percent: 55 [02:48:31.845] index :: _onStepProgress_vidbot(), percent: 60 [02:48:50.644] index :: _onStepProgress_vidbot(), percent: 65 [02:49:09.741] index :: _onStepProgress_vidbot(), percent: 70 [02:49:28.045] index :: _onStepProgress_vidbot(), percent: 75 [02:49:46.797] index :: _onStepProgress_vidbot(), percent: 80 [02:50:05.581] index :: _onStepProgress_vidbot(), percent: 85 [02:50:26.540] index :: _onStepProgress_vidbot(), percent: 90 [02:50:49.518] index :: _onStepProgress_vidbot(), percent: 95 [02:51:12.441] index :: _onStepProgress_vidbot(), percent: 100 [02:51:14.272] StreamManager :: render(), Promise.all.then... [02:51:14.272] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [02:51:14.273] Vidbot :: _next(), _stepIndex:3 of 4 [02:51:14.273] index :: _onStepCompleted_vidbot(), step: 3 [02:51:14.274] index :: _onStepStarted_vidbot(), step: 4 [02:51:14.275] Vidbot :: step[3], label:Encoding Media [02:51:14.278] CanvasFilters :: Overlay() [02:51:14.279] AudioStream[audio_vo] :: inputOptions() [02:51:14.279] AudioFilters :: Volume() [02:51:14.279] filter: [2:a]volume=1[2_vol] [02:51:14.279] AudioFilters :: Delay() [02:51:14.279] filter: [2_vol]adelay=0|0[2_del] [02:51:14.279] AudioStream[bg_music] :: inputOptions() [02:51:14.280] AudioFilters :: Volume() [02:51:14.280] filter: [3:a]volume=0.25[3_vol] [02:51:14.280] AudioFilters :: FadeOut() [02:51:14.280] filter: [3_vol]afade=t=out:st=46.82:d=1[3_fadeout] [02:51:14.280] AudioFilters :: Delay() [02:51:14.280] filter: [3_fadeout]adelay=0|0[3_del] [02:51:14.280] AudioFilters :: Mix() [02:51:14.281] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [02:51:14.281] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [02:51:14.283] hang.time: 60 [02:51:14.434] Vidbot :: ffmpeg.on( 'start' ) [02:51:14.435] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=46.82 -r 30 -i ./tmp/canvas_1213546242458_%05d.png -to 00:00:46.820 -i file:///var/www/html/ [02:51:14.435] clients/20508/audio/3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C.mp3 -to 00:00:46.820 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF9_ED [02:51:14.435] M_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:s [02:51:14.435] t=46.82: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 [02:51:14.435] [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/20508/video/3C9A37D9-DA6C-B9FF [02:51:14.435] -EA27-393A00D4E11C.mp4 [02:51:14.645] index :: _onStepProgress_vidbot(), percent: -4436669067 [02:51:15.033] index :: _onStepProgress_vidbot(), percent: 1 [02:51:16.051] index :: _onStepProgress_vidbot(), percent: 6 [02:51:17.059] index :: _onStepProgress_vidbot(), percent: 11 [02:51:18.079] index :: _onStepProgress_vidbot(), percent: 16 [02:51:19.097] index :: _onStepProgress_vidbot(), percent: 21 [02:51:20.105] index :: _onStepProgress_vidbot(), percent: 26 [02:51:21.119] index :: _onStepProgress_vidbot(), percent: 31 [02:51:22.127] index :: _onStepProgress_vidbot(), percent: 36 [02:51:23.138] index :: _onStepProgress_vidbot(), percent: 41 [02:51:24.156] index :: _onStepProgress_vidbot(), percent: 46 [02:51:25.168] index :: _onStepProgress_vidbot(), percent: 52 [02:51:26.183] index :: _onStepProgress_vidbot(), percent: 57 [02:51:26.685] index :: _onStepProgress_vidbot(), percent: 60 [02:51:27.692] index :: _onStepProgress_vidbot(), percent: 65 [02:51:28.700] index :: _onStepProgress_vidbot(), percent: 70 [02:51:29.715] index :: _onStepProgress_vidbot(), percent: 75 [02:51:30.724] index :: _onStepProgress_vidbot(), percent: 81 [02:51:31.733] index :: _onStepProgress_vidbot(), percent: 86 [02:51:32.742] index :: _onStepProgress_vidbot(), percent: 92 [02:51:33.249] index :: _onStepProgress_vidbot(), percent: 96 [02:51:33.923] index :: _onStepProgress_vidbot(), percent: 100 [02:51:33.960] Vidbot :: ffmpeg.on( 'end' ), Done! [02:51:33.961] StreamManager :: dispose() [02:51:33.961] CanvasStream[canvas_1213546242458] :: dispose() [02:51:33.966] Vidbot :: fflog.on( 'finish' ) [02:51:33.966] fflog.path: /var/www/html/clients/20508/video/3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C.mp4.fflog [02:51:33.966] Vidbot :: _next(), _stepIndex:4 of 4 [02:51:33.966] index :: _onStepCompleted_vidbot(), step: 4 [02:51:33.967] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 416.787, output: '/var/www/html/clients/20508/video/3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C.mp4', duration: 46.82 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/20508/video/3C9A37D9-DA6C-B9FF-EA27-393A00D4E11C.mp4 Media Duration : 00:00:46.820 Generation Time : 00:06:56.786 ---------------------------------------------------------------------------------------------------------------