--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [14:22:05.249] Vidbot :: start() [14:22:05.250] Vidbot :: _next(), _stepIndex:0 of 4 [14:22:05.250] index :: _onStepStarted_vidbot(), step: 1 [14:22:05.252] Vidbot :: step[0], label:Initializing Core [14:22:05.260] index :: _onStepProgress_vidbot(), percent: 20 [14:22:05.260] Vidbot :: _parse() [14:22:05.261] index :: _onStepProgress_vidbot(), percent: 40 [14:22:05.262] Vidbot :: _validate() [14:22:05.262] index :: _onStepProgress_vidbot(), percent: 60 [14:22:05.263] Vidbot :: _fonts() [14:22:05.263] FabricFontManager :: add(), id: SourceSansPro-Bold [14:22:05.263] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [14:22:05.271] FabricFontManager :: add(), id: SourceSansPro-Light [14:22:05.271] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [14:22:05.272] FabricFontManager :: add(), id: DINOT-Bold [14:22:05.272] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [14:22:05.273] FabricFontManager :: add(), id: DINOT-Light [14:22:05.273] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [14:22:05.273] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [14:22:05.274] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [14:22:05.274] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [14:22:05.274] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [14:22:05.275] index :: _onStepProgress_vidbot(), percent: 80 [14:22:05.275] Vidbot :: _clips() [14:22:05.276] StreamManager :: add(), id:audio_vo, type:audio [14:22:05.276] AudioClip[audio_vo] :: constructor() [14:22:05.276] InputStream[audio_vo] :: constructor() [14:22:05.277] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [14:22:05.279] StreamManager :: add(), id:bg_music, type:audio [14:22:05.279] AudioClip[bg_music] :: constructor() [14:22:05.279] InputStream[bg_music] :: constructor() [14:22:05.279] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [14:22:05.280] StreamManager :: add(), id:mira, type:canvas [14:22:05.280] CanvasStream[canvas_22681376957] :: constructor() [14:22:05.280] InputStream[canvas_22681376957] :: constructor() [14:22:05.353] MiraSlideshow[mira] :: constructor() [14:22:05.353] Mira[mira] :: constructor() [14:22:05.353] Overlay[mira] :: constructor() [14:22:05.353] CanvasClip[mira] :: constructor() [14:22:05.354] Clip[mira] :: constructor() [14:22:05.354] clip:"mira" added to stream:"canvas_22681376957" [14:22:05.354] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_22681376957', clipId: 'mira' } [14:22:05.354] all added... [14:22:05.354] Vidbot :: _next(), _stepIndex:1 of 4 [14:22:05.354] index :: _onStepCompleted_vidbot(), step: 1 [14:22:05.355] index :: _onStepStarted_vidbot(), step: 2 [14:22:05.355] Vidbot :: step[1], label:Initializing Input Streams [14:22:05.355] StreamManager :: init() [14:22:05.355] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [14:22:05.356] index :: _onStepProgress_vidbot(), percent: 33 [14:22:05.356] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [14:22:05.356] index :: _onStepProgress_vidbot(), percent: 67 [14:22:05.356] CanvasStream[canvas_22681376957] :: _init(), BEGIN [14:22:05.357] i:0, c.id:mira [14:22:05.357] MiraSlideshow[mira] :: _init(), BEGIN [14:22:05.357] MiraSlideshow[mira] :: _validate() [14:22:05.359] MiraSlideshow :: _validateSlides() [14:22:05.359] i:0, s.type: title [14:22:05.359] i:1, s.type: info [14:22:05.359] i:2, s.type: image [14:22:05.359] i:3, s.type: image [14:22:05.359] i:4, s.type: image [14:22:05.359] i:5, s.type: image [14:22:05.359] i:6, s.type: image [14:22:05.359] i:7, s.type: image [14:22:05.359] i:8, s.type: image [14:22:05.359] i:9, s.type: image [14:22:05.360] i:10, s.type: image [14:22:05.360] i:11, s.type: image [14:22:05.360] i:12, s.type: image [14:22:05.360] i:13, s.type: image [14:22:05.360] i:14, s.type: image [14:22:05.360] i:15, s.type: image [14:22:05.360] i:16, s.type: image [14:22:05.363] MiraSlideshow[mira] :: _build(), BEGIN [14:22:05.368] MiraTitlecard[titlecard] :: constructor() [14:22:05.368] Mira[titlecard] :: constructor() [14:22:05.368] Overlay[titlecard] :: constructor() [14:22:05.368] CanvasClip[titlecard] :: constructor() [14:22:05.368] Clip[titlecard] :: constructor() [14:22:05.368] MiraTitlecard[titlecard] :: _init() [14:22:05.368] MiraTitlecard[titlecard] :: _validate() [14:22:05.369] MiraTitlecard[titlecard] :: _build() [14:22:05.392] Overlay[titlecard] :: _animate() [14:22:05.393] MiraTitlecard[titlecard] :: _animate() [14:22:05.395] AnimatedImageFrame[aiftitle] :: constructor() [14:22:05.397] AnimatedImageFrame[aiftitle] :: _init(), BEGIN [14:22:05.397] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_1.jpg [14:22:05.447] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.451] AnimatedImageFrame[aiftitle] :: _init(), END [14:22:05.455] MiraInfosheet[info] :: constructor() [14:22:05.455] Mira[info] :: constructor() [14:22:05.455] Overlay[info] :: constructor() [14:22:05.455] CanvasClip[info] :: constructor() [14:22:05.455] Clip[info] :: constructor() [14:22:05.456] MiraInfosheet[info] :: _init() [14:22:05.456] MiraInfosheet[info] :: _validate() [14:22:05.457] MiraInfosheet[info] :: _build() [14:22:05.467] RenOptions[info] :: _animate() [14:22:05.468] Overlay[info] :: _animate() [14:22:05.469] AnimatedImageFrame[info1] :: constructor() [14:22:05.469] AnimatedImageFrame[info2] :: constructor() [14:22:05.470] AnimatedImageFrame[info3] :: constructor() [14:22:05.470] AnimatedImageFrame[info1] :: _init(), BEGIN [14:22:05.470] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_3.jpg [14:22:05.505] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.507] AnimatedImageFrame[info1] :: _init(), END [14:22:05.507] AnimatedImageFrame[info2] :: _init(), BEGIN [14:22:05.507] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_4.jpg [14:22:05.543] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.544] AnimatedImageFrame[info2] :: _init(), END [14:22:05.544] AnimatedImageFrame[info3] :: _init(), BEGIN [14:22:05.545] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_20.jpg [14:22:05.580] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.581] AnimatedImageFrame[info3] :: _init(), END [14:22:05.582] AnimatedImageFrame[image] :: constructor() [14:22:05.582] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.582] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_1.jpg [14:22:05.617] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.619] AnimatedImageFrame[image] :: _init(), END [14:22:05.619] AnimatedImageFrame[image] :: constructor() [14:22:05.619] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.619] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_2.jpg [14:22:05.655] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.656] AnimatedImageFrame[image] :: _init(), END [14:22:05.657] AnimatedImageFrame[image] :: constructor() [14:22:05.657] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.657] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_3.jpg [14:22:05.690] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.691] AnimatedImageFrame[image] :: _init(), END [14:22:05.692] AnimatedImageFrame[image] :: constructor() [14:22:05.692] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.692] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_4.jpg [14:22:05.728] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.729] AnimatedImageFrame[image] :: _init(), END [14:22:05.730] AnimatedImageFrame[image] :: constructor() [14:22:05.730] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.730] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_5.jpg [14:22:05.764] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.765] AnimatedImageFrame[image] :: _init(), END [14:22:05.765] AnimatedImageFrame[image] :: constructor() [14:22:05.765] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.765] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_6.jpg [14:22:05.797] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.798] AnimatedImageFrame[image] :: _init(), END [14:22:05.799] AnimatedImageFrame[image] :: constructor() [14:22:05.799] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.799] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_7.jpg [14:22:05.830] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.831] AnimatedImageFrame[image] :: _init(), END [14:22:05.832] AnimatedImageFrame[image] :: constructor() [14:22:05.832] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.832] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_8.jpg [14:22:05.865] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.865] AnimatedImageFrame[image] :: _init(), END [14:22:05.866] AnimatedImageFrame[image] :: constructor() [14:22:05.866] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.866] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_9.jpg [14:22:05.900] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.901] AnimatedImageFrame[image] :: _init(), END [14:22:05.902] AnimatedImageFrame[image] :: constructor() [14:22:05.902] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.902] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_10.jpg [14:22:05.938] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.939] AnimatedImageFrame[image] :: _init(), END [14:22:05.939] AnimatedImageFrame[image] :: constructor() [14:22:05.940] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.940] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_11.jpg [14:22:05.986] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:05.988] AnimatedImageFrame[image] :: _init(), END [14:22:05.989] AnimatedImageFrame[image] :: constructor() [14:22:05.989] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:05.989] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_12.jpg [14:22:06.024] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:06.025] AnimatedImageFrame[image] :: _init(), END [14:22:06.025] AnimatedImageFrame[image] :: constructor() [14:22:06.026] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:06.026] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_13.jpg [14:22:06.061] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:06.062] AnimatedImageFrame[image] :: _init(), END [14:22:06.062] AnimatedImageFrame[image] :: constructor() [14:22:06.062] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:06.062] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_14.jpg [14:22:06.097] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:06.098] AnimatedImageFrame[image] :: _init(), END [14:22:06.098] AnimatedImageFrame[image] :: constructor() [14:22:06.098] AnimatedImageFrame[image] :: _init(), BEGIN [14:22:06.098] CanvasClip :: LoadImageWithPromise(), src: FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5_15.jpg [14:22:06.132] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [14:22:06.133] AnimatedImageFrame[image] :: _init(), END [14:22:06.133] MiraSlideshow[mira] :: _build(), END [14:22:06.133] Overlay[mira] :: _animate() [14:22:06.134] MiraSlideshow[mira] :: _init(), END [14:22:06.134] CanvasStream[mira] :: _init(), p.then() [14:22:06.134] CanvasStream[canvas_22681376957] :: _init(), promise.all.then() [14:22:06.136] CanvasStream[canvas_22681376957] :: _init(), END [14:22:06.136] StreamMangaer :: init(), stream[canvas_22681376957].then() [14:22:06.136] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_22681376957', progress: 1 } [14:22:06.136] index :: _onStepProgress_vidbot(), percent: 100 [14:22:06.136] StreamManager :: init(), promise.all.then... [14:22:06.136] Vidbot :: StreamMgr.on( 'INITED' ) [14:22:06.136] Vidbot :: _next(), _stepIndex:2 of 4 [14:22:06.137] index :: _onStepCompleted_vidbot(), step: 2 [14:22:06.137] index :: _onStepStarted_vidbot(), step: 3 [14:22:06.137] Vidbot :: step[2], label:Rendering Canvas Streams [14:22:06.137] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [14:22:06.137] StreamManager :: render() [14:22:06.138] CanvasStream[canvas_22681376957] :: render() [14:22:06.197] index :: _onStepProgress_vidbot(), percent: 0 [14:22:32.821] index :: _onStepProgress_vidbot(), percent: 5 [14:22:56.113] index :: _onStepProgress_vidbot(), percent: 10 [14:23:29.871] index :: _onStepProgress_vidbot(), percent: 15 [14:24:05.308] index :: _onStepProgress_vidbot(), percent: 20 [14:24:41.014] index :: _onStepProgress_vidbot(), percent: 25 [14:25:13.464] index :: _onStepProgress_vidbot(), percent: 30 [14:25:47.406] index :: _onStepProgress_vidbot(), percent: 35 [14:26:22.684] index :: _onStepProgress_vidbot(), percent: 40 [14:26:58.692] index :: _onStepProgress_vidbot(), percent: 45 [14:27:39.804] index :: _onStepProgress_vidbot(), percent: 50 [14:28:17.545] index :: _onStepProgress_vidbot(), percent: 55 [14:28:55.131] index :: _onStepProgress_vidbot(), percent: 60 [14:29:34.165] index :: _onStepProgress_vidbot(), percent: 65 [14:30:16.131] index :: _onStepProgress_vidbot(), percent: 70 [14:30:56.257] index :: _onStepProgress_vidbot(), percent: 75 [14:31:36.437] index :: _onStepProgress_vidbot(), percent: 80 [14:32:13.824] index :: _onStepProgress_vidbot(), percent: 85 [14:32:50.280] index :: _onStepProgress_vidbot(), percent: 90 [14:33:28.719] index :: _onStepProgress_vidbot(), percent: 95 [14:34:07.091] index :: _onStepProgress_vidbot(), percent: 100 [14:34:11.361] StreamManager :: render(), Promise.all.then... [14:34:11.362] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [14:34:11.362] Vidbot :: _next(), _stepIndex:3 of 4 [14:34:11.362] index :: _onStepCompleted_vidbot(), step: 3 [14:34:11.363] index :: _onStepStarted_vidbot(), step: 4 [14:34:11.364] Vidbot :: step[3], label:Encoding Media [14:34:11.366] CanvasFilters :: Overlay() [14:34:11.367] AudioStream[audio_vo] :: inputOptions() [14:34:11.367] AudioFilters :: Volume() [14:34:11.367] filter: [2:a]volume=1[2_vol] [14:34:11.367] AudioFilters :: Delay() [14:34:11.367] filter: [2_vol]adelay=0|0[2_del] [14:34:11.368] AudioStream[bg_music] :: inputOptions() [14:34:11.368] AudioFilters :: Volume() [14:34:11.368] filter: [3:a]volume=0.15[3_vol] [14:34:11.368] AudioFilters :: FadeOut() [14:34:11.368] filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout] [14:34:11.368] AudioFilters :: Delay() [14:34:11.368] filter: [3_fadeout]adelay=0|0[3_del] [14:34:11.368] AudioFilters :: Mix() [14:34:11.368] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [14:34:11.369] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [14:34:11.371] hang.time: 60 [14:34:11.525] Vidbot :: ffmpeg.on( 'start' ) [14:34:11.525] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=60 -r 30 -i ./tmp/canvas_22681376957_%05d.png -to 00:01:00.000 -i file:///var/www/html/clien [14:34:11.525] ts/21625/audio/FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF6_Rock.mp [14:34:11.525] 3 -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=out:st=60:d [14:34:11.525] =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_out] - [14:34:11.525] map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/21625/video/FF64CF8C-96ED-01FD-B4BA-50E [14:34:11.525] C44AC5EF5.mp4 [14:34:11.772] index :: _onStepProgress_vidbot(), percent: -3462080762 [14:34:12.181] index :: _onStepProgress_vidbot(), percent: 1 [14:34:13.693] index :: _onStepProgress_vidbot(), percent: 6 [14:34:15.196] index :: _onStepProgress_vidbot(), percent: 10 [14:34:16.715] index :: _onStepProgress_vidbot(), percent: 16 [14:34:17.733] index :: _onStepProgress_vidbot(), percent: 20 [14:34:19.251] index :: _onStepProgress_vidbot(), percent: 25 [14:34:20.787] index :: _onStepProgress_vidbot(), percent: 31 [14:34:22.324] index :: _onStepProgress_vidbot(), percent: 35 [14:34:23.849] index :: _onStepProgress_vidbot(), percent: 40 [14:34:25.363] index :: _onStepProgress_vidbot(), percent: 46 [14:34:26.365] index :: _onStepProgress_vidbot(), percent: 50 [14:34:27.376] index :: _onStepProgress_vidbot(), percent: 55 [14:34:28.394] index :: _onStepProgress_vidbot(), percent: 60 [14:34:29.917] index :: _onStepProgress_vidbot(), percent: 67 [14:34:30.928] index :: _onStepProgress_vidbot(), percent: 71 [14:34:31.931] index :: _onStepProgress_vidbot(), percent: 75 [14:34:33.451] index :: _onStepProgress_vidbot(), percent: 80 [14:34:34.974] index :: _onStepProgress_vidbot(), percent: 86 [14:34:36.497] index :: _onStepProgress_vidbot(), percent: 91 [14:34:37.509] index :: _onStepProgress_vidbot(), percent: 95 [14:34:38.887] index :: _onStepProgress_vidbot(), percent: 100 [14:34:38.919] Vidbot :: ffmpeg.on( 'end' ), Done! [14:34:38.919] StreamManager :: dispose() [14:34:38.920] CanvasStream[canvas_22681376957] :: dispose() [14:34:38.924] Vidbot :: fflog.on( 'finish' ) [14:34:38.925] fflog.path: /var/www/html/clients/21625/video/FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5.mp4.fflog [14:34:38.925] Vidbot :: _next(), _stepIndex:4 of 4 [14:34:38.925] index :: _onStepCompleted_vidbot(), step: 4 [14:34:38.925] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 753.7, output: '/var/www/html/clients/21625/video/FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5.mp4', duration: 60 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/21625/video/FF64CF8C-96ED-01FD-B4BA-50EC44AC5EF5.mp4 Media Duration : 00:01:00.000 Generation Time : 00:12:33.700 ---------------------------------------------------------------------------------------------------------------