--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [13:51:16.801] Vidbot :: start() [13:51:16.802] Vidbot :: _next(), _stepIndex:0 of 4 [13:51:16.802] index :: _onStepStarted_vidbot(), step: 1 [13:51:16.803] Vidbot :: step[0], label:Initializing Core [13:51:16.813] index :: _onStepProgress_vidbot(), percent: 20 [13:51:16.813] Vidbot :: _parse() [13:51:16.815] index :: _onStepProgress_vidbot(), percent: 40 [13:51:16.815] Vidbot :: _validate() [13:51:16.816] index :: _onStepProgress_vidbot(), percent: 60 [13:51:16.816] Vidbot :: _fonts() [13:51:16.816] FabricFontManager :: add(), id: SourceSansPro-Bold [13:51:16.816] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [13:51:16.825] FabricFontManager :: add(), id: SourceSansPro-Light [13:51:16.825] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [13:51:16.826] FabricFontManager :: add(), id: DINOT-Bold [13:51:16.826] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [13:51:16.827] FabricFontManager :: add(), id: DINOT-Light [13:51:16.827] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [13:51:16.828] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [13:51:16.828] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [13:51:16.829] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [13:51:16.829] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [13:51:16.830] index :: _onStepProgress_vidbot(), percent: 80 [13:51:16.830] Vidbot :: _clips() [13:51:16.831] StreamManager :: add(), id:audio_vo, type:audio [13:51:16.831] AudioClip[audio_vo] :: constructor() [13:51:16.831] InputStream[audio_vo] :: constructor() [13:51:16.832] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [13:51:16.834] StreamManager :: add(), id:bg_music, type:audio [13:51:16.834] AudioClip[bg_music] :: constructor() [13:51:16.835] InputStream[bg_music] :: constructor() [13:51:16.835] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [13:51:16.835] StreamManager :: add(), id:mira, type:canvas [13:51:16.835] CanvasStream[canvas_218065899550] :: constructor() [13:51:16.835] InputStream[canvas_218065899550] :: constructor() [13:51:16.916] MiraSlideshow[mira] :: constructor() [13:51:16.916] Mira[mira] :: constructor() [13:51:16.917] Overlay[mira] :: constructor() [13:51:16.917] CanvasClip[mira] :: constructor() [13:51:16.917] Clip[mira] :: constructor() [13:51:16.917] clip:"mira" added to stream:"canvas_218065899550" [13:51:16.917] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_218065899550', clipId: 'mira' } [13:51:16.917] all added... [13:51:16.918] Vidbot :: _next(), _stepIndex:1 of 4 [13:51:16.918] index :: _onStepCompleted_vidbot(), step: 1 [13:51:16.918] index :: _onStepStarted_vidbot(), step: 2 [13:51:16.918] Vidbot :: step[1], label:Initializing Input Streams [13:51:16.919] StreamManager :: init() [13:51:16.919] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [13:51:16.919] index :: _onStepProgress_vidbot(), percent: 33 [13:51:16.919] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [13:51:16.920] index :: _onStepProgress_vidbot(), percent: 67 [13:51:16.920] CanvasStream[canvas_218065899550] :: _init(), BEGIN [13:51:16.920] i:0, c.id:mira [13:51:16.920] MiraSlideshow[mira] :: _init(), BEGIN [13:51:16.921] MiraSlideshow[mira] :: _validate() [13:51:16.923] MiraSlideshow :: _validateSlides() [13:51:16.923] i:0, s.type: title [13:51:16.923] i:1, s.type: info [13:51:16.923] i:2, s.type: image [13:51:16.923] i:3, s.type: image [13:51:16.923] i:4, s.type: image [13:51:16.923] i:5, s.type: image [13:51:16.923] i:6, s.type: image [13:51:16.923] i:7, s.type: image [13:51:16.923] i:8, s.type: image [13:51:16.924] i:9, s.type: image [13:51:16.924] i:10, s.type: image [13:51:16.924] i:11, s.type: image [13:51:16.924] i:12, s.type: image [13:51:16.924] i:13, s.type: image [13:51:16.924] i:14, s.type: image [13:51:16.924] i:15, s.type: image [13:51:16.924] i:16, s.type: image [13:51:16.928] MiraSlideshow[mira] :: _build(), BEGIN [13:51:16.933] MiraTitlecard[titlecard] :: constructor() [13:51:16.933] Mira[titlecard] :: constructor() [13:51:16.933] Overlay[titlecard] :: constructor() [13:51:16.933] CanvasClip[titlecard] :: constructor() [13:51:16.933] Clip[titlecard] :: constructor() [13:51:16.933] MiraTitlecard[titlecard] :: _init() [13:51:16.933] MiraTitlecard[titlecard] :: _validate() [13:51:16.934] MiraTitlecard[titlecard] :: _build() [13:51:16.959] Overlay[titlecard] :: _animate() [13:51:16.961] MiraTitlecard[titlecard] :: _animate() [13:51:16.963] AnimatedImageFrame[aiftitle] :: constructor() [13:51:16.964] AnimatedImageFrame[aiftitle] :: _init(), BEGIN [13:51:16.965] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_1.jpg [13:51:17.037] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.041] AnimatedImageFrame[aiftitle] :: _init(), END [13:51:17.046] MiraInfosheet[info] :: constructor() [13:51:17.046] Mira[info] :: constructor() [13:51:17.046] Overlay[info] :: constructor() [13:51:17.046] CanvasClip[info] :: constructor() [13:51:17.046] Clip[info] :: constructor() [13:51:17.047] MiraInfosheet[info] :: _init() [13:51:17.047] MiraInfosheet[info] :: _validate() [13:51:17.049] MiraInfosheet[info] :: _build() [13:51:17.060] RenOptions[info] :: _animate() [13:51:17.060] Overlay[info] :: _animate() [13:51:17.062] AnimatedImageFrame[info1] :: constructor() [13:51:17.062] AnimatedImageFrame[info2] :: constructor() [13:51:17.063] AnimatedImageFrame[info3] :: constructor() [13:51:17.063] AnimatedImageFrame[info1] :: _init(), BEGIN [13:51:17.063] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_7.jpg [13:51:17.105] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.107] AnimatedImageFrame[info1] :: _init(), END [13:51:17.107] AnimatedImageFrame[info2] :: _init(), BEGIN [13:51:17.108] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_9.jpg [13:51:17.144] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.145] AnimatedImageFrame[info2] :: _init(), END [13:51:17.145] AnimatedImageFrame[info3] :: _init(), BEGIN [13:51:17.145] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_13.jpg [13:51:17.188] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.189] AnimatedImageFrame[info3] :: _init(), END [13:51:17.191] AnimatedImageFrame[image] :: constructor() [13:51:17.191] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.191] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_1.jpg [13:51:17.239] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.240] AnimatedImageFrame[image] :: _init(), END [13:51:17.241] AnimatedImageFrame[image] :: constructor() [13:51:17.241] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.241] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_2.jpg [13:51:17.286] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.287] AnimatedImageFrame[image] :: _init(), END [13:51:17.287] AnimatedImageFrame[image] :: constructor() [13:51:17.287] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.288] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_3.jpg [13:51:17.322] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.323] AnimatedImageFrame[image] :: _init(), END [13:51:17.324] AnimatedImageFrame[image] :: constructor() [13:51:17.324] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.324] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_4.jpg [13:51:17.359] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.360] AnimatedImageFrame[image] :: _init(), END [13:51:17.360] AnimatedImageFrame[image] :: constructor() [13:51:17.360] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.360] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_5.jpg [13:51:17.397] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.398] AnimatedImageFrame[image] :: _init(), END [13:51:17.398] AnimatedImageFrame[image] :: constructor() [13:51:17.398] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.399] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_6.jpg [13:51:17.426] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.427] AnimatedImageFrame[image] :: _init(), END [13:51:17.428] AnimatedImageFrame[image] :: constructor() [13:51:17.428] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.428] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_7.jpg [13:51:17.468] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.469] AnimatedImageFrame[image] :: _init(), END [13:51:17.470] AnimatedImageFrame[image] :: constructor() [13:51:17.470] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.470] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_8.jpg [13:51:17.507] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.508] AnimatedImageFrame[image] :: _init(), END [13:51:17.508] AnimatedImageFrame[image] :: constructor() [13:51:17.508] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.508] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_9.jpg [13:51:17.539] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.540] AnimatedImageFrame[image] :: _init(), END [13:51:17.541] AnimatedImageFrame[image] :: constructor() [13:51:17.541] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.541] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_10.jpg [13:51:17.582] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.583] AnimatedImageFrame[image] :: _init(), END [13:51:17.583] AnimatedImageFrame[image] :: constructor() [13:51:17.583] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.584] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_11.jpg [13:51:17.617] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.619] AnimatedImageFrame[image] :: _init(), END [13:51:17.619] AnimatedImageFrame[image] :: constructor() [13:51:17.619] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.619] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_12.jpg [13:51:17.666] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.668] AnimatedImageFrame[image] :: _init(), END [13:51:17.669] AnimatedImageFrame[image] :: constructor() [13:51:17.669] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.669] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_13.jpg [13:51:17.702] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.703] AnimatedImageFrame[image] :: _init(), END [13:51:17.703] AnimatedImageFrame[image] :: constructor() [13:51:17.703] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.703] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_14.jpg [13:51:17.735] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.736] AnimatedImageFrame[image] :: _init(), END [13:51:17.736] AnimatedImageFrame[image] :: constructor() [13:51:17.736] AnimatedImageFrame[image] :: _init(), BEGIN [13:51:17.737] CanvasClip :: LoadImageWithPromise(), src: 86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7_15.jpg [13:51:17.769] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [13:51:17.770] AnimatedImageFrame[image] :: _init(), END [13:51:17.771] MiraSlideshow[mira] :: _build(), END [13:51:17.771] Overlay[mira] :: _animate() [13:51:17.772] MiraSlideshow[mira] :: _init(), END [13:51:17.772] CanvasStream[mira] :: _init(), p.then() [13:51:17.772] CanvasStream[canvas_218065899550] :: _init(), promise.all.then() [13:51:17.773] CanvasStream[canvas_218065899550] :: _init(), END [13:51:17.774] StreamMangaer :: init(), stream[canvas_218065899550].then() [13:51:17.774] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_218065899550', progress: 1 } [13:51:17.774] index :: _onStepProgress_vidbot(), percent: 100 [13:51:17.774] StreamManager :: init(), promise.all.then... [13:51:17.774] Vidbot :: StreamMgr.on( 'INITED' ) [13:51:17.774] Vidbot :: _next(), _stepIndex:2 of 4 [13:51:17.775] index :: _onStepCompleted_vidbot(), step: 2 [13:51:17.775] index :: _onStepStarted_vidbot(), step: 3 [13:51:17.775] Vidbot :: step[2], label:Rendering Canvas Streams [13:51:17.775] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [13:51:17.775] StreamManager :: render() [13:51:17.776] CanvasStream[canvas_218065899550] :: render() [13:51:17.836] index :: _onStepProgress_vidbot(), percent: 0 [13:51:52.479] index :: _onStepProgress_vidbot(), percent: 5 [13:52:17.786] index :: _onStepProgress_vidbot(), percent: 10 [13:52:55.666] index :: _onStepProgress_vidbot(), percent: 15 [13:53:40.529] index :: _onStepProgress_vidbot(), percent: 20 [13:54:23.215] index :: _onStepProgress_vidbot(), percent: 25 [13:55:02.190] index :: _onStepProgress_vidbot(), percent: 30 [13:55:46.513] index :: _onStepProgress_vidbot(), percent: 35 [13:56:36.002] index :: _onStepProgress_vidbot(), percent: 40 [13:57:19.879] index :: _onStepProgress_vidbot(), percent: 45 [13:57:37.684] index :: _onStepProgress_vidbot(), percent: 50 [13:58:19.151] index :: _onStepProgress_vidbot(), percent: 55 [13:59:07.848] index :: _onStepProgress_vidbot(), percent: 60 [13:59:50.141] index :: _onStepProgress_vidbot(), percent: 65 [14:00:28.876] index :: _onStepProgress_vidbot(), percent: 70 [14:01:14.930] index :: _onStepProgress_vidbot(), percent: 75 [14:02:01.809] index :: _onStepProgress_vidbot(), percent: 80 [14:02:41.179] index :: _onStepProgress_vidbot(), percent: 85 [14:03:18.648] index :: _onStepProgress_vidbot(), percent: 90 [14:03:58.048] index :: _onStepProgress_vidbot(), percent: 95 [14:04:39.183] index :: _onStepProgress_vidbot(), percent: 100 [14:04:43.273] StreamManager :: render(), Promise.all.then... [14:04:43.274] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [14:04:43.274] Vidbot :: _next(), _stepIndex:3 of 4 [14:04:43.274] index :: _onStepCompleted_vidbot(), step: 3 [14:04:43.275] index :: _onStepStarted_vidbot(), step: 4 [14:04:43.276] Vidbot :: step[3], label:Encoding Media [14:04:43.278] CanvasFilters :: Overlay() [14:04:43.279] AudioStream[audio_vo] :: inputOptions() [14:04:43.279] AudioFilters :: Volume() [14:04:43.279] filter: [2:a]volume=1[2_vol] [14:04:43.279] AudioFilters :: Delay() [14:04:43.279] filter: [2_vol]adelay=0|0[2_del] [14:04:43.279] AudioStream[bg_music] :: inputOptions() [14:04:43.280] AudioFilters :: Volume() [14:04:43.280] filter: [3:a]volume=0.15[3_vol] [14:04:43.280] AudioFilters :: FadeOut() [14:04:43.280] filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout] [14:04:43.280] AudioFilters :: Delay() [14:04:43.280] filter: [3_fadeout]adelay=0|0[3_del] [14:04:43.280] AudioFilters :: Mix() [14:04:43.280] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [14:04:43.280] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [14:04:43.283] hang.time: 60 [14:04:43.425] Vidbot :: ffmpeg.on( 'start' ) [14:04:43.425] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=60 -r 30 -i ./tmp/canvas_218065899550_%05d.png -to 00:01:00.000 -i file:///var/www/html/clie [14:04:43.425] nts/21743/audio/86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF3_Easy_L [14:04:43.425] 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.15[3_vol];[3_vol]afade=t= [14:04:43.426] out:st=60: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 [14:04:43.426] p [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/21743/video/86BFD1F5-D423-FD [14:04:43.426] 0E-E0BB-20F9B2F104F7.mp4 [14:04:43.635] index :: _onStepProgress_vidbot(), percent: -3462080762 [14:04:44.048] index :: _onStepProgress_vidbot(), percent: 1 [14:04:45.055] index :: _onStepProgress_vidbot(), percent: 5 [14:04:46.069] index :: _onStepProgress_vidbot(), percent: 10 [14:04:47.576] index :: _onStepProgress_vidbot(), percent: 15 [14:04:49.096] index :: _onStepProgress_vidbot(), percent: 20 [14:04:50.613] index :: _onStepProgress_vidbot(), percent: 26 [14:04:51.626] index :: _onStepProgress_vidbot(), percent: 30 [14:04:53.127] index :: _onStepProgress_vidbot(), percent: 35 [14:04:54.129] index :: _onStepProgress_vidbot(), percent: 40 [14:04:55.632] index :: _onStepProgress_vidbot(), percent: 46 [14:04:56.646] index :: _onStepProgress_vidbot(), percent: 50 [14:04:57.648] index :: _onStepProgress_vidbot(), percent: 55 [14:04:59.160] index :: _onStepProgress_vidbot(), percent: 60 [14:05:00.673] index :: _onStepProgress_vidbot(), percent: 65 [14:05:02.195] index :: _onStepProgress_vidbot(), percent: 71 [14:05:03.200] index :: _onStepProgress_vidbot(), percent: 75 [14:05:04.710] index :: _onStepProgress_vidbot(), percent: 81 [14:05:05.718] index :: _onStepProgress_vidbot(), percent: 85 [14:05:06.724] index :: _onStepProgress_vidbot(), percent: 90 [14:05:08.237] index :: _onStepProgress_vidbot(), percent: 97 [14:05:08.974] index :: _onStepProgress_vidbot(), percent: 100 [14:05:09.021] Vidbot :: ffmpeg.on( 'end' ), Done! [14:05:09.022] StreamManager :: dispose() [14:05:09.022] CanvasStream[canvas_218065899550] :: dispose() [14:05:09.046] Vidbot :: fflog.on( 'finish' ) [14:05:09.046] fflog.path: /var/www/html/clients/21743/video/86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7.mp4.fflog [14:05:09.046] Vidbot :: _next(), _stepIndex:4 of 4 [14:05:09.047] index :: _onStepCompleted_vidbot(), step: 4 [14:05:09.047] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 832.266, output: '/var/www/html/clients/21743/video/86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7.mp4', duration: 60 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/21743/video/86BFD1F5-D423-FD0E-E0BB-20F9B2F104F7.mp4 Media Duration : 00:01:00.000 Generation Time : 00:13:52.265 ---------------------------------------------------------------------------------------------------------------