--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [15:47:03.918] Vidbot :: start() [15:47:03.918] Vidbot :: _next(), _stepIndex:0 of 4 [15:47:03.919] index :: _onStepStarted_vidbot(), step: 1 [15:47:03.920] Vidbot :: step[0], label:Initializing Core [15:47:03.934] index :: _onStepProgress_vidbot(), percent: 20 [15:47:03.934] Vidbot :: _parse() [15:47:03.936] index :: _onStepProgress_vidbot(), percent: 40 [15:47:03.936] Vidbot :: _validate() [15:47:03.937] index :: _onStepProgress_vidbot(), percent: 60 [15:47:03.937] Vidbot :: _fonts() [15:47:03.937] FabricFontManager :: add(), id: SourceSansPro-Bold [15:47:03.937] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [15:47:03.947] FabricFontManager :: add(), id: SourceSansPro-Light [15:47:03.947] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [15:47:03.948] FabricFontManager :: add(), id: DINOT-Bold [15:47:03.948] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [15:47:03.949] FabricFontManager :: add(), id: DINOT-Light [15:47:03.949] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [15:47:03.950] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [15:47:03.950] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [15:47:03.951] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [15:47:03.951] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [15:47:03.952] index :: _onStepProgress_vidbot(), percent: 80 [15:47:03.952] Vidbot :: _clips() [15:47:03.953] StreamManager :: add(), id:audio_vo, type:audio [15:47:03.953] AudioClip[audio_vo] :: constructor() [15:47:03.953] InputStream[audio_vo] :: constructor() [15:47:03.954] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [15:47:03.957] StreamManager :: add(), id:bg_music, type:audio [15:47:03.957] AudioClip[bg_music] :: constructor() [15:47:03.957] InputStream[bg_music] :: constructor() [15:47:03.958] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [15:47:03.958] StreamManager :: add(), id:simplefadedisplay, type:canvas [15:47:03.958] CanvasStream[canvas_1096139183621] :: constructor() [15:47:03.958] InputStream[canvas_1096139183621] :: constructor() [15:47:04.057] KenBurnsSlideshow[simplefadedisplay] :: constructor() [15:47:04.058] Overlay[simplefadedisplay] :: constructor() [15:47:04.058] CanvasClip[simplefadedisplay] :: constructor() [15:47:04.058] Clip[simplefadedisplay] :: constructor() [15:47:04.058] clip:"simplefadedisplay" added to stream:"canvas_1096139183621" [15:47:04.058] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1096139183621', clipId: 'simplefadedisplay' } [15:47:04.059] StreamManager :: add(), id:caption, type:canvas [15:47:04.059] RenCaption[caption] :: constructor() [15:47:04.059] Ren[caption] :: constructor() [15:47:04.059] Overlay[caption] :: constructor() [15:47:04.059] CanvasClip[caption] :: constructor() [15:47:04.059] Clip[caption] :: constructor() [15:47:04.059] clip:"caption" added to stream:"canvas_1096139183621" [15:47:04.059] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1096139183621', clipId: 'caption' } [15:47:04.059] all added... [15:47:04.060] Vidbot :: _next(), _stepIndex:1 of 4 [15:47:04.060] index :: _onStepCompleted_vidbot(), step: 1 [15:47:04.060] index :: _onStepStarted_vidbot(), step: 2 [15:47:04.060] Vidbot :: step[1], label:Initializing Input Streams [15:47:04.061] StreamManager :: init() [15:47:04.061] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [15:47:04.061] index :: _onStepProgress_vidbot(), percent: 33 [15:47:04.061] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [15:47:04.062] index :: _onStepProgress_vidbot(), percent: 67 [15:47:04.063] CanvasStream[canvas_1096139183621] :: _init(), BEGIN [15:47:04.063] i:0, c.id:simplefadedisplay [15:47:04.065] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [15:47:04.066] KenBurnsSlideshow[simplefadedisplay] :: _validate() [15:47:04.066] KenBurnsSlideshow[undefined] :: _validateAnim() [15:47:04.066] KenBurnsSlideshow[undefined] :: _validateTheme() [15:47:04.068] i:1, c.id:caption [15:47:04.068] RenCaption[caption] :: _init() [15:47:04.069] RenCaption[caption] :: _validate() [15:47:04.071] KenBurnsSlideshow[simplefadedisplay] :: _build() [15:47:04.078] AnimatedImageFrame[aif] :: constructor() [15:47:04.079] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.079] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_1.jpg [15:47:04.092] RenCaption[caption] :: _build() [15:47:04.110] Overlay[caption] :: _animate() [15:47:04.113] CanvasStream[caption] :: _init(), p.then() [15:47:04.129] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.133] AnimatedImageFrame[aif] :: _init(), END [15:47:04.135] AnimatedImageFrame[aif] :: constructor() [15:47:04.135] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.135] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_2.jpg [15:47:04.149] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.150] AnimatedImageFrame[aif] :: _init(), END [15:47:04.151] AnimatedImageFrame[aif] :: constructor() [15:47:04.151] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.151] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_3.jpg [15:47:04.163] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.164] AnimatedImageFrame[aif] :: _init(), END [15:47:04.165] AnimatedImageFrame[aif] :: constructor() [15:47:04.165] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.165] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_4.jpg [15:47:04.176] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.178] AnimatedImageFrame[aif] :: _init(), END [15:47:04.178] AnimatedImageFrame[aif] :: constructor() [15:47:04.179] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.179] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_5.jpg [15:47:04.190] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.191] AnimatedImageFrame[aif] :: _init(), END [15:47:04.192] AnimatedImageFrame[aif] :: constructor() [15:47:04.192] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.192] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_6.jpg [15:47:04.204] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.205] AnimatedImageFrame[aif] :: _init(), END [15:47:04.206] AnimatedImageFrame[aif] :: constructor() [15:47:04.206] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.206] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_7.jpg [15:47:04.219] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.220] AnimatedImageFrame[aif] :: _init(), END [15:47:04.220] AnimatedImageFrame[aif] :: constructor() [15:47:04.221] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.221] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_8.jpg [15:47:04.233] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.234] AnimatedImageFrame[aif] :: _init(), END [15:47:04.235] AnimatedImageFrame[aif] :: constructor() [15:47:04.235] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.235] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_9.jpg [15:47:04.247] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.248] AnimatedImageFrame[aif] :: _init(), END [15:47:04.248] AnimatedImageFrame[aif] :: constructor() [15:47:04.248] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.248] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_10.jpg [15:47:04.261] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.262] AnimatedImageFrame[aif] :: _init(), END [15:47:04.263] AnimatedImageFrame[aif] :: constructor() [15:47:04.263] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.263] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_11.jpg [15:47:04.282] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.283] AnimatedImageFrame[aif] :: _init(), END [15:47:04.284] AnimatedImageFrame[aif] :: constructor() [15:47:04.284] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.284] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_12.jpg [15:47:04.296] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.297] AnimatedImageFrame[aif] :: _init(), END [15:47:04.298] AnimatedImageFrame[aif] :: constructor() [15:47:04.298] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.298] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_13.jpg [15:47:04.317] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.318] AnimatedImageFrame[aif] :: _init(), END [15:47:04.319] AnimatedImageFrame[aif] :: constructor() [15:47:04.319] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.319] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_14.jpg [15:47:04.344] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.345] AnimatedImageFrame[aif] :: _init(), END [15:47:04.346] AnimatedImageFrame[aif] :: constructor() [15:47:04.346] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.346] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_1.jpg [15:47:04.370] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.371] AnimatedImageFrame[aif] :: _init(), END [15:47:04.371] AnimatedImageFrame[aif] :: constructor() [15:47:04.371] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.372] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_2.jpg [15:47:04.384] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.385] AnimatedImageFrame[aif] :: _init(), END [15:47:04.386] AnimatedImageFrame[aif] :: constructor() [15:47:04.386] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.386] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_3.jpg [15:47:04.397] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.398] AnimatedImageFrame[aif] :: _init(), END [15:47:04.399] AnimatedImageFrame[aif] :: constructor() [15:47:04.399] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.399] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_4.jpg [15:47:04.410] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.410] AnimatedImageFrame[aif] :: _init(), END [15:47:04.411] AnimatedImageFrame[aif] :: constructor() [15:47:04.411] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.411] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_5.jpg [15:47:04.425] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.426] AnimatedImageFrame[aif] :: _init(), END [15:47:04.427] AnimatedImageFrame[aif] :: constructor() [15:47:04.427] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.427] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_6.jpg [15:47:04.439] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.440] AnimatedImageFrame[aif] :: _init(), END [15:47:04.440] AnimatedImageFrame[aif] :: constructor() [15:47:04.440] AnimatedImageFrame[aif] :: _init(), BEGIN [15:47:04.440] CanvasClip :: LoadImageWithPromise(), src: 34252B1D-0C1C-9E61-A11C-71EB0784E730_7.jpg [15:47:04.457] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [15:47:04.458] AnimatedImageFrame[aif] :: _init(), END [15:47:04.458] Overlay[simplefadedisplay] :: _animate() [15:47:04.459] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [15:47:04.459] CanvasStream[simplefadedisplay] :: _init(), p.then() [15:47:04.459] CanvasStream[canvas_1096139183621] :: _init(), promise.all.then() [15:47:04.461] CanvasStream[canvas_1096139183621] :: _init(), END [15:47:04.461] StreamMangaer :: init(), stream[canvas_1096139183621].then() [15:47:04.462] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1096139183621', progress: 1 } [15:47:04.462] index :: _onStepProgress_vidbot(), percent: 100 [15:47:04.462] StreamManager :: init(), promise.all.then... [15:47:04.462] Vidbot :: StreamMgr.on( 'INITED' ) [15:47:04.462] Vidbot :: _next(), _stepIndex:2 of 4 [15:47:04.462] index :: _onStepCompleted_vidbot(), step: 2 [15:47:04.462] index :: _onStepStarted_vidbot(), step: 3 [15:47:04.463] Vidbot :: step[2], label:Rendering Canvas Streams [15:47:04.463] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [15:47:04.463] StreamManager :: render() [15:47:04.464] CanvasStream[canvas_1096139183621] :: render() [15:47:04.501] index :: _onStepProgress_vidbot(), percent: 0 [15:47:14.261] index :: _onStepProgress_vidbot(), percent: 5 [15:47:28.506] index :: _onStepProgress_vidbot(), percent: 10 [15:47:36.432] index :: _onStepProgress_vidbot(), percent: 15 [15:47:44.005] index :: _onStepProgress_vidbot(), percent: 20 [15:47:51.527] index :: _onStepProgress_vidbot(), percent: 25 [15:48:02.321] index :: _onStepProgress_vidbot(), percent: 30 [15:48:11.345] index :: _onStepProgress_vidbot(), percent: 35 [15:48:20.438] index :: _onStepProgress_vidbot(), percent: 40 [15:48:32.781] index :: _onStepProgress_vidbot(), percent: 45 [15:48:43.234] index :: _onStepProgress_vidbot(), percent: 50 [15:48:56.665] index :: _onStepProgress_vidbot(), percent: 55 [15:49:07.518] index :: _onStepProgress_vidbot(), percent: 60 [15:49:16.048] index :: _onStepProgress_vidbot(), percent: 65 [15:49:26.385] index :: _onStepProgress_vidbot(), percent: 70 [15:49:40.684] index :: _onStepProgress_vidbot(), percent: 75 [15:49:50.068] index :: _onStepProgress_vidbot(), percent: 80 [15:49:58.130] index :: _onStepProgress_vidbot(), percent: 85 [15:50:07.775] index :: _onStepProgress_vidbot(), percent: 90 [15:50:16.529] index :: _onStepProgress_vidbot(), percent: 95 [15:50:26.933] index :: _onStepProgress_vidbot(), percent: 100 [15:50:27.958] StreamManager :: render(), Promise.all.then... [15:50:27.958] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [15:50:27.959] Vidbot :: _next(), _stepIndex:3 of 4 [15:50:27.959] index :: _onStepCompleted_vidbot(), step: 3 [15:50:27.960] index :: _onStepStarted_vidbot(), step: 4 [15:50:27.961] Vidbot :: step[3], label:Encoding Media [15:50:27.963] CanvasFilters :: Overlay() [15:50:27.963] AudioStream[audio_vo] :: inputOptions() [15:50:27.964] AudioFilters :: Volume() [15:50:27.964] filter: [2:a]volume=1[2_vol] [15:50:27.964] AudioFilters :: Delay() [15:50:27.964] filter: [2_vol]adelay=0|0[2_del] [15:50:27.964] AudioStream[bg_music] :: inputOptions() [15:50:27.964] AudioFilters :: Volume() [15:50:27.964] filter: [3:a]volume=0.25[3_vol] [15:50:27.964] AudioFilters :: FadeOut() [15:50:27.964] filter: [3_vol]afade=t=out:st=60.87:d=1[3_fadeout] [15:50:27.965] AudioFilters :: Delay() [15:50:27.965] filter: [3_fadeout]adelay=0|0[3_del] [15:50:27.965] AudioFilters :: Mix() [15:50:27.965] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:50:27.965] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [15:50:27.967] hang.time: 60 [15:50:28.078] Vidbot :: ffmpeg.on( 'start' ) [15:50:28.078] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60.87 -r 30 -i ./tmp/canvas_1096139183621_%05d.png -to 00:01:00.869 -i file:///var/www/html/ [15:50:28.078] clients/6935/audio/34252B1D-0C1C-9E61-A11C-71EB0784E730.mp3 -to 00:01:00.869 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF4_Cou [15:50:28.078] ntry_Jazz.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 [15:50:28.078] =out:st=60.87: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 [15:50:28.078] -map [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/6935/video/34252B1D-0C1C [15:50:28.078] -9E61-A11C-71EB0784E730.mp4 [15:50:28.266] index :: _onStepProgress_vidbot(), percent: -3412598090 [15:50:28.664] index :: _onStepProgress_vidbot(), percent: 1 [15:50:29.685] index :: _onStepProgress_vidbot(), percent: 6 [15:50:30.702] index :: _onStepProgress_vidbot(), percent: 12 [15:50:31.711] index :: _onStepProgress_vidbot(), percent: 16 [15:50:32.211] index :: _onStepProgress_vidbot(), percent: 20 [15:50:33.215] index :: _onStepProgress_vidbot(), percent: 25 [15:50:34.217] index :: _onStepProgress_vidbot(), percent: 31 [15:50:35.223] index :: _onStepProgress_vidbot(), percent: 37 [15:50:35.723] index :: _onStepProgress_vidbot(), percent: 40 [15:50:36.736] index :: _onStepProgress_vidbot(), percent: 46 [15:50:37.737] index :: _onStepProgress_vidbot(), percent: 51 [15:50:38.741] index :: _onStepProgress_vidbot(), percent: 57 [15:50:39.241] index :: _onStepProgress_vidbot(), percent: 61 [15:50:39.743] index :: _onStepProgress_vidbot(), percent: 65 [15:50:40.813] index :: _onStepProgress_vidbot(), percent: 73 [15:50:41.323] index :: _onStepProgress_vidbot(), percent: 77 [15:50:41.825] index :: _onStepProgress_vidbot(), percent: 80 [15:50:42.827] index :: _onStepProgress_vidbot(), percent: 87 [15:50:43.335] index :: _onStepProgress_vidbot(), percent: 90 [15:50:44.339] index :: _onStepProgress_vidbot(), percent: 99 [15:50:44.444] index :: _onStepProgress_vidbot(), percent: 100 [15:50:44.469] Vidbot :: ffmpeg.on( 'end' ), Done! [15:50:44.469] StreamManager :: dispose() [15:50:44.469] CanvasStream[canvas_1096139183621] :: dispose() [15:50:44.475] Vidbot :: fflog.on( 'finish' ) [15:50:44.475] fflog.path: /var/www/html/clients/6935/video/34252B1D-0C1C-9E61-A11C-71EB0784E730.mp4.fflog [15:50:44.475] Vidbot :: _next(), _stepIndex:4 of 4 [15:50:44.475] index :: _onStepCompleted_vidbot(), step: 4 [15:50:44.475] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 220.579, output: '/var/www/html/clients/6935/video/34252B1D-0C1C-9E61-A11C-71EB0784E730.mp4', duration: 60.87 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/6935/video/34252B1D-0C1C-9E61-A11C-71EB0784E730.mp4 Media Duration : 00:01:00.869 Generation Time : 00:03:40.579 ---------------------------------------------------------------------------------------------------------------