--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [08:51:43.553] Vidbot :: start() [08:51:43.554] Vidbot :: _next(), _stepIndex:0 of 4 [08:51:43.554] index :: _onStepStarted_vidbot(), step: 1 [08:51:43.555] Vidbot :: step[0], label:Initializing Core [08:51:43.563] index :: _onStepProgress_vidbot(), percent: 20 [08:51:43.563] Vidbot :: _parse() [08:51:43.564] index :: _onStepProgress_vidbot(), percent: 40 [08:51:43.565] Vidbot :: _validate() [08:51:43.565] index :: _onStepProgress_vidbot(), percent: 60 [08:51:43.565] Vidbot :: _fonts() [08:51:43.566] FabricFontManager :: add(), id: SourceSansPro-Bold [08:51:43.566] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [08:51:43.574] FabricFontManager :: add(), id: SourceSansPro-Light [08:51:43.574] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [08:51:43.574] FabricFontManager :: add(), id: DINOT-Bold [08:51:43.575] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [08:51:43.575] FabricFontManager :: add(), id: DINOT-Light [08:51:43.575] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [08:51:43.576] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [08:51:43.576] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [08:51:43.577] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [08:51:43.577] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [08:51:43.578] index :: _onStepProgress_vidbot(), percent: 80 [08:51:43.578] Vidbot :: _clips() [08:51:43.579] StreamManager :: add(), id:audio_vo, type:audio [08:51:43.579] AudioClip[audio_vo] :: constructor() [08:51:43.579] InputStream[audio_vo] :: constructor() [08:51:43.579] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [08:51:43.582] StreamManager :: add(), id:bg_music, type:audio [08:51:43.582] AudioClip[bg_music] :: constructor() [08:51:43.582] InputStream[bg_music] :: constructor() [08:51:43.582] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [08:51:43.582] StreamManager :: add(), id:simplefadedisplay, type:canvas [08:51:43.583] CanvasStream[canvas_158612341663] :: constructor() [08:51:43.583] InputStream[canvas_158612341663] :: constructor() [08:51:43.657] KenBurnsSlideshow[simplefadedisplay] :: constructor() [08:51:43.657] Overlay[simplefadedisplay] :: constructor() [08:51:43.657] CanvasClip[simplefadedisplay] :: constructor() [08:51:43.657] Clip[simplefadedisplay] :: constructor() [08:51:43.658] clip:"simplefadedisplay" added to stream:"canvas_158612341663" [08:51:43.658] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_158612341663', clipId: 'simplefadedisplay' } [08:51:43.658] StreamManager :: add(), id:caption, type:canvas [08:51:43.658] RenCaption[caption] :: constructor() [08:51:43.658] Ren[caption] :: constructor() [08:51:43.658] Overlay[caption] :: constructor() [08:51:43.658] CanvasClip[caption] :: constructor() [08:51:43.658] Clip[caption] :: constructor() [08:51:43.658] clip:"caption" added to stream:"canvas_158612341663" [08:51:43.658] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_158612341663', clipId: 'caption' } [08:51:43.659] StreamManager :: add(), id:options, type:canvas [08:51:43.659] RenOptions[options] :: constructor() [08:51:43.659] Ren[options] :: constructor() [08:51:43.659] Overlay[options] :: constructor() [08:51:43.659] CanvasClip[options] :: constructor() [08:51:43.659] Clip[options] :: constructor() [08:51:43.659] clip:"options" added to stream:"canvas_158612341663" [08:51:43.659] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_158612341663', clipId: 'options' } [08:51:43.659] all added... [08:51:43.659] Vidbot :: _next(), _stepIndex:1 of 4 [08:51:43.660] index :: _onStepCompleted_vidbot(), step: 1 [08:51:43.660] index :: _onStepStarted_vidbot(), step: 2 [08:51:43.660] Vidbot :: step[1], label:Initializing Input Streams [08:51:43.660] StreamManager :: init() [08:51:43.661] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [08:51:43.661] index :: _onStepProgress_vidbot(), percent: 33 [08:51:43.661] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [08:51:43.661] index :: _onStepProgress_vidbot(), percent: 67 [08:51:43.662] CanvasStream[canvas_158612341663] :: _init(), BEGIN [08:51:43.662] i:0, c.id:simplefadedisplay [08:51:43.662] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [08:51:43.662] KenBurnsSlideshow[simplefadedisplay] :: _validate() [08:51:43.663] KenBurnsSlideshow[undefined] :: _validateAnim() [08:51:43.663] KenBurnsSlideshow[undefined] :: _validateTheme() [08:51:43.664] i:1, c.id:caption [08:51:43.664] RenCaption[caption] :: _init() [08:51:43.665] RenCaption[caption] :: _validate() [08:51:43.665] i:2, c.id:options [08:51:43.665] RenPrice[options] :: _init() [08:51:43.666] RenOptions[options] :: _validate() [08:51:43.667] KenBurnsSlideshow[simplefadedisplay] :: _build() [08:51:43.673] AnimatedImageFrame[aif] :: constructor() [08:51:43.674] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:43.674] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_1.jpg [08:51:43.685] RenCaption[caption] :: _build() [08:51:43.700] RenOptions[options] :: _assets() [08:51:43.701] CanvasClip :: LoadSVGFromStringWithPromise() [08:51:43.728] CanvasClip :: LoadSVGFromString(), loaded [08:51:43.731] Overlay[caption] :: _animate() [08:51:43.734] RenOptions[options] :: _build() [08:51:43.823] CanvasStream[caption] :: _init(), p.then() [08:51:43.824] RenOptions[options] :: _animate() [08:51:43.824] Overlay[options] :: _animate() [08:51:43.825] CanvasStream[options] :: _init(), p.then() [08:51:43.858] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:43.861] AnimatedImageFrame[aif] :: _init(), END [08:51:43.862] AnimatedImageFrame[aif] :: constructor() [08:51:43.862] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:43.862] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_2.jpg [08:51:43.889] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:43.890] AnimatedImageFrame[aif] :: _init(), END [08:51:43.891] AnimatedImageFrame[aif] :: constructor() [08:51:43.891] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:43.891] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_3.jpg [08:51:43.922] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:43.923] AnimatedImageFrame[aif] :: _init(), END [08:51:43.924] AnimatedImageFrame[aif] :: constructor() [08:51:43.924] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:43.924] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_4.jpg [08:51:43.949] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:43.949] AnimatedImageFrame[aif] :: _init(), END [08:51:43.950] AnimatedImageFrame[aif] :: constructor() [08:51:43.950] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:43.950] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_5.jpg [08:51:43.976] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:43.977] AnimatedImageFrame[aif] :: _init(), END [08:51:43.977] AnimatedImageFrame[aif] :: constructor() [08:51:43.978] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:43.978] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_6.jpg [08:51:44.006] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.007] AnimatedImageFrame[aif] :: _init(), END [08:51:44.007] AnimatedImageFrame[aif] :: constructor() [08:51:44.007] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.008] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_7.jpg [08:51:44.037] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.038] AnimatedImageFrame[aif] :: _init(), END [08:51:44.039] AnimatedImageFrame[aif] :: constructor() [08:51:44.039] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.039] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_8.jpg [08:51:44.069] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.070] AnimatedImageFrame[aif] :: _init(), END [08:51:44.070] AnimatedImageFrame[aif] :: constructor() [08:51:44.070] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.070] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_9.jpg [08:51:44.100] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.101] AnimatedImageFrame[aif] :: _init(), END [08:51:44.101] AnimatedImageFrame[aif] :: constructor() [08:51:44.102] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.102] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_10.jpg [08:51:44.140] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.140] AnimatedImageFrame[aif] :: _init(), END [08:51:44.141] AnimatedImageFrame[aif] :: constructor() [08:51:44.141] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.141] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_11.jpg [08:51:44.177] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.178] AnimatedImageFrame[aif] :: _init(), END [08:51:44.179] AnimatedImageFrame[aif] :: constructor() [08:51:44.179] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.179] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_12.jpg [08:51:44.214] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.215] AnimatedImageFrame[aif] :: _init(), END [08:51:44.215] AnimatedImageFrame[aif] :: constructor() [08:51:44.215] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.216] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_13.jpg [08:51:44.246] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.248] AnimatedImageFrame[aif] :: _init(), END [08:51:44.248] AnimatedImageFrame[aif] :: constructor() [08:51:44.249] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.249] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_14.jpg [08:51:44.297] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.298] AnimatedImageFrame[aif] :: _init(), END [08:51:44.299] AnimatedImageFrame[aif] :: constructor() [08:51:44.299] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.299] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_15.jpg [08:51:44.325] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.325] AnimatedImageFrame[aif] :: _init(), END [08:51:44.326] AnimatedImageFrame[aif] :: constructor() [08:51:44.326] AnimatedImageFrame[aif] :: _init(), BEGIN [08:51:44.326] CanvasClip :: LoadImageWithPromise(), src: 8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED_16.jpg [08:51:44.355] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [08:51:44.356] AnimatedImageFrame[aif] :: _init(), END [08:51:44.356] Overlay[simplefadedisplay] :: _animate() [08:51:44.357] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [08:51:44.357] CanvasStream[simplefadedisplay] :: _init(), p.then() [08:51:44.357] CanvasStream[canvas_158612341663] :: _init(), promise.all.then() [08:51:44.360] CanvasStream[canvas_158612341663] :: _init(), END [08:51:44.360] StreamMangaer :: init(), stream[canvas_158612341663].then() [08:51:44.360] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_158612341663', progress: 1 } [08:51:44.361] index :: _onStepProgress_vidbot(), percent: 100 [08:51:44.361] StreamManager :: init(), promise.all.then... [08:51:44.361] Vidbot :: StreamMgr.on( 'INITED' ) [08:51:44.361] Vidbot :: _next(), _stepIndex:2 of 4 [08:51:44.361] index :: _onStepCompleted_vidbot(), step: 2 [08:51:44.361] index :: _onStepStarted_vidbot(), step: 3 [08:51:44.362] Vidbot :: step[2], label:Rendering Canvas Streams [08:51:44.362] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [08:51:44.362] StreamManager :: render() [08:51:44.363] CanvasStream[canvas_158612341663] :: render() [08:51:44.435] index :: _onStepProgress_vidbot(), percent: 0 [08:52:04.467] index :: _onStepProgress_vidbot(), percent: 5 [08:52:26.392] index :: _onStepProgress_vidbot(), percent: 10 [08:52:54.270] index :: _onStepProgress_vidbot(), percent: 15 [08:53:24.010] index :: _onStepProgress_vidbot(), percent: 20 [08:53:37.697] index :: _onStepProgress_vidbot(), percent: 25 [08:53:51.550] index :: _onStepProgress_vidbot(), percent: 30 [08:54:05.613] index :: _onStepProgress_vidbot(), percent: 35 [08:54:19.187] index :: _onStepProgress_vidbot(), percent: 40 [08:54:33.292] index :: _onStepProgress_vidbot(), percent: 45 [08:54:46.673] index :: _onStepProgress_vidbot(), percent: 50 [08:55:00.227] index :: _onStepProgress_vidbot(), percent: 55 [08:55:13.657] index :: _onStepProgress_vidbot(), percent: 60 [08:55:28.486] index :: _onStepProgress_vidbot(), percent: 65 [08:55:44.414] index :: _onStepProgress_vidbot(), percent: 70 [08:56:14.416] index :: _onStepProgress_vidbot(), percent: 75 [08:56:43.143] index :: _onStepProgress_vidbot(), percent: 80 [08:57:10.274] index :: _onStepProgress_vidbot(), percent: 85 [08:57:37.879] index :: _onStepProgress_vidbot(), percent: 90 [08:58:04.698] index :: _onStepProgress_vidbot(), percent: 95 [08:58:25.592] index :: _onStepProgress_vidbot(), percent: 100 [08:58:27.489] StreamManager :: render(), Promise.all.then... [08:58:27.490] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [08:58:27.490] Vidbot :: _next(), _stepIndex:3 of 4 [08:58:27.490] index :: _onStepCompleted_vidbot(), step: 3 [08:58:27.490] index :: _onStepStarted_vidbot(), step: 4 [08:58:27.491] Vidbot :: step[3], label:Encoding Media [08:58:27.494] CanvasFilters :: Overlay() [08:58:27.494] AudioStream[audio_vo] :: inputOptions() [08:58:27.494] AudioFilters :: Volume() [08:58:27.494] filter: [2:a]volume=1[2_vol] [08:58:27.495] AudioFilters :: Delay() [08:58:27.495] filter: [2_vol]adelay=0|0[2_del] [08:58:27.495] AudioStream[bg_music] :: inputOptions() [08:58:27.495] AudioFilters :: Volume() [08:58:27.495] filter: [3:a]volume=0.25[3_vol] [08:58:27.499] AudioFilters :: FadeOut() [08:58:27.499] filter: [3_vol]afade=t=out:st=48:d=1[3_fadeout] [08:58:27.499] AudioFilters :: Delay() [08:58:27.499] filter: [3_fadeout]adelay=0|0[3_del] [08:58:27.499] AudioFilters :: Mix() [08:58:27.499] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [08:58:27.499] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [08:58:27.502] hang.time: 60 [08:58:27.602] Vidbot :: ffmpeg.on( 'start' ) [08:58:27.602] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=48 -r 30 -i ./tmp/canvas_158612341663_%05d.png -to 00:00:48.000 -i file:///var/www/html/clie [08:58:27.602] nts/22817/audio/8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED.mp3 -to 00:00:48.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF3_Easy_L [08:58:27.602] istening.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= [08:58:27.602] out:st=48: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 -ma [08:58:27.602] p [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/22817/video/8FEB1E96-79D8-F9 [08:58:27.603] DF-44DF-05A23DE4D9ED.mp4 [08:58:27.774] index :: _onStepProgress_vidbot(), percent: -4327600953 [08:58:28.190] index :: _onStepProgress_vidbot(), percent: 1 [08:58:29.196] index :: _onStepProgress_vidbot(), percent: 6 [08:58:30.214] index :: _onStepProgress_vidbot(), percent: 12 [08:58:30.705] index :: _onStepProgress_vidbot(), percent: 15 [08:58:31.708] index :: _onStepProgress_vidbot(), percent: 20 [08:58:32.728] index :: _onStepProgress_vidbot(), percent: 25 [08:58:34.242] index :: _onStepProgress_vidbot(), percent: 32 [08:58:35.244] index :: _onStepProgress_vidbot(), percent: 37 [08:58:36.265] index :: _onStepProgress_vidbot(), percent: 42 [08:58:36.787] index :: _onStepProgress_vidbot(), percent: 45 [08:58:37.802] index :: _onStepProgress_vidbot(), percent: 50 [08:58:38.815] index :: _onStepProgress_vidbot(), percent: 55 [08:58:39.826] index :: _onStepProgress_vidbot(), percent: 60 [08:58:40.831] index :: _onStepProgress_vidbot(), percent: 66 [08:58:41.837] index :: _onStepProgress_vidbot(), percent: 71 [08:58:42.852] index :: _onStepProgress_vidbot(), percent: 76 [08:58:43.871] index :: _onStepProgress_vidbot(), percent: 80 [08:58:44.874] index :: _onStepProgress_vidbot(), percent: 85 [08:58:46.405] index :: _onStepProgress_vidbot(), percent: 91 [08:58:47.430] index :: _onStepProgress_vidbot(), percent: 95 [08:58:48.696] index :: _onStepProgress_vidbot(), percent: 100 [08:58:48.779] Vidbot :: ffmpeg.on( 'end' ), Done! [08:58:48.779] StreamManager :: dispose() [08:58:48.779] CanvasStream[canvas_158612341663] :: dispose() [08:58:48.784] Vidbot :: fflog.on( 'finish' ) [08:58:48.784] fflog.path: /var/www/html/clients/22817/video/8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED.mp4.fflog [08:58:48.784] Vidbot :: _next(), _stepIndex:4 of 4 [08:58:48.785] index :: _onStepCompleted_vidbot(), step: 4 [08:58:48.785] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 425.25, output: '/var/www/html/clients/22817/video/8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED.mp4', duration: 48 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/22817/video/8FEB1E96-79D8-F9DF-44DF-05A23DE4D9ED.mp4 Media Duration : 00:00:48.000 Generation Time : 00:07:05.250 ---------------------------------------------------------------------------------------------------------------