--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [10:46:47.831] Vidbot :: start() [10:46:47.831] Vidbot :: _next(), _stepIndex:0 of 4 [10:46:47.832] index :: _onStepStarted_vidbot(), step: 1 [10:46:47.833] Vidbot :: step[0], label:Initializing Core [10:46:47.847] index :: _onStepProgress_vidbot(), percent: 20 [10:46:47.848] Vidbot :: _parse() [10:46:47.849] index :: _onStepProgress_vidbot(), percent: 40 [10:46:47.849] Vidbot :: _validate() [10:46:47.850] index :: _onStepProgress_vidbot(), percent: 60 [10:46:47.850] Vidbot :: _fonts() [10:46:47.851] FabricFontManager :: add(), id: SourceSansPro-Bold [10:46:47.851] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [10:46:47.859] FabricFontManager :: add(), id: SourceSansPro-Light [10:46:47.859] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [10:46:47.860] FabricFontManager :: add(), id: DINOT-Bold [10:46:47.860] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [10:46:47.861] FabricFontManager :: add(), id: DINOT-Light [10:46:47.861] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [10:46:47.862] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [10:46:47.862] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [10:46:47.863] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [10:46:47.863] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [10:46:47.864] index :: _onStepProgress_vidbot(), percent: 80 [10:46:47.864] Vidbot :: _clips() [10:46:47.865] StreamManager :: add(), id:audio_vo, type:audio [10:46:47.865] AudioClip[audio_vo] :: constructor() [10:46:47.865] InputStream[audio_vo] :: constructor() [10:46:47.865] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [10:46:47.868] StreamManager :: add(), id:bg_music, type:audio [10:46:47.868] AudioClip[bg_music] :: constructor() [10:46:47.868] InputStream[bg_music] :: constructor() [10:46:47.869] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [10:46:47.869] StreamManager :: add(), id:simplefadedisplay, type:canvas [10:46:47.869] CanvasStream[canvas_998566004527] :: constructor() [10:46:47.869] InputStream[canvas_998566004527] :: constructor() [10:46:47.948] KenBurnsSlideshow[simplefadedisplay] :: constructor() [10:46:47.949] Overlay[simplefadedisplay] :: constructor() [10:46:47.949] CanvasClip[simplefadedisplay] :: constructor() [10:46:47.949] Clip[simplefadedisplay] :: constructor() [10:46:47.949] clip:"simplefadedisplay" added to stream:"canvas_998566004527" [10:46:47.949] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_998566004527', clipId: 'simplefadedisplay' } [10:46:47.949] StreamManager :: add(), id:caption, type:canvas [10:46:47.950] RenCaption[caption] :: constructor() [10:46:47.950] Ren[caption] :: constructor() [10:46:47.950] Overlay[caption] :: constructor() [10:46:47.950] CanvasClip[caption] :: constructor() [10:46:47.950] Clip[caption] :: constructor() [10:46:47.950] clip:"caption" added to stream:"canvas_998566004527" [10:46:47.950] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_998566004527', clipId: 'caption' } [10:46:47.950] StreamManager :: add(), id:options, type:canvas [10:46:47.950] RenOptions[options] :: constructor() [10:46:47.950] Ren[options] :: constructor() [10:46:47.950] Overlay[options] :: constructor() [10:46:47.951] CanvasClip[options] :: constructor() [10:46:47.951] Clip[options] :: constructor() [10:46:47.951] clip:"options" added to stream:"canvas_998566004527" [10:46:47.951] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_998566004527', clipId: 'options' } [10:46:47.951] all added... [10:46:47.951] Vidbot :: _next(), _stepIndex:1 of 4 [10:46:47.951] index :: _onStepCompleted_vidbot(), step: 1 [10:46:47.952] index :: _onStepStarted_vidbot(), step: 2 [10:46:47.952] Vidbot :: step[1], label:Initializing Input Streams [10:46:47.952] StreamManager :: init() [10:46:47.952] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [10:46:47.953] index :: _onStepProgress_vidbot(), percent: 33 [10:46:47.953] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [10:46:47.953] index :: _onStepProgress_vidbot(), percent: 67 [10:46:47.953] CanvasStream[canvas_998566004527] :: _init(), BEGIN [10:46:47.953] i:0, c.id:simplefadedisplay [10:46:47.954] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [10:46:47.954] KenBurnsSlideshow[simplefadedisplay] :: _validate() [10:46:47.954] KenBurnsSlideshow[undefined] :: _validateAnim() [10:46:47.955] KenBurnsSlideshow[undefined] :: _validateTheme() [10:46:47.956] i:1, c.id:caption [10:46:47.956] RenCaption[caption] :: _init() [10:46:47.957] RenCaption[caption] :: _validate() [10:46:47.958] i:2, c.id:options [10:46:47.958] RenPrice[options] :: _init() [10:46:47.958] RenOptions[options] :: _validate() [10:46:47.959] KenBurnsSlideshow[simplefadedisplay] :: _build() [10:46:47.965] AnimatedImageFrame[aif] :: constructor() [10:46:47.966] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:47.966] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_1.jpg [10:46:47.979] RenCaption[caption] :: _build() [10:46:47.996] RenOptions[options] :: _assets() [10:46:47.997] CanvasClip :: LoadSVGFromStringWithPromise() [10:46:48.029] CanvasClip :: LoadSVGFromString(), loaded [10:46:48.032] Overlay[caption] :: _animate() [10:46:48.035] RenOptions[options] :: _build() [10:46:48.178] CanvasStream[caption] :: _init(), p.then() [10:46:48.178] RenOptions[options] :: _animate() [10:46:48.178] Overlay[options] :: _animate() [10:46:48.180] CanvasStream[options] :: _init(), p.then() [10:46:48.262] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.266] AnimatedImageFrame[aif] :: _init(), END [10:46:48.267] AnimatedImageFrame[aif] :: constructor() [10:46:48.267] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.267] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_2.jpg [10:46:48.321] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.323] AnimatedImageFrame[aif] :: _init(), END [10:46:48.323] AnimatedImageFrame[aif] :: constructor() [10:46:48.323] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.324] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_3.jpg [10:46:48.396] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.397] AnimatedImageFrame[aif] :: _init(), END [10:46:48.398] AnimatedImageFrame[aif] :: constructor() [10:46:48.398] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.398] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_4.jpg [10:46:48.450] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.451] AnimatedImageFrame[aif] :: _init(), END [10:46:48.452] AnimatedImageFrame[aif] :: constructor() [10:46:48.452] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.452] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_5.jpg [10:46:48.500] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.501] AnimatedImageFrame[aif] :: _init(), END [10:46:48.502] AnimatedImageFrame[aif] :: constructor() [10:46:48.502] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.502] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_6.jpg [10:46:48.539] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.540] AnimatedImageFrame[aif] :: _init(), END [10:46:48.541] AnimatedImageFrame[aif] :: constructor() [10:46:48.541] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.541] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_7.jpg [10:46:48.578] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.579] AnimatedImageFrame[aif] :: _init(), END [10:46:48.580] AnimatedImageFrame[aif] :: constructor() [10:46:48.580] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.580] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_8.jpg [10:46:48.631] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.632] AnimatedImageFrame[aif] :: _init(), END [10:46:48.633] AnimatedImageFrame[aif] :: constructor() [10:46:48.633] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.633] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_9.jpg [10:46:48.708] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.710] AnimatedImageFrame[aif] :: _init(), END [10:46:48.710] AnimatedImageFrame[aif] :: constructor() [10:46:48.710] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.710] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_10.jpg [10:46:48.774] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.775] AnimatedImageFrame[aif] :: _init(), END [10:46:48.775] AnimatedImageFrame[aif] :: constructor() [10:46:48.775] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.775] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_11.jpg [10:46:48.809] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.810] AnimatedImageFrame[aif] :: _init(), END [10:46:48.810] AnimatedImageFrame[aif] :: constructor() [10:46:48.811] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.811] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_12.jpg [10:46:48.844] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.845] AnimatedImageFrame[aif] :: _init(), END [10:46:48.845] AnimatedImageFrame[aif] :: constructor() [10:46:48.845] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.846] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_13.jpg [10:46:48.882] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.883] AnimatedImageFrame[aif] :: _init(), END [10:46:48.884] AnimatedImageFrame[aif] :: constructor() [10:46:48.884] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.884] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_14.jpg [10:46:48.920] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.921] AnimatedImageFrame[aif] :: _init(), END [10:46:48.922] AnimatedImageFrame[aif] :: constructor() [10:46:48.932] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.933] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_15.jpg [10:46:48.970] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:48.971] AnimatedImageFrame[aif] :: _init(), END [10:46:48.972] AnimatedImageFrame[aif] :: constructor() [10:46:48.972] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:48.972] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_16.jpg [10:46:49.052] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:49.053] AnimatedImageFrame[aif] :: _init(), END [10:46:49.054] AnimatedImageFrame[aif] :: constructor() [10:46:49.054] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:49.054] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_1.jpg [10:46:49.100] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:49.101] AnimatedImageFrame[aif] :: _init(), END [10:46:49.102] AnimatedImageFrame[aif] :: constructor() [10:46:49.102] AnimatedImageFrame[aif] :: _init(), BEGIN [10:46:49.102] CanvasClip :: LoadImageWithPromise(), src: 0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF_2.jpg [10:46:49.150] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:46:49.151] AnimatedImageFrame[aif] :: _init(), END [10:46:49.152] Overlay[simplefadedisplay] :: _animate() [10:46:49.153] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [10:46:49.153] CanvasStream[simplefadedisplay] :: _init(), p.then() [10:46:49.153] CanvasStream[canvas_998566004527] :: _init(), promise.all.then() [10:46:49.156] CanvasStream[canvas_998566004527] :: _init(), END [10:46:49.156] StreamMangaer :: init(), stream[canvas_998566004527].then() [10:46:49.156] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_998566004527', progress: 1 } [10:46:49.156] index :: _onStepProgress_vidbot(), percent: 100 [10:46:49.156] StreamManager :: init(), promise.all.then... [10:46:49.156] Vidbot :: StreamMgr.on( 'INITED' ) [10:46:49.157] Vidbot :: _next(), _stepIndex:2 of 4 [10:46:49.157] index :: _onStepCompleted_vidbot(), step: 2 [10:46:49.157] index :: _onStepStarted_vidbot(), step: 3 [10:46:49.157] Vidbot :: step[2], label:Rendering Canvas Streams [10:46:49.158] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [10:46:49.158] StreamManager :: render() [10:46:49.158] CanvasStream[canvas_998566004527] :: render() [10:46:49.228] index :: _onStepProgress_vidbot(), percent: 0 [10:47:24.543] index :: _onStepProgress_vidbot(), percent: 5 [10:48:04.086] index :: _onStepProgress_vidbot(), percent: 10 [10:48:40.766] index :: _onStepProgress_vidbot(), percent: 15 [10:49:22.036] index :: _onStepProgress_vidbot(), percent: 20 [10:50:03.445] index :: _onStepProgress_vidbot(), percent: 25 [10:50:40.663] index :: _onStepProgress_vidbot(), percent: 30 [10:51:17.452] index :: _onStepProgress_vidbot(), percent: 35 [10:51:51.887] index :: _onStepProgress_vidbot(), percent: 40 [10:52:29.704] index :: _onStepProgress_vidbot(), percent: 45 [10:53:03.079] index :: _onStepProgress_vidbot(), percent: 50 [10:53:38.024] index :: _onStepProgress_vidbot(), percent: 55 [10:54:15.909] index :: _onStepProgress_vidbot(), percent: 60 [10:54:47.298] index :: _onStepProgress_vidbot(), percent: 65 [10:55:14.950] index :: _onStepProgress_vidbot(), percent: 70 [10:55:43.126] index :: _onStepProgress_vidbot(), percent: 75 [10:56:11.031] index :: _onStepProgress_vidbot(), percent: 80 [10:56:39.050] index :: _onStepProgress_vidbot(), percent: 85 [10:57:08.906] index :: _onStepProgress_vidbot(), percent: 90 [10:57:47.898] index :: _onStepProgress_vidbot(), percent: 95 [10:58:25.816] index :: _onStepProgress_vidbot(), percent: 100 [10:58:29.096] StreamManager :: render(), Promise.all.then... [10:58:29.096] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [10:58:29.097] Vidbot :: _next(), _stepIndex:3 of 4 [10:58:29.097] index :: _onStepCompleted_vidbot(), step: 3 [10:58:29.097] index :: _onStepStarted_vidbot(), step: 4 [10:58:29.098] Vidbot :: step[3], label:Encoding Media [10:58:29.101] CanvasFilters :: Overlay() [10:58:29.101] AudioStream[audio_vo] :: inputOptions() [10:58:29.101] AudioFilters :: Volume() [10:58:29.101] filter: [2:a]volume=1[2_vol] [10:58:29.102] AudioFilters :: Delay() [10:58:29.102] filter: [2_vol]adelay=0|0[2_del] [10:58:29.102] AudioStream[bg_music] :: inputOptions() [10:58:29.102] AudioFilters :: Volume() [10:58:29.102] filter: [3:a]volume=0.25[3_vol] [10:58:29.102] AudioFilters :: FadeOut() [10:58:29.102] filter: [3_vol]afade=t=out:st=53.17:d=1[3_fadeout] [10:58:29.102] AudioFilters :: Delay() [10:58:29.102] filter: [3_fadeout]adelay=0|0[3_del] [10:58:29.102] AudioFilters :: Mix() [10:58:29.103] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [10:58:29.103] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [10:58:29.114] hang.time: 60 [10:58:29.258] Vidbot :: ffmpeg.on( 'start' ) [10:58:29.259] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=53.17 -r 30 -i ./tmp/canvas_998566004527_%05d.png -to 00:00:53.170 -i file:///var/www/html/c [10:58:29.259] lients/17410/audio/0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF.mp3 -to 00:00:53.170 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF3_Eas [10:58:29.259] y_Listening.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 [10:58:29.259] =t=out:st=53.17: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 m [10:58:29.259] p4 -map [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/17410/video/0CF5C60F-8 [10:58:29.259] 98F-C7DF-3DDE-8AF9879BBEEF.mp4 [10:58:29.539] index :: _onStepProgress_vidbot(), percent: -3906805449 [10:58:29.859] index :: _onStepProgress_vidbot(), percent: 1 [10:58:31.408] index :: _onStepProgress_vidbot(), percent: 5 [10:58:32.924] index :: _onStepProgress_vidbot(), percent: 11 [10:58:33.930] index :: _onStepProgress_vidbot(), percent: 15 [10:58:35.452] index :: _onStepProgress_vidbot(), percent: 21 [10:58:36.961] index :: _onStepProgress_vidbot(), percent: 27 [10:58:37.991] index :: _onStepProgress_vidbot(), percent: 30 [10:58:39.011] index :: _onStepProgress_vidbot(), percent: 35 [10:58:40.504] index :: _onStepProgress_vidbot(), percent: 42 [10:58:41.006] index :: _onStepProgress_vidbot(), percent: 45 [10:58:42.031] index :: _onStepProgress_vidbot(), percent: 50 [10:58:43.565] index :: _onStepProgress_vidbot(), percent: 56 [10:58:44.578] index :: _onStepProgress_vidbot(), percent: 60 [10:58:46.083] index :: _onStepProgress_vidbot(), percent: 67 [10:58:47.089] index :: _onStepProgress_vidbot(), percent: 72 [10:58:47.599] index :: _onStepProgress_vidbot(), percent: 75 [10:58:49.109] index :: _onStepProgress_vidbot(), percent: 81 [10:58:50.119] index :: _onStepProgress_vidbot(), percent: 85 [10:58:51.630] index :: _onStepProgress_vidbot(), percent: 92 [10:58:52.688] index :: _onStepProgress_vidbot(), percent: 97 [10:58:53.167] index :: _onStepProgress_vidbot(), percent: 100 [10:58:53.355] Vidbot :: ffmpeg.on( 'end' ), Done! [10:58:53.356] StreamManager :: dispose() [10:58:53.356] CanvasStream[canvas_998566004527] :: dispose() [10:58:53.365] Vidbot :: fflog.on( 'finish' ) [10:58:53.365] fflog.path: /var/www/html/clients/17410/video/0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF.mp4.fflog [10:58:53.365] Vidbot :: _next(), _stepIndex:4 of 4 [10:58:53.365] index :: _onStepCompleted_vidbot(), step: 4 [10:58:53.365] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 725.555, output: '/var/www/html/clients/17410/video/0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF.mp4', duration: 53.17 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/17410/video/0CF5C60F-898F-C7DF-3DDE-8AF9879BBEEF.mp4 Media Duration : 00:00:53.170 Generation Time : 00:12:05.554 ---------------------------------------------------------------------------------------------------------------