--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [21:41:54.520] Vidbot :: start() [21:41:54.521] Vidbot :: _next(), _stepIndex:0 of 4 [21:41:54.521] index :: _onStepStarted_vidbot(), step: 1 [21:41:54.522] Vidbot :: step[0], label:Initializing Core [21:41:54.531] index :: _onStepProgress_vidbot(), percent: 20 [21:41:54.531] Vidbot :: _parse() [21:41:54.533] index :: _onStepProgress_vidbot(), percent: 40 [21:41:54.533] Vidbot :: _validate() [21:41:54.534] index :: _onStepProgress_vidbot(), percent: 60 [21:41:54.534] Vidbot :: _fonts() [21:41:54.534] FabricFontManager :: add(), id: SourceSansPro-Bold [21:41:54.534] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [21:41:54.543] FabricFontManager :: add(), id: SourceSansPro-Light [21:41:54.543] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [21:41:54.544] FabricFontManager :: add(), id: DINOT-Bold [21:41:54.544] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [21:41:54.545] FabricFontManager :: add(), id: DINOT-Light [21:41:54.545] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [21:41:54.546] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [21:41:54.546] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [21:41:54.547] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [21:41:54.547] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [21:41:54.548] index :: _onStepProgress_vidbot(), percent: 80 [21:41:54.548] Vidbot :: _clips() [21:41:54.549] StreamManager :: add(), id:audio_vo, type:audio [21:41:54.549] AudioClip[audio_vo] :: constructor() [21:41:54.549] InputStream[audio_vo] :: constructor() [21:41:54.549] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [21:41:54.552] StreamManager :: add(), id:bg_music, type:audio [21:41:54.552] AudioClip[bg_music] :: constructor() [21:41:54.552] InputStream[bg_music] :: constructor() [21:41:54.553] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [21:41:54.553] StreamManager :: add(), id:simplefadedisplay, type:canvas [21:41:54.553] CanvasStream[canvas_836080774230] :: constructor() [21:41:54.553] InputStream[canvas_836080774230] :: constructor() [21:41:54.639] KenBurnsSlideshow[simplefadedisplay] :: constructor() [21:41:54.639] Overlay[simplefadedisplay] :: constructor() [21:41:54.639] CanvasClip[simplefadedisplay] :: constructor() [21:41:54.639] Clip[simplefadedisplay] :: constructor() [21:41:54.640] clip:"simplefadedisplay" added to stream:"canvas_836080774230" [21:41:54.640] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_836080774230', clipId: 'simplefadedisplay' } [21:41:54.640] StreamManager :: add(), id:caption, type:canvas [21:41:54.640] RenCaption[caption] :: constructor() [21:41:54.640] Ren[caption] :: constructor() [21:41:54.640] Overlay[caption] :: constructor() [21:41:54.640] CanvasClip[caption] :: constructor() [21:41:54.640] Clip[caption] :: constructor() [21:41:54.641] clip:"caption" added to stream:"canvas_836080774230" [21:41:54.641] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_836080774230', clipId: 'caption' } [21:41:54.641] all added... [21:41:54.641] Vidbot :: _next(), _stepIndex:1 of 4 [21:41:54.641] index :: _onStepCompleted_vidbot(), step: 1 [21:41:54.641] index :: _onStepStarted_vidbot(), step: 2 [21:41:54.642] Vidbot :: step[1], label:Initializing Input Streams [21:41:54.642] StreamManager :: init() [21:41:54.642] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [21:41:54.643] index :: _onStepProgress_vidbot(), percent: 33 [21:41:54.643] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [21:41:54.643] index :: _onStepProgress_vidbot(), percent: 67 [21:41:54.643] CanvasStream[canvas_836080774230] :: _init(), BEGIN [21:41:54.644] i:0, c.id:simplefadedisplay [21:41:54.644] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [21:41:54.644] KenBurnsSlideshow[simplefadedisplay] :: _validate() [21:41:54.645] KenBurnsSlideshow[undefined] :: _validateAnim() [21:41:54.645] KenBurnsSlideshow[undefined] :: _validateTheme() [21:41:54.646] i:1, c.id:caption [21:41:54.647] RenCaption[caption] :: _init() [21:41:54.647] RenCaption[caption] :: _validate() [21:41:54.648] KenBurnsSlideshow[simplefadedisplay] :: _build() [21:41:54.654] AnimatedImageFrame[aif] :: constructor() [21:41:54.656] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.656] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_1.jpg [21:41:54.669] RenCaption[caption] :: _build() [21:41:54.688] Overlay[caption] :: _animate() [21:41:54.691] CanvasStream[caption] :: _init(), p.then() [21:41:54.707] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.710] AnimatedImageFrame[aif] :: _init(), END [21:41:54.712] AnimatedImageFrame[aif] :: constructor() [21:41:54.712] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.712] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_2.jpg [21:41:54.725] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.726] AnimatedImageFrame[aif] :: _init(), END [21:41:54.727] AnimatedImageFrame[aif] :: constructor() [21:41:54.727] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.727] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_3.jpg [21:41:54.739] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.740] AnimatedImageFrame[aif] :: _init(), END [21:41:54.741] AnimatedImageFrame[aif] :: constructor() [21:41:54.741] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.741] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_4.jpg [21:41:54.754] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.755] AnimatedImageFrame[aif] :: _init(), END [21:41:54.756] AnimatedImageFrame[aif] :: constructor() [21:41:54.756] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.756] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_1.jpg [21:41:54.768] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.769] AnimatedImageFrame[aif] :: _init(), END [21:41:54.770] AnimatedImageFrame[aif] :: constructor() [21:41:54.770] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.770] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_2.jpg [21:41:54.782] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.783] AnimatedImageFrame[aif] :: _init(), END [21:41:54.783] AnimatedImageFrame[aif] :: constructor() [21:41:54.783] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.783] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_3.jpg [21:41:54.795] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.796] AnimatedImageFrame[aif] :: _init(), END [21:41:54.797] AnimatedImageFrame[aif] :: constructor() [21:41:54.797] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.797] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_4.jpg [21:41:54.809] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.810] AnimatedImageFrame[aif] :: _init(), END [21:41:54.810] AnimatedImageFrame[aif] :: constructor() [21:41:54.810] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.810] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_1.jpg [21:41:54.822] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.823] AnimatedImageFrame[aif] :: _init(), END [21:41:54.824] AnimatedImageFrame[aif] :: constructor() [21:41:54.824] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.824] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_2.jpg [21:41:54.836] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.837] AnimatedImageFrame[aif] :: _init(), END [21:41:54.837] AnimatedImageFrame[aif] :: constructor() [21:41:54.837] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.837] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_3.jpg [21:41:54.849] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.850] AnimatedImageFrame[aif] :: _init(), END [21:41:54.850] AnimatedImageFrame[aif] :: constructor() [21:41:54.850] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.850] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_4.jpg [21:41:54.862] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.863] AnimatedImageFrame[aif] :: _init(), END [21:41:54.864] AnimatedImageFrame[aif] :: constructor() [21:41:54.864] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.864] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_1.jpg [21:41:54.876] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.877] AnimatedImageFrame[aif] :: _init(), END [21:41:54.878] AnimatedImageFrame[aif] :: constructor() [21:41:54.878] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.878] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_2.jpg [21:41:54.890] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.891] AnimatedImageFrame[aif] :: _init(), END [21:41:54.891] AnimatedImageFrame[aif] :: constructor() [21:41:54.891] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.891] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_3.jpg [21:41:54.903] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.904] AnimatedImageFrame[aif] :: _init(), END [21:41:54.904] AnimatedImageFrame[aif] :: constructor() [21:41:54.905] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.905] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_4.jpg [21:41:54.919] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.920] AnimatedImageFrame[aif] :: _init(), END [21:41:54.921] AnimatedImageFrame[aif] :: constructor() [21:41:54.921] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.921] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_1.jpg [21:41:54.932] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.933] AnimatedImageFrame[aif] :: _init(), END [21:41:54.934] AnimatedImageFrame[aif] :: constructor() [21:41:54.934] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.934] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_2.jpg [21:41:54.945] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.946] AnimatedImageFrame[aif] :: _init(), END [21:41:54.946] AnimatedImageFrame[aif] :: constructor() [21:41:54.947] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.947] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_3.jpg [21:41:54.962] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.963] AnimatedImageFrame[aif] :: _init(), END [21:41:54.964] AnimatedImageFrame[aif] :: constructor() [21:41:54.964] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.964] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_4.jpg [21:41:54.976] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.978] AnimatedImageFrame[aif] :: _init(), END [21:41:54.978] AnimatedImageFrame[aif] :: constructor() [21:41:54.978] AnimatedImageFrame[aif] :: _init(), BEGIN [21:41:54.979] CanvasClip :: LoadImageWithPromise(), src: 0C9F888F-9A11-3F9E-93B1-BE1235E06D78_1.jpg [21:41:54.990] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [21:41:54.990] AnimatedImageFrame[aif] :: _init(), END [21:41:54.991] Overlay[simplefadedisplay] :: _animate() [21:41:54.992] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [21:41:54.992] CanvasStream[simplefadedisplay] :: _init(), p.then() [21:41:54.992] CanvasStream[canvas_836080774230] :: _init(), promise.all.then() [21:41:54.994] CanvasStream[canvas_836080774230] :: _init(), END [21:41:54.994] StreamMangaer :: init(), stream[canvas_836080774230].then() [21:41:54.994] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_836080774230', progress: 1 } [21:41:54.994] index :: _onStepProgress_vidbot(), percent: 100 [21:41:54.995] StreamManager :: init(), promise.all.then... [21:41:54.995] Vidbot :: StreamMgr.on( 'INITED' ) [21:41:54.995] Vidbot :: _next(), _stepIndex:2 of 4 [21:41:54.995] index :: _onStepCompleted_vidbot(), step: 2 [21:41:54.995] index :: _onStepStarted_vidbot(), step: 3 [21:41:54.995] Vidbot :: step[2], label:Rendering Canvas Streams [21:41:54.996] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [21:41:54.996] StreamManager :: render() [21:41:54.997] CanvasStream[canvas_836080774230] :: render() [21:41:55.033] index :: _onStepProgress_vidbot(), percent: 0 [21:42:04.840] index :: _onStepProgress_vidbot(), percent: 5 [21:42:15.842] index :: _onStepProgress_vidbot(), percent: 10 [21:42:27.546] index :: _onStepProgress_vidbot(), percent: 15 [21:42:39.159] index :: _onStepProgress_vidbot(), percent: 20 [21:42:50.979] index :: _onStepProgress_vidbot(), percent: 25 [21:43:02.427] index :: _onStepProgress_vidbot(), percent: 30 [21:43:13.792] index :: _onStepProgress_vidbot(), percent: 35 [21:43:25.795] index :: _onStepProgress_vidbot(), percent: 40 [21:43:36.691] index :: _onStepProgress_vidbot(), percent: 45 [21:43:47.577] index :: _onStepProgress_vidbot(), percent: 50 [21:43:57.229] index :: _onStepProgress_vidbot(), percent: 55 [21:44:07.515] index :: _onStepProgress_vidbot(), percent: 60 [21:44:18.423] index :: _onStepProgress_vidbot(), percent: 65 [21:44:28.677] index :: _onStepProgress_vidbot(), percent: 70 [21:44:38.983] index :: _onStepProgress_vidbot(), percent: 75 [21:44:48.526] index :: _onStepProgress_vidbot(), percent: 80 [21:44:58.718] index :: _onStepProgress_vidbot(), percent: 85 [21:45:08.745] index :: _onStepProgress_vidbot(), percent: 90 [21:45:18.686] index :: _onStepProgress_vidbot(), percent: 95 [21:45:28.829] index :: _onStepProgress_vidbot(), percent: 100 [21:45:29.679] StreamManager :: render(), Promise.all.then... [21:45:29.680] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [21:45:29.680] Vidbot :: _next(), _stepIndex:3 of 4 [21:45:29.680] index :: _onStepCompleted_vidbot(), step: 3 [21:45:29.681] index :: _onStepStarted_vidbot(), step: 4 [21:45:29.682] Vidbot :: step[3], label:Encoding Media [21:45:29.688] CanvasFilters :: Overlay() [21:45:29.689] AudioStream[audio_vo] :: inputOptions() [21:45:29.689] AudioFilters :: Volume() [21:45:29.689] filter: [2:a]volume=1[2_vol] [21:45:29.689] AudioFilters :: Delay() [21:45:29.689] filter: [2_vol]adelay=0|0[2_del] [21:45:29.689] AudioStream[bg_music] :: inputOptions() [21:45:29.689] AudioFilters :: Volume() [21:45:29.689] filter: [3:a]volume=0.25[3_vol] [21:45:29.690] AudioFilters :: FadeOut() [21:45:29.690] filter: [3_vol]afade=t=out:st=61.82:d=1[3_fadeout] [21:45:29.690] AudioFilters :: Delay() [21:45:29.690] filter: [3_fadeout]adelay=0|0[3_del] [21:45:29.690] AudioFilters :: Mix() [21:45:29.690] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [21:45:29.690] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [21:45:29.692] hang.time: 60 [21:45:29.790] Vidbot :: ffmpeg.on( 'start' ) [21:45:29.790] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=61.82 -r 30 -i ./tmp/canvas_836080774230_%05d.png -to 00:01:01.820 -i file:///var/www/html/c [21:45:29.790] lients/5717/audio/0C9F888F-9A11-3F9E-93B1-BE1235E06D78.mp3 -to 00:01:01.820 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/bgmusic. [21:45:29.790] 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=61 [21:45:29.790] .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 [a_o [21:45:29.790] ut] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/5717/video/0C9F888F-9A11-3F9E-93B1 [21:45:29.790] -BE1235E06D78.mp4 [21:45:29.915] index :: _onStepProgress_vidbot(), percent: -3360156029 [21:45:30.355] index :: _onStepProgress_vidbot(), percent: 2 [21:45:30.856] index :: _onStepProgress_vidbot(), percent: 6 [21:45:31.356] index :: _onStepProgress_vidbot(), percent: 11 [21:45:31.861] index :: _onStepProgress_vidbot(), percent: 16 [21:45:32.363] index :: _onStepProgress_vidbot(), percent: 21 [21:45:32.865] index :: _onStepProgress_vidbot(), percent: 26 [21:45:33.365] index :: _onStepProgress_vidbot(), percent: 31 [21:45:33.865] index :: _onStepProgress_vidbot(), percent: 36 [21:45:34.370] index :: _onStepProgress_vidbot(), percent: 42 [21:45:34.870] index :: _onStepProgress_vidbot(), percent: 47 [21:45:35.370] index :: _onStepProgress_vidbot(), percent: 53 [21:45:35.880] index :: _onStepProgress_vidbot(), percent: 59 [21:45:36.380] index :: _onStepProgress_vidbot(), percent: 65 [21:45:36.881] index :: _onStepProgress_vidbot(), percent: 70 [21:45:37.382] index :: _onStepProgress_vidbot(), percent: 75 [21:45:37.883] index :: _onStepProgress_vidbot(), percent: 81 [21:45:38.385] index :: _onStepProgress_vidbot(), percent: 87 [21:45:38.886] index :: _onStepProgress_vidbot(), percent: 93 [21:45:39.388] index :: _onStepProgress_vidbot(), percent: 99 [21:45:39.443] index :: _onStepProgress_vidbot(), percent: 100 [21:45:39.469] Vidbot :: ffmpeg.on( 'end' ), Done! [21:45:39.469] StreamManager :: dispose() [21:45:39.470] CanvasStream[canvas_836080774230] :: dispose() [21:45:39.474] Vidbot :: fflog.on( 'finish' ) [21:45:39.475] fflog.path: /var/www/html/clients/5717/video/0C9F888F-9A11-3F9E-93B1-BE1235E06D78.mp4.fflog [21:45:39.475] Vidbot :: _next(), _stepIndex:4 of 4 [21:45:39.475] index :: _onStepCompleted_vidbot(), step: 4 [21:45:39.475] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 224.976, output: '/var/www/html/clients/5717/video/0C9F888F-9A11-3F9E-93B1-BE1235E06D78.mp4', duration: 61.82 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/5717/video/0C9F888F-9A11-3F9E-93B1-BE1235E06D78.mp4 Media Duration : 00:01:01.820 Generation Time : 00:03:44.975 ---------------------------------------------------------------------------------------------------------------