--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [15:35:33.312] Vidbot :: start() [15:35:33.313] Vidbot :: _next(), _stepIndex:0 of 4 [15:35:33.313] index :: _onStepStarted_vidbot(), step: 1 [15:35:33.314] Vidbot :: step[0], label:Initializing Core [15:35:33.323] index :: _onStepProgress_vidbot(), percent: 20 [15:35:33.323] Vidbot :: _parse() [15:35:33.325] index :: _onStepProgress_vidbot(), percent: 40 [15:35:33.380] Vidbot :: _validate() [15:35:33.381] index :: _onStepProgress_vidbot(), percent: 60 [15:35:33.382] Vidbot :: _fonts() [15:35:33.382] FabricFontManager :: add(), id: SourceSansPro-Bold [15:35:33.382] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [15:35:33.391] FabricFontManager :: add(), id: SourceSansPro-Light [15:35:33.391] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [15:35:33.392] FabricFontManager :: add(), id: DINOT-Bold [15:35:33.392] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [15:35:33.393] FabricFontManager :: add(), id: DINOT-Light [15:35:33.393] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [15:35:33.394] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [15:35:33.394] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [15:35:33.395] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [15:35:33.395] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [15:35:33.396] index :: _onStepProgress_vidbot(), percent: 80 [15:35:33.396] Vidbot :: _clips() [15:35:33.396] StreamManager :: add(), id:audio_vo, type:audio [15:35:33.397] AudioClip[audio_vo] :: constructor() [15:35:33.397] InputStream[audio_vo] :: constructor() [15:35:33.397] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [15:35:33.400] StreamManager :: add(), id:bg_music, type:audio [15:35:33.400] AudioClip[bg_music] :: constructor() [15:35:33.400] InputStream[bg_music] :: constructor() [15:35:33.400] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [15:35:33.400] StreamManager :: add(), id:simplefadedisplay, type:canvas [15:35:33.401] CanvasStream[canvas_57347079775] :: constructor() [15:35:33.401] InputStream[canvas_57347079775] :: constructor() [15:35:33.478] KenBurnsSlideshow[simplefadedisplay] :: constructor() [15:35:33.478] Overlay[simplefadedisplay] :: constructor() [15:35:33.478] CanvasClip[simplefadedisplay] :: constructor() [15:35:33.478] Clip[simplefadedisplay] :: constructor() [15:35:33.478] clip:"simplefadedisplay" added to stream:"canvas_57347079775" [15:35:33.478] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_57347079775', clipId: 'simplefadedisplay' } [15:35:33.479] StreamManager :: add(), id:caption, type:canvas [15:35:33.479] RenCaption[caption] :: constructor() [15:35:33.479] Ren[caption] :: constructor() [15:35:33.479] Overlay[caption] :: constructor() [15:35:33.479] CanvasClip[caption] :: constructor() [15:35:33.479] Clip[caption] :: constructor() [15:35:33.479] clip:"caption" added to stream:"canvas_57347079775" [15:35:33.479] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_57347079775', clipId: 'caption' } [15:35:33.479] all added... [15:35:33.479] Vidbot :: _next(), _stepIndex:1 of 4 [15:35:33.480] index :: _onStepCompleted_vidbot(), step: 1 [15:35:33.480] index :: _onStepStarted_vidbot(), step: 2 [15:35:33.480] Vidbot :: step[1], label:Initializing Input Streams [15:35:33.481] StreamManager :: init() [15:35:33.481] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [15:35:33.481] index :: _onStepProgress_vidbot(), percent: 33 [15:35:33.481] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [15:35:33.481] index :: _onStepProgress_vidbot(), percent: 67 [15:35:33.482] CanvasStream[canvas_57347079775] :: _init(), BEGIN [15:35:33.482] i:0, c.id:simplefadedisplay [15:35:33.482] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [15:35:33.483] KenBurnsSlideshow[simplefadedisplay] :: _validate() [15:35:33.483] KenBurnsSlideshow[undefined] :: _validateAnim() [15:35:33.483] KenBurnsSlideshow[undefined] :: _validateTheme() [15:35:33.485] i:1, c.id:caption [15:35:33.485] RenCaption[caption] :: _init() [15:35:33.485] RenCaption[caption] :: _validate() [15:35:33.486] KenBurnsSlideshow[simplefadedisplay] :: _build() [15:35:33.492] AnimatedImageFrame[aif] :: constructor() [15:35:33.493] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.494] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_1.jpg [15:35:33.506] RenCaption[caption] :: _build() [15:35:33.523] Overlay[caption] :: _animate() [15:35:33.526] CanvasStream[caption] :: _init(), p.then() [15:35:33.542] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.546] AnimatedImageFrame[aif] :: _init(), END [15:35:33.547] AnimatedImageFrame[aif] :: constructor() [15:35:33.548] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.548] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_2.jpg [15:35:33.560] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.561] AnimatedImageFrame[aif] :: _init(), END [15:35:33.562] AnimatedImageFrame[aif] :: constructor() [15:35:33.562] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.562] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_3.jpg [15:35:33.572] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.574] AnimatedImageFrame[aif] :: _init(), END [15:35:33.574] AnimatedImageFrame[aif] :: constructor() [15:35:33.574] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.574] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_4.jpg [15:35:33.585] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.586] AnimatedImageFrame[aif] :: _init(), END [15:35:33.587] AnimatedImageFrame[aif] :: constructor() [15:35:33.587] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.587] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_5.jpg [15:35:33.598] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.599] AnimatedImageFrame[aif] :: _init(), END [15:35:33.599] AnimatedImageFrame[aif] :: constructor() [15:35:33.599] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.599] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_6.jpg [15:35:33.609] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.610] AnimatedImageFrame[aif] :: _init(), END [15:35:33.610] AnimatedImageFrame[aif] :: constructor() [15:35:33.610] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.611] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_7.jpg [15:35:33.621] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.622] AnimatedImageFrame[aif] :: _init(), END [15:35:33.622] AnimatedImageFrame[aif] :: constructor() [15:35:33.622] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.622] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_8.jpg [15:35:33.632] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.633] AnimatedImageFrame[aif] :: _init(), END [15:35:33.634] AnimatedImageFrame[aif] :: constructor() [15:35:33.634] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.634] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_9.jpg [15:35:33.645] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.646] AnimatedImageFrame[aif] :: _init(), END [15:35:33.646] AnimatedImageFrame[aif] :: constructor() [15:35:33.646] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.646] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_10.jpg [15:35:33.658] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.659] AnimatedImageFrame[aif] :: _init(), END [15:35:33.659] AnimatedImageFrame[aif] :: constructor() [15:35:33.659] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.659] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_11.jpg [15:35:33.671] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.672] AnimatedImageFrame[aif] :: _init(), END [15:35:33.672] AnimatedImageFrame[aif] :: constructor() [15:35:33.673] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.673] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_12.jpg [15:35:33.684] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.685] AnimatedImageFrame[aif] :: _init(), END [15:35:33.685] AnimatedImageFrame[aif] :: constructor() [15:35:33.685] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.686] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_13.jpg [15:35:33.697] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.698] AnimatedImageFrame[aif] :: _init(), END [15:35:33.698] AnimatedImageFrame[aif] :: constructor() [15:35:33.698] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.699] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_14.jpg [15:35:33.710] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.710] AnimatedImageFrame[aif] :: _init(), END [15:35:33.711] AnimatedImageFrame[aif] :: constructor() [15:35:33.711] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.711] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_15.jpg [15:35:33.723] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.723] AnimatedImageFrame[aif] :: _init(), END [15:35:33.724] AnimatedImageFrame[aif] :: constructor() [15:35:33.724] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.724] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_16.jpg [15:35:33.736] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.736] AnimatedImageFrame[aif] :: _init(), END [15:35:33.737] AnimatedImageFrame[aif] :: constructor() [15:35:33.737] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.737] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_17.jpg [15:35:33.748] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.749] AnimatedImageFrame[aif] :: _init(), END [15:35:33.749] AnimatedImageFrame[aif] :: constructor() [15:35:33.749] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.750] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_1.jpg [15:35:33.760] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.760] AnimatedImageFrame[aif] :: _init(), END [15:35:33.761] AnimatedImageFrame[aif] :: constructor() [15:35:33.761] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.761] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_2.jpg [15:35:33.774] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.775] AnimatedImageFrame[aif] :: _init(), END [15:35:33.775] AnimatedImageFrame[aif] :: constructor() [15:35:33.775] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.775] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_3.jpg [15:35:33.785] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.786] AnimatedImageFrame[aif] :: _init(), END [15:35:33.787] AnimatedImageFrame[aif] :: constructor() [15:35:33.787] AnimatedImageFrame[aif] :: _init(), BEGIN [15:35:33.787] CanvasClip :: LoadImageWithPromise(), src: 179BE86A-6661-EDF2-4EF1-1F4BE0167184_4.jpg [15:35:33.797] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:35:33.798] AnimatedImageFrame[aif] :: _init(), END [15:35:33.799] Overlay[simplefadedisplay] :: _animate() [15:35:33.799] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [15:35:33.799] CanvasStream[simplefadedisplay] :: _init(), p.then() [15:35:33.800] CanvasStream[canvas_57347079775] :: _init(), promise.all.then() [15:35:33.802] CanvasStream[canvas_57347079775] :: _init(), END [15:35:33.802] StreamMangaer :: init(), stream[canvas_57347079775].then() [15:35:33.802] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_57347079775', progress: 1 } [15:35:33.802] index :: _onStepProgress_vidbot(), percent: 100 [15:35:33.802] StreamManager :: init(), promise.all.then... [15:35:33.802] Vidbot :: StreamMgr.on( 'INITED' ) [15:35:33.803] Vidbot :: _next(), _stepIndex:2 of 4 [15:35:33.803] index :: _onStepCompleted_vidbot(), step: 2 [15:35:33.803] index :: _onStepStarted_vidbot(), step: 3 [15:35:33.803] Vidbot :: step[2], label:Rendering Canvas Streams [15:35:33.803] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [15:35:33.804] StreamManager :: render() [15:35:33.804] CanvasStream[canvas_57347079775] :: render() [15:35:33.835] index :: _onStepProgress_vidbot(), percent: 0 [15:35:45.007] index :: _onStepProgress_vidbot(), percent: 5 [15:35:54.497] index :: _onStepProgress_vidbot(), percent: 10 [15:36:02.714] index :: _onStepProgress_vidbot(), percent: 15 [15:36:16.122] index :: _onStepProgress_vidbot(), percent: 20 [15:36:27.789] index :: _onStepProgress_vidbot(), percent: 25 [15:36:37.432] index :: _onStepProgress_vidbot(), percent: 30 [15:36:48.653] index :: _onStepProgress_vidbot(), percent: 35 [15:36:56.824] index :: _onStepProgress_vidbot(), percent: 40 [15:37:08.359] index :: _onStepProgress_vidbot(), percent: 45 [15:37:21.811] index :: _onStepProgress_vidbot(), percent: 50 [15:37:34.093] index :: _onStepProgress_vidbot(), percent: 55 [15:37:47.215] index :: _onStepProgress_vidbot(), percent: 60 [15:37:57.400] index :: _onStepProgress_vidbot(), percent: 65 [15:38:08.150] index :: _onStepProgress_vidbot(), percent: 70 [15:38:22.999] index :: _onStepProgress_vidbot(), percent: 75 [15:38:36.151] index :: _onStepProgress_vidbot(), percent: 80 [15:38:50.035] index :: _onStepProgress_vidbot(), percent: 85 [15:39:00.648] index :: _onStepProgress_vidbot(), percent: 90 [15:39:10.685] index :: _onStepProgress_vidbot(), percent: 95 [15:39:21.281] index :: _onStepProgress_vidbot(), percent: 100 [15:39:21.996] StreamManager :: render(), Promise.all.then... [15:39:21.996] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [15:39:21.997] Vidbot :: _next(), _stepIndex:3 of 4 [15:39:21.997] index :: _onStepCompleted_vidbot(), step: 3 [15:39:21.998] index :: _onStepStarted_vidbot(), step: 4 [15:39:21.999] Vidbot :: step[3], label:Encoding Media [15:39:22.001] CanvasFilters :: Overlay() [15:39:22.002] AudioStream[audio_vo] :: inputOptions() [15:39:22.002] AudioFilters :: Volume() [15:39:22.002] filter: [2:a]volume=1[2_vol] [15:39:22.002] AudioFilters :: Delay() [15:39:22.002] filter: [2_vol]adelay=0|0[2_del] [15:39:22.003] AudioStream[bg_music] :: inputOptions() [15:39:22.003] AudioFilters :: Volume() [15:39:22.003] filter: [3:a]volume=0.25[3_vol] [15:39:22.003] AudioFilters :: FadeOut() [15:39:22.003] filter: [3_vol]afade=t=out:st=60.08:d=1[3_fadeout] [15:39:22.003] AudioFilters :: Delay() [15:39:22.003] filter: [3_fadeout]adelay=0|0[3_del] [15:39:22.003] AudioFilters :: Mix() [15:39:22.003] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:39:22.003] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:39:22.006] hang.time: 60 [15:39:22.110] Vidbot :: ffmpeg.on( 'start' ) [15:39:22.110] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60.08 -r 30 -i ./tmp/canvas_57347079775_%05d.png -to 00:01:00.079 -i file:///var/www/html/cl [15:39:22.110] ients/10231/audio/179BE86A-6661-EDF2-4EF1-1F4BE0167184.mp3 -to 00:01:00.079 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Rock.mp3 [15:39:22.110] -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=60.08 [15:39:22.110] :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_out] [15:39:22.111] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/10231/video/179BE86A-6661-EDF2-4EF1-1 [15:39:22.111] F4BE0167184.mp4 [15:39:22.280] index :: _onStepProgress_vidbot(), percent: -3457470801 [15:39:22.681] index :: _onStepProgress_vidbot(), percent: 1 [15:39:23.690] index :: _onStepProgress_vidbot(), percent: 5 [15:39:24.698] index :: _onStepProgress_vidbot(), percent: 11 [15:39:25.199] index :: _onStepProgress_vidbot(), percent: 15 [15:39:26.219] index :: _onStepProgress_vidbot(), percent: 21 [15:39:27.226] index :: _onStepProgress_vidbot(), percent: 25 [15:39:28.227] index :: _onStepProgress_vidbot(), percent: 33 [15:39:28.739] index :: _onStepProgress_vidbot(), percent: 36 [15:39:29.755] index :: _onStepProgress_vidbot(), percent: 42 [15:39:30.255] index :: _onStepProgress_vidbot(), percent: 45 [15:39:31.286] index :: _onStepProgress_vidbot(), percent: 51 [15:39:32.319] index :: _onStepProgress_vidbot(), percent: 57 [15:39:32.819] index :: _onStepProgress_vidbot(), percent: 60 [15:39:33.820] index :: _onStepProgress_vidbot(), percent: 65 [15:39:34.821] index :: _onStepProgress_vidbot(), percent: 71 [15:39:35.831] index :: _onStepProgress_vidbot(), percent: 76 [15:39:36.838] index :: _onStepProgress_vidbot(), percent: 82 [15:39:37.845] index :: _onStepProgress_vidbot(), percent: 86 [15:39:38.860] index :: _onStepProgress_vidbot(), percent: 92 [15:39:39.380] index :: _onStepProgress_vidbot(), percent: 95 [15:39:40.249] index :: _onStepProgress_vidbot(), percent: 100 [15:39:40.275] Vidbot :: ffmpeg.on( 'end' ), Done! [15:39:40.275] StreamManager :: dispose() [15:39:40.276] CanvasStream[canvas_57347079775] :: dispose() [15:39:40.281] Vidbot :: fflog.on( 'finish' ) [15:39:40.281] fflog.path: /var/www/html/clients/10231/video/179BE86A-6661-EDF2-4EF1-1F4BE0167184.mp4.fflog [15:39:40.281] Vidbot :: _next(), _stepIndex:4 of 4 [15:39:40.281] index :: _onStepCompleted_vidbot(), step: 4 [15:39:40.281] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 246.988, output: '/var/www/html/clients/10231/video/179BE86A-6661-EDF2-4EF1-1F4BE0167184.mp4', duration: 60.08 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/10231/video/179BE86A-6661-EDF2-4EF1-1F4BE0167184.mp4 Media Duration : 00:01:00.079 Generation Time : 00:04:06.987 ---------------------------------------------------------------------------------------------------------------