--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [03:00:09.626] Vidbot :: start() [03:00:09.627] Vidbot :: _next(), _stepIndex:0 of 4 [03:00:09.627] index :: _onStepStarted_vidbot(), step: 1 [03:00:09.629] Vidbot :: step[0], label:Initializing Core [03:00:09.639] index :: _onStepProgress_vidbot(), percent: 20 [03:00:09.640] Vidbot :: _parse() [03:00:09.641] index :: _onStepProgress_vidbot(), percent: 40 [03:00:09.641] Vidbot :: _validate() [03:00:09.642] index :: _onStepProgress_vidbot(), percent: 60 [03:00:09.642] Vidbot :: _fonts() [03:00:09.643] FabricFontManager :: add(), id: SourceSansPro-Bold [03:00:09.643] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [03:00:09.652] FabricFontManager :: add(), id: SourceSansPro-Light [03:00:09.652] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [03:00:09.653] FabricFontManager :: add(), id: DINOT-Bold [03:00:09.653] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [03:00:09.654] FabricFontManager :: add(), id: DINOT-Light [03:00:09.654] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [03:00:09.655] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [03:00:09.655] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [03:00:09.656] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [03:00:09.656] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [03:00:09.658] index :: _onStepProgress_vidbot(), percent: 80 [03:00:09.658] Vidbot :: _clips() [03:00:09.659] StreamManager :: add(), id:audio_vo, type:audio [03:00:09.659] AudioClip[audio_vo] :: constructor() [03:00:09.659] InputStream[audio_vo] :: constructor() [03:00:09.659] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [03:00:09.662] StreamManager :: add(), id:bg_music, type:audio [03:00:09.663] AudioClip[bg_music] :: constructor() [03:00:09.663] InputStream[bg_music] :: constructor() [03:00:09.663] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [03:00:09.663] StreamManager :: add(), id:simplefadedisplay, type:canvas [03:00:09.664] CanvasStream[canvas_1679923286042] :: constructor() [03:00:09.664] InputStream[canvas_1679923286042] :: constructor() [03:00:09.755] KenBurnsSlideshow[simplefadedisplay] :: constructor() [03:00:09.755] Overlay[simplefadedisplay] :: constructor() [03:00:09.755] CanvasClip[simplefadedisplay] :: constructor() [03:00:09.755] Clip[simplefadedisplay] :: constructor() [03:00:09.756] clip:"simplefadedisplay" added to stream:"canvas_1679923286042" [03:00:09.756] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1679923286042', clipId: 'simplefadedisplay' } [03:00:09.756] StreamManager :: add(), id:caption, type:canvas [03:00:09.756] RenCaption[caption] :: constructor() [03:00:09.756] Ren[caption] :: constructor() [03:00:09.756] Overlay[caption] :: constructor() [03:00:09.757] CanvasClip[caption] :: constructor() [03:00:09.757] Clip[caption] :: constructor() [03:00:09.757] clip:"caption" added to stream:"canvas_1679923286042" [03:00:09.757] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1679923286042', clipId: 'caption' } [03:00:09.757] all added... [03:00:09.757] Vidbot :: _next(), _stepIndex:1 of 4 [03:00:09.757] index :: _onStepCompleted_vidbot(), step: 1 [03:00:09.758] index :: _onStepStarted_vidbot(), step: 2 [03:00:09.758] Vidbot :: step[1], label:Initializing Input Streams [03:00:09.758] StreamManager :: init() [03:00:09.759] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [03:00:09.759] index :: _onStepProgress_vidbot(), percent: 33 [03:00:09.759] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [03:00:09.759] index :: _onStepProgress_vidbot(), percent: 67 [03:00:09.760] CanvasStream[canvas_1679923286042] :: _init(), BEGIN [03:00:09.760] i:0, c.id:simplefadedisplay [03:00:09.760] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [03:00:09.761] KenBurnsSlideshow[simplefadedisplay] :: _validate() [03:00:09.761] KenBurnsSlideshow[undefined] :: _validateAnim() [03:00:09.762] KenBurnsSlideshow[undefined] :: _validateTheme() [03:00:09.763] i:1, c.id:caption [03:00:09.763] RenCaption[caption] :: _init() [03:00:09.764] RenCaption[caption] :: _validate() [03:00:09.765] KenBurnsSlideshow[simplefadedisplay] :: _build() [03:00:09.772] AnimatedImageFrame[aif] :: constructor() [03:00:09.773] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.774] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_1.jpg [03:00:09.788] RenCaption[caption] :: _build() [03:00:09.808] Overlay[caption] :: _animate() [03:00:09.811] CanvasStream[caption] :: _init(), p.then() [03:00:09.838] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.842] AnimatedImageFrame[aif] :: _init(), END [03:00:09.844] AnimatedImageFrame[aif] :: constructor() [03:00:09.845] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.845] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_2.jpg [03:00:09.868] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.870] AnimatedImageFrame[aif] :: _init(), END [03:00:09.871] AnimatedImageFrame[aif] :: constructor() [03:00:09.871] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.871] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_3.jpg [03:00:09.894] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.896] AnimatedImageFrame[aif] :: _init(), END [03:00:09.897] AnimatedImageFrame[aif] :: constructor() [03:00:09.897] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.897] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_4.jpg [03:00:09.917] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.919] AnimatedImageFrame[aif] :: _init(), END [03:00:09.919] AnimatedImageFrame[aif] :: constructor() [03:00:09.920] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.920] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_5.jpg [03:00:09.941] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.942] AnimatedImageFrame[aif] :: _init(), END [03:00:09.943] AnimatedImageFrame[aif] :: constructor() [03:00:09.943] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.943] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_6.jpg [03:00:09.972] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.973] AnimatedImageFrame[aif] :: _init(), END [03:00:09.974] AnimatedImageFrame[aif] :: constructor() [03:00:09.974] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.974] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_7.jpg [03:00:09.996] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:09.997] AnimatedImageFrame[aif] :: _init(), END [03:00:09.998] AnimatedImageFrame[aif] :: constructor() [03:00:09.998] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:09.998] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_8.jpg [03:00:10.018] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.019] AnimatedImageFrame[aif] :: _init(), END [03:00:10.020] AnimatedImageFrame[aif] :: constructor() [03:00:10.020] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.020] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_9.jpg [03:00:10.038] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.039] AnimatedImageFrame[aif] :: _init(), END [03:00:10.040] AnimatedImageFrame[aif] :: constructor() [03:00:10.040] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.040] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_10.jpg [03:00:10.057] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.058] AnimatedImageFrame[aif] :: _init(), END [03:00:10.059] AnimatedImageFrame[aif] :: constructor() [03:00:10.059] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.059] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_11.jpg [03:00:10.075] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.077] AnimatedImageFrame[aif] :: _init(), END [03:00:10.077] AnimatedImageFrame[aif] :: constructor() [03:00:10.077] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.077] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_12.jpg [03:00:10.095] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.097] AnimatedImageFrame[aif] :: _init(), END [03:00:10.097] AnimatedImageFrame[aif] :: constructor() [03:00:10.098] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.098] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_13.jpg [03:00:10.116] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.117] AnimatedImageFrame[aif] :: _init(), END [03:00:10.118] AnimatedImageFrame[aif] :: constructor() [03:00:10.118] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.118] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_14.jpg [03:00:10.135] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.136] AnimatedImageFrame[aif] :: _init(), END [03:00:10.137] AnimatedImageFrame[aif] :: constructor() [03:00:10.137] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.137] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_15.jpg [03:00:10.154] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.156] AnimatedImageFrame[aif] :: _init(), END [03:00:10.156] AnimatedImageFrame[aif] :: constructor() [03:00:10.156] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.156] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_16.jpg [03:00:10.174] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.176] AnimatedImageFrame[aif] :: _init(), END [03:00:10.176] AnimatedImageFrame[aif] :: constructor() [03:00:10.176] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.177] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_17.jpg [03:00:10.192] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.194] AnimatedImageFrame[aif] :: _init(), END [03:00:10.194] AnimatedImageFrame[aif] :: constructor() [03:00:10.195] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.195] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_18.jpg [03:00:10.213] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.214] AnimatedImageFrame[aif] :: _init(), END [03:00:10.215] AnimatedImageFrame[aif] :: constructor() [03:00:10.215] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.215] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_19.jpg [03:00:10.253] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.254] AnimatedImageFrame[aif] :: _init(), END [03:00:10.255] AnimatedImageFrame[aif] :: constructor() [03:00:10.255] AnimatedImageFrame[aif] :: _init(), BEGIN [03:00:10.255] CanvasClip :: LoadImageWithPromise(), src: 08647106-7DE3-15F5-75CA-1C83BD332B16_20.jpg [03:00:10.278] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [03:00:10.280] AnimatedImageFrame[aif] :: _init(), END [03:00:10.280] Overlay[simplefadedisplay] :: _animate() [03:00:10.281] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [03:00:10.281] CanvasStream[simplefadedisplay] :: _init(), p.then() [03:00:10.281] CanvasStream[canvas_1679923286042] :: _init(), promise.all.then() [03:00:10.283] CanvasStream[canvas_1679923286042] :: _init(), END [03:00:10.284] StreamMangaer :: init(), stream[canvas_1679923286042].then() [03:00:10.284] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1679923286042', progress: 1 } [03:00:10.284] index :: _onStepProgress_vidbot(), percent: 100 [03:00:10.284] StreamManager :: init(), promise.all.then... [03:00:10.284] Vidbot :: StreamMgr.on( 'INITED' ) [03:00:10.285] Vidbot :: _next(), _stepIndex:2 of 4 [03:00:10.285] index :: _onStepCompleted_vidbot(), step: 2 [03:00:10.285] index :: _onStepStarted_vidbot(), step: 3 [03:00:10.285] Vidbot :: step[2], label:Rendering Canvas Streams [03:00:10.285] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [03:00:10.286] StreamManager :: render() [03:00:10.286] CanvasStream[canvas_1679923286042] :: render() [03:00:10.321] index :: _onStepProgress_vidbot(), percent: 0 [03:00:29.852] index :: _onStepProgress_vidbot(), percent: 5 [03:00:52.512] index :: _onStepProgress_vidbot(), percent: 10 [03:01:09.580] index :: _onStepProgress_vidbot(), percent: 15 [03:01:26.633] index :: _onStepProgress_vidbot(), percent: 20 [03:01:42.321] index :: _onStepProgress_vidbot(), percent: 25 [03:01:58.578] index :: _onStepProgress_vidbot(), percent: 30 [03:02:15.157] index :: _onStepProgress_vidbot(), percent: 35 [03:02:30.341] index :: _onStepProgress_vidbot(), percent: 40 [03:02:45.001] index :: _onStepProgress_vidbot(), percent: 45 [03:02:57.615] index :: _onStepProgress_vidbot(), percent: 50 [03:03:07.247] index :: _onStepProgress_vidbot(), percent: 55 [03:03:19.530] index :: _onStepProgress_vidbot(), percent: 60 [03:03:33.061] index :: _onStepProgress_vidbot(), percent: 65 [03:03:45.044] index :: _onStepProgress_vidbot(), percent: 70 [03:04:01.604] index :: _onStepProgress_vidbot(), percent: 75 [03:04:14.544] index :: _onStepProgress_vidbot(), percent: 80 [03:04:24.597] index :: _onStepProgress_vidbot(), percent: 85 [03:04:37.209] index :: _onStepProgress_vidbot(), percent: 90 [03:04:53.565] index :: _onStepProgress_vidbot(), percent: 95 [03:05:10.529] index :: _onStepProgress_vidbot(), percent: 100 [03:05:12.233] StreamManager :: render(), Promise.all.then... [03:05:12.233] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [03:05:12.234] Vidbot :: _next(), _stepIndex:3 of 4 [03:05:12.234] index :: _onStepCompleted_vidbot(), step: 3 [03:05:12.234] index :: _onStepStarted_vidbot(), step: 4 [03:05:12.235] Vidbot :: step[3], label:Encoding Media [03:05:12.238] CanvasFilters :: Overlay() [03:05:12.239] AudioStream[audio_vo] :: inputOptions() [03:05:12.239] AudioFilters :: Volume() [03:05:12.239] filter: [2:a]volume=1[2_vol] [03:05:12.240] AudioFilters :: Delay() [03:05:12.240] filter: [2_vol]adelay=0|0[2_del] [03:05:12.240] AudioStream[bg_music] :: inputOptions() [03:05:12.240] AudioFilters :: Volume() [03:05:12.240] filter: [3:a]volume=0.25[3_vol] [03:05:12.240] AudioFilters :: FadeOut() [03:05:12.240] filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout] [03:05:12.240] AudioFilters :: Delay() [03:05:12.240] filter: [3_fadeout]adelay=0|0[3_del] [03:05:12.241] AudioFilters :: Mix() [03:05:12.241] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [03:05:12.241] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [03:05:12.243] hang.time: 60 [03:05:12.359] Vidbot :: ffmpeg.on( 'start' ) [03:05:12.359] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60 -r 30 -i ./tmp/canvas_1679923286042_%05d.png -to 00:01:00.000 -i file:///var/www/html/cli [03:05:12.359] ents/16181/audio/08647106-7DE3-15F5-75CA-1C83BD332B16.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Groove-4. [03:05:12.359] 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=60 [03:05:12.359] :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] [03:05:12.359] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/16181/video/08647106-7DE3-15F5-75CA-1 [03:05:12.359] C83BD332B16.mp4 [03:05:12.553] index :: _onStepProgress_vidbot(), percent: -3462080762 [03:05:12.959] index :: _onStepProgress_vidbot(), percent: 1 [03:05:13.968] index :: _onStepProgress_vidbot(), percent: 5 [03:05:14.977] index :: _onStepProgress_vidbot(), percent: 10 [03:05:16.491] index :: _onStepProgress_vidbot(), percent: 17 [03:05:16.992] index :: _onStepProgress_vidbot(), percent: 20 [03:05:18.006] index :: _onStepProgress_vidbot(), percent: 25 [03:05:19.010] index :: _onStepProgress_vidbot(), percent: 30 [03:05:20.533] index :: _onStepProgress_vidbot(), percent: 37 [03:05:21.033] index :: _onStepProgress_vidbot(), percent: 40 [03:05:22.045] index :: _onStepProgress_vidbot(), percent: 45 [03:05:23.059] index :: _onStepProgress_vidbot(), percent: 52 [03:05:23.560] index :: _onStepProgress_vidbot(), percent: 55 [03:05:24.568] index :: _onStepProgress_vidbot(), percent: 61 [03:05:25.075] index :: _onStepProgress_vidbot(), percent: 65 [03:05:26.090] index :: _onStepProgress_vidbot(), percent: 72 [03:05:26.591] index :: _onStepProgress_vidbot(), percent: 75 [03:05:27.593] index :: _onStepProgress_vidbot(), percent: 82 [03:05:28.104] index :: _onStepProgress_vidbot(), percent: 87 [03:05:28.609] index :: _onStepProgress_vidbot(), percent: 90 [03:05:29.616] index :: _onStepProgress_vidbot(), percent: 96 [03:05:30.116] index :: _onStepProgress_vidbot(), percent: 100 [03:05:30.184] Vidbot :: ffmpeg.on( 'end' ), Done! [03:05:30.184] StreamManager :: dispose() [03:05:30.185] CanvasStream[canvas_1679923286042] :: dispose() [03:05:30.190] Vidbot :: fflog.on( 'finish' ) [03:05:30.190] fflog.path: /var/www/html/clients/16181/video/08647106-7DE3-15F5-75CA-1C83BD332B16.mp4.fflog [03:05:30.190] Vidbot :: _next(), _stepIndex:4 of 4 [03:05:30.190] index :: _onStepCompleted_vidbot(), step: 4 [03:05:30.190] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 320.586, output: '/var/www/html/clients/16181/video/08647106-7DE3-15F5-75CA-1C83BD332B16.mp4', duration: 60 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/16181/video/08647106-7DE3-15F5-75CA-1C83BD332B16.mp4 Media Duration : 00:01:00.000 Generation Time : 00:05:20.586 ---------------------------------------------------------------------------------------------------------------