--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [09:42:27.240] Vidbot :: start() [09:42:27.240] Vidbot :: _next(), _stepIndex:0 of 4 [09:42:27.240] index :: _onStepStarted_vidbot(), step: 1 [09:42:27.242] Vidbot :: step[0], label:Initializing Core [09:42:27.250] index :: _onStepProgress_vidbot(), percent: 20 [09:42:27.250] Vidbot :: _parse() [09:42:27.252] index :: _onStepProgress_vidbot(), percent: 40 [09:42:27.252] Vidbot :: _validate() [09:42:27.253] index :: _onStepProgress_vidbot(), percent: 60 [09:42:27.253] Vidbot :: _fonts() [09:42:27.253] FabricFontManager :: add(), id: SourceSansPro-Bold [09:42:27.253] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [09:42:27.262] FabricFontManager :: add(), id: SourceSansPro-Light [09:42:27.262] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [09:42:27.263] FabricFontManager :: add(), id: DINOT-Bold [09:42:27.263] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [09:42:27.264] FabricFontManager :: add(), id: DINOT-Light [09:42:27.264] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [09:42:27.265] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [09:42:27.265] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [09:42:27.266] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [09:42:27.266] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [09:42:27.267] index :: _onStepProgress_vidbot(), percent: 80 [09:42:27.267] Vidbot :: _clips() [09:42:27.268] StreamManager :: add(), id:audio_vo, type:audio [09:42:27.268] AudioClip[audio_vo] :: constructor() [09:42:27.269] InputStream[audio_vo] :: constructor() [09:42:27.269] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [09:42:27.271] StreamManager :: add(), id:bg_music, type:audio [09:42:27.271] AudioClip[bg_music] :: constructor() [09:42:27.271] InputStream[bg_music] :: constructor() [09:42:27.272] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [09:42:27.272] StreamManager :: add(), id:mira, type:canvas [09:42:27.272] CanvasStream[canvas_525946477345] :: constructor() [09:42:27.272] InputStream[canvas_525946477345] :: constructor() [09:42:27.351] MiraSlideshow[mira] :: constructor() [09:42:27.351] Mira[mira] :: constructor() [09:42:27.351] Overlay[mira] :: constructor() [09:42:27.351] CanvasClip[mira] :: constructor() [09:42:27.351] Clip[mira] :: constructor() [09:42:27.352] clip:"mira" added to stream:"canvas_525946477345" [09:42:27.352] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_525946477345', clipId: 'mira' } [09:42:27.352] all added... [09:42:27.352] Vidbot :: _next(), _stepIndex:1 of 4 [09:42:27.352] index :: _onStepCompleted_vidbot(), step: 1 [09:42:27.352] index :: _onStepStarted_vidbot(), step: 2 [09:42:27.353] Vidbot :: step[1], label:Initializing Input Streams [09:42:27.353] StreamManager :: init() [09:42:27.353] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [09:42:27.354] index :: _onStepProgress_vidbot(), percent: 33 [09:42:27.354] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [09:42:27.354] index :: _onStepProgress_vidbot(), percent: 67 [09:42:27.354] CanvasStream[canvas_525946477345] :: _init(), BEGIN [09:42:27.354] i:0, c.id:mira [09:42:27.355] MiraSlideshow[mira] :: _init(), BEGIN [09:42:27.355] MiraSlideshow[mira] :: _validate() [09:42:27.357] MiraSlideshow :: _validateSlides() [09:42:27.357] i:0, s.type: title [09:42:27.357] i:1, s.type: info [09:42:27.357] i:2, s.type: image [09:42:27.357] i:3, s.type: image [09:42:27.357] i:4, s.type: image [09:42:27.357] i:5, s.type: image [09:42:27.357] i:6, s.type: image [09:42:27.357] i:7, s.type: image [09:42:27.357] i:8, s.type: image [09:42:27.357] i:9, s.type: image [09:42:27.357] i:10, s.type: image [09:42:27.357] i:11, s.type: image [09:42:27.357] i:12, s.type: image [09:42:27.357] i:13, s.type: image [09:42:27.357] i:14, s.type: image [09:42:27.358] i:15, s.type: image [09:42:27.358] i:16, s.type: image [09:42:27.361] MiraSlideshow[mira] :: _build(), BEGIN [09:42:27.366] MiraTitlecard[titlecard] :: constructor() [09:42:27.366] Mira[titlecard] :: constructor() [09:42:27.366] Overlay[titlecard] :: constructor() [09:42:27.366] CanvasClip[titlecard] :: constructor() [09:42:27.366] Clip[titlecard] :: constructor() [09:42:27.366] MiraTitlecard[titlecard] :: _init() [09:42:27.366] MiraTitlecard[titlecard] :: _validate() [09:42:27.367] MiraTitlecard[titlecard] :: _build() [09:42:27.395] Overlay[titlecard] :: _animate() [09:42:27.397] MiraTitlecard[titlecard] :: _animate() [09:42:27.399] AnimatedImageFrame[aiftitle] :: constructor() [09:42:27.400] AnimatedImageFrame[aiftitle] :: _init(), BEGIN [09:42:27.400] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_1.jpg [09:42:27.450] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.455] AnimatedImageFrame[aiftitle] :: _init(), END [09:42:27.459] MiraInfosheet[info] :: constructor() [09:42:27.460] Mira[info] :: constructor() [09:42:27.460] Overlay[info] :: constructor() [09:42:27.460] CanvasClip[info] :: constructor() [09:42:27.460] Clip[info] :: constructor() [09:42:27.460] MiraInfosheet[info] :: _init() [09:42:27.460] MiraInfosheet[info] :: _validate() [09:42:27.462] MiraInfosheet[info] :: _build() [09:42:27.473] RenOptions[info] :: _animate() [09:42:27.473] Overlay[info] :: _animate() [09:42:27.475] AnimatedImageFrame[info1] :: constructor() [09:42:27.476] AnimatedImageFrame[info2] :: constructor() [09:42:27.476] AnimatedImageFrame[info3] :: constructor() [09:42:27.476] AnimatedImageFrame[info1] :: _init(), BEGIN [09:42:27.476] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_6.jpg [09:42:27.510] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.512] AnimatedImageFrame[info1] :: _init(), END [09:42:27.512] AnimatedImageFrame[info2] :: _init(), BEGIN [09:42:27.512] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_12.jpg [09:42:27.546] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.547] AnimatedImageFrame[info2] :: _init(), END [09:42:27.547] AnimatedImageFrame[info3] :: _init(), BEGIN [09:42:27.547] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_13.jpg [09:42:27.583] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.584] AnimatedImageFrame[info3] :: _init(), END [09:42:27.586] AnimatedImageFrame[image] :: constructor() [09:42:27.586] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.586] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_1.jpg [09:42:27.621] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.623] AnimatedImageFrame[image] :: _init(), END [09:42:27.623] AnimatedImageFrame[image] :: constructor() [09:42:27.623] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.623] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_2.jpg [09:42:27.655] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.656] AnimatedImageFrame[image] :: _init(), END [09:42:27.657] AnimatedImageFrame[image] :: constructor() [09:42:27.657] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.657] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_3.jpg [09:42:27.689] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.690] AnimatedImageFrame[image] :: _init(), END [09:42:27.691] AnimatedImageFrame[image] :: constructor() [09:42:27.691] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.691] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_4.jpg [09:42:27.724] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.725] AnimatedImageFrame[image] :: _init(), END [09:42:27.726] AnimatedImageFrame[image] :: constructor() [09:42:27.726] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.726] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_5.jpg [09:42:27.758] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.759] AnimatedImageFrame[image] :: _init(), END [09:42:27.760] AnimatedImageFrame[image] :: constructor() [09:42:27.760] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.760] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_6.jpg [09:42:27.796] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.797] AnimatedImageFrame[image] :: _init(), END [09:42:27.798] AnimatedImageFrame[image] :: constructor() [09:42:27.798] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.798] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_7.jpg [09:42:27.825] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.826] AnimatedImageFrame[image] :: _init(), END [09:42:27.827] AnimatedImageFrame[image] :: constructor() [09:42:27.827] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.827] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_8.jpg [09:42:27.856] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.857] AnimatedImageFrame[image] :: _init(), END [09:42:27.858] AnimatedImageFrame[image] :: constructor() [09:42:27.858] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.858] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_9.jpg [09:42:27.885] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.886] AnimatedImageFrame[image] :: _init(), END [09:42:27.888] AnimatedImageFrame[image] :: constructor() [09:42:27.888] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.888] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_10.jpg [09:42:27.919] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.920] AnimatedImageFrame[image] :: _init(), END [09:42:27.920] AnimatedImageFrame[image] :: constructor() [09:42:27.920] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.921] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_11.jpg [09:42:27.949] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.950] AnimatedImageFrame[image] :: _init(), END [09:42:27.950] AnimatedImageFrame[image] :: constructor() [09:42:27.950] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.950] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_12.jpg [09:42:27.982] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:27.984] AnimatedImageFrame[image] :: _init(), END [09:42:27.985] AnimatedImageFrame[image] :: constructor() [09:42:27.985] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:27.985] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_13.jpg [09:42:28.040] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:28.041] AnimatedImageFrame[image] :: _init(), END [09:42:28.042] AnimatedImageFrame[image] :: constructor() [09:42:28.042] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:28.042] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_14.jpg [09:42:28.085] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:28.086] AnimatedImageFrame[image] :: _init(), END [09:42:28.087] AnimatedImageFrame[image] :: constructor() [09:42:28.087] AnimatedImageFrame[image] :: _init(), BEGIN [09:42:28.087] CanvasClip :: LoadImageWithPromise(), src: 2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8_15.jpg [09:42:28.115] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [09:42:28.116] AnimatedImageFrame[image] :: _init(), END [09:42:28.117] MiraSlideshow[mira] :: _build(), END [09:42:28.117] Overlay[mira] :: _animate() [09:42:28.117] MiraSlideshow[mira] :: _init(), END [09:42:28.118] CanvasStream[mira] :: _init(), p.then() [09:42:28.118] CanvasStream[canvas_525946477345] :: _init(), promise.all.then() [09:42:28.119] CanvasStream[canvas_525946477345] :: _init(), END [09:42:28.119] StreamMangaer :: init(), stream[canvas_525946477345].then() [09:42:28.119] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_525946477345', progress: 1 } [09:42:28.120] index :: _onStepProgress_vidbot(), percent: 100 [09:42:28.120] StreamManager :: init(), promise.all.then... [09:42:28.120] Vidbot :: StreamMgr.on( 'INITED' ) [09:42:28.120] Vidbot :: _next(), _stepIndex:2 of 4 [09:42:28.120] index :: _onStepCompleted_vidbot(), step: 2 [09:42:28.120] index :: _onStepStarted_vidbot(), step: 3 [09:42:28.120] Vidbot :: step[2], label:Rendering Canvas Streams [09:42:28.121] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [09:42:28.121] StreamManager :: render() [09:42:28.122] CanvasStream[canvas_525946477345] :: render() [09:42:28.184] index :: _onStepProgress_vidbot(), percent: 0 [09:42:58.920] index :: _onStepProgress_vidbot(), percent: 5 [09:43:21.725] index :: _onStepProgress_vidbot(), percent: 10 [09:44:00.356] index :: _onStepProgress_vidbot(), percent: 15 [09:44:40.844] index :: _onStepProgress_vidbot(), percent: 20 [09:45:18.463] index :: _onStepProgress_vidbot(), percent: 25 [09:45:55.830] index :: _onStepProgress_vidbot(), percent: 30 [09:46:29.763] index :: _onStepProgress_vidbot(), percent: 35 [09:47:05.363] index :: _onStepProgress_vidbot(), percent: 40 [09:47:40.528] index :: _onStepProgress_vidbot(), percent: 45 [09:48:18.536] index :: _onStepProgress_vidbot(), percent: 50 [09:48:57.064] index :: _onStepProgress_vidbot(), percent: 55 [09:49:32.966] index :: _onStepProgress_vidbot(), percent: 60 [09:50:06.376] index :: _onStepProgress_vidbot(), percent: 65 [09:50:32.162] index :: _onStepProgress_vidbot(), percent: 70 [09:51:14.549] index :: _onStepProgress_vidbot(), percent: 75 [09:51:52.929] index :: _onStepProgress_vidbot(), percent: 80 [09:52:29.373] index :: _onStepProgress_vidbot(), percent: 85 [09:53:08.252] index :: _onStepProgress_vidbot(), percent: 90 [09:53:50.393] index :: _onStepProgress_vidbot(), percent: 95 [09:54:32.160] index :: _onStepProgress_vidbot(), percent: 100 [09:54:36.325] StreamManager :: render(), Promise.all.then... [09:54:36.326] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [09:54:36.326] Vidbot :: _next(), _stepIndex:3 of 4 [09:54:36.326] index :: _onStepCompleted_vidbot(), step: 3 [09:54:36.327] index :: _onStepStarted_vidbot(), step: 4 [09:54:36.328] Vidbot :: step[3], label:Encoding Media [09:54:36.330] CanvasFilters :: Overlay() [09:54:36.331] AudioStream[audio_vo] :: inputOptions() [09:54:36.331] AudioFilters :: Volume() [09:54:36.331] filter: [2:a]volume=1[2_vol] [09:54:36.331] AudioFilters :: Delay() [09:54:36.331] filter: [2_vol]adelay=0|0[2_del] [09:54:36.331] AudioStream[bg_music] :: inputOptions() [09:54:36.332] AudioFilters :: Volume() [09:54:36.332] filter: [3:a]volume=0.15[3_vol] [09:54:36.332] AudioFilters :: FadeOut() [09:54:36.332] filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout] [09:54:36.332] AudioFilters :: Delay() [09:54:36.332] filter: [3_fadeout]adelay=0|0[3_del] [09:54:36.332] AudioFilters :: Mix() [09:54:36.332] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [09:54:36.332] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [09:54:36.335] hang.time: 60 [09:54:36.481] Vidbot :: ffmpeg.on( 'start' ) [09:54:36.481] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=60 -r 30 -i ./tmp/canvas_525946477345_%05d.png -to 00:01:00.000 -i file:///var/www/html/clie [09:54:36.481] nts/21594/audio/2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF5_Lounge [09:54:36.481] _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.15[3_vol];[3_vol]afade=t=out [09:54:36.481] :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 -map [ [09:54:36.481] a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/21594/video/2E6F1E5B-8B4A-8050- [09:54:36.481] A11D-C03DEBC631F8.mp4 [09:54:36.787] index :: _onStepProgress_vidbot(), percent: -3462080762 [09:54:37.152] index :: _onStepProgress_vidbot(), percent: 1 [09:54:38.662] index :: _onStepProgress_vidbot(), percent: 5 [09:54:40.178] index :: _onStepProgress_vidbot(), percent: 10 [09:54:41.694] index :: _onStepProgress_vidbot(), percent: 15 [09:54:43.710] index :: _onStepProgress_vidbot(), percent: 21 [09:54:45.234] index :: _onStepProgress_vidbot(), percent: 25 [09:54:46.784] index :: _onStepProgress_vidbot(), percent: 30 [09:54:48.294] index :: _onStepProgress_vidbot(), percent: 36 [09:54:49.294] index :: _onStepProgress_vidbot(), percent: 40 [09:54:50.304] index :: _onStepProgress_vidbot(), percent: 45 [09:54:51.320] index :: _onStepProgress_vidbot(), percent: 50 [09:54:52.328] index :: _onStepProgress_vidbot(), percent: 55 [09:54:53.844] index :: _onStepProgress_vidbot(), percent: 61 [09:54:54.846] index :: _onStepProgress_vidbot(), percent: 66 [09:54:55.849] index :: _onStepProgress_vidbot(), percent: 72 [09:54:56.349] index :: _onStepProgress_vidbot(), percent: 75 [09:54:57.366] index :: _onStepProgress_vidbot(), percent: 80 [09:54:58.366] index :: _onStepProgress_vidbot(), percent: 86 [09:54:59.382] index :: _onStepProgress_vidbot(), percent: 91 [09:55:00.391] index :: _onStepProgress_vidbot(), percent: 97 [09:55:01.046] index :: _onStepProgress_vidbot(), percent: 100 [09:55:01.082] Vidbot :: ffmpeg.on( 'end' ), Done! [09:55:01.083] StreamManager :: dispose() [09:55:01.083] CanvasStream[canvas_525946477345] :: dispose() [09:55:01.088] Vidbot :: fflog.on( 'finish' ) [09:55:01.088] fflog.path: /var/www/html/clients/21594/video/2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8.mp4.fflog [09:55:01.088] Vidbot :: _next(), _stepIndex:4 of 4 [09:55:01.088] index :: _onStepCompleted_vidbot(), step: 4 [09:55:01.088] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 753.867, output: '/var/www/html/clients/21594/video/2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8.mp4', duration: 60 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/21594/video/2E6F1E5B-8B4A-8050-A11D-C03DEBC631F8.mp4 Media Duration : 00:01:00.000 Generation Time : 00:12:33.866 ---------------------------------------------------------------------------------------------------------------