--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [22:52:39.466] Vidbot :: start() [22:52:39.466] Vidbot :: _next(), _stepIndex:0 of 4 [22:52:39.467] index :: _onStepStarted_vidbot(), step: 1 [22:52:39.468] Vidbot :: step[0], label:Initializing Core [22:52:39.476] index :: _onStepProgress_vidbot(), percent: 20 [22:52:39.476] Vidbot :: _parse() [22:52:39.478] index :: _onStepProgress_vidbot(), percent: 40 [22:52:39.478] Vidbot :: _validate() [22:52:39.478] index :: _onStepProgress_vidbot(), percent: 60 [22:52:39.479] Vidbot :: _fonts() [22:52:39.479] FabricFontManager :: add(), id: SourceSansPro-Bold [22:52:39.479] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [22:52:39.487] FabricFontManager :: add(), id: SourceSansPro-Light [22:52:39.487] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [22:52:39.488] FabricFontManager :: add(), id: DINOT-Bold [22:52:39.488] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [22:52:39.489] FabricFontManager :: add(), id: DINOT-Light [22:52:39.489] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [22:52:39.489] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [22:52:39.489] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [22:52:39.490] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [22:52:39.490] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [22:52:39.491] index :: _onStepProgress_vidbot(), percent: 80 [22:52:39.491] Vidbot :: _clips() [22:52:39.492] StreamManager :: add(), id:audio_vo, type:audio [22:52:39.492] AudioClip[audio_vo] :: constructor() [22:52:39.492] InputStream[audio_vo] :: constructor() [22:52:39.493] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [22:52:39.495] StreamManager :: add(), id:bg_music, type:audio [22:52:39.495] AudioClip[bg_music] :: constructor() [22:52:39.495] InputStream[bg_music] :: constructor() [22:52:39.495] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [22:52:39.496] StreamManager :: add(), id:intro, type:video [22:52:39.496] VideoStream[intro] :: constructor() [22:52:39.496] InputStream[intro] :: constructor() [22:52:39.496] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'intro', clipId: null } [22:52:39.496] StreamManager :: add(), id:simplefadedisplay, type:canvas [22:52:39.496] CanvasStream[canvas_420183253263] :: constructor() [22:52:39.497] InputStream[canvas_420183253263] :: constructor() [22:52:39.571] KenBurnsSlideshow[simplefadedisplay] :: constructor() [22:52:39.571] Overlay[simplefadedisplay] :: constructor() [22:52:39.571] CanvasClip[simplefadedisplay] :: constructor() [22:52:39.571] Clip[simplefadedisplay] :: constructor() [22:52:39.571] clip:"simplefadedisplay" added to stream:"canvas_420183253263" [22:52:39.572] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_420183253263', clipId: 'simplefadedisplay' } [22:52:39.572] all added... [22:52:39.572] Vidbot :: _next(), _stepIndex:1 of 4 [22:52:39.572] index :: _onStepCompleted_vidbot(), step: 1 [22:52:39.572] index :: _onStepStarted_vidbot(), step: 2 [22:52:39.572] Vidbot :: step[1], label:Initializing Input Streams [22:52:39.573] StreamManager :: init() [22:52:39.573] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.25 } [22:52:39.573] index :: _onStepProgress_vidbot(), percent: 25 [22:52:39.573] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.5 } [22:52:39.574] index :: _onStepProgress_vidbot(), percent: 50 [22:52:39.574] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'intro', progress: 0.75 } [22:52:39.574] index :: _onStepProgress_vidbot(), percent: 75 [22:52:39.574] CanvasStream[canvas_420183253263] :: _init(), BEGIN [22:52:39.574] i:0, c.id:simplefadedisplay [22:52:39.575] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [22:52:39.575] KenBurnsSlideshow[simplefadedisplay] :: _validate() [22:52:39.575] KenBurnsSlideshow[undefined] :: _validateAnim() [22:52:39.576] KenBurnsSlideshow[undefined] :: _validateTheme() [22:52:39.577] KenBurnsSlideshow[simplefadedisplay] :: _build() [22:52:39.583] AnimatedImageFrame[aif] :: constructor() [22:52:39.584] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.584] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_1.jpg [22:52:39.620] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.624] AnimatedImageFrame[aif] :: _init(), END [22:52:39.626] AnimatedImageFrame[aif] :: constructor() [22:52:39.626] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.627] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_2.jpg [22:52:39.641] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.643] AnimatedImageFrame[aif] :: _init(), END [22:52:39.644] AnimatedImageFrame[aif] :: constructor() [22:52:39.644] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.644] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_3.jpg [22:52:39.658] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.660] AnimatedImageFrame[aif] :: _init(), END [22:52:39.660] AnimatedImageFrame[aif] :: constructor() [22:52:39.660] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.661] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_4.jpg [22:52:39.675] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.676] AnimatedImageFrame[aif] :: _init(), END [22:52:39.677] AnimatedImageFrame[aif] :: constructor() [22:52:39.677] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.677] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_5.jpg [22:52:39.697] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.698] AnimatedImageFrame[aif] :: _init(), END [22:52:39.698] AnimatedImageFrame[aif] :: constructor() [22:52:39.698] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.699] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_6.jpg [22:52:39.714] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.715] AnimatedImageFrame[aif] :: _init(), END [22:52:39.715] AnimatedImageFrame[aif] :: constructor() [22:52:39.715] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.716] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_7.jpg [22:52:39.730] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.731] AnimatedImageFrame[aif] :: _init(), END [22:52:39.731] AnimatedImageFrame[aif] :: constructor() [22:52:39.732] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.732] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_8.jpg [22:52:39.747] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.747] AnimatedImageFrame[aif] :: _init(), END [22:52:39.748] AnimatedImageFrame[aif] :: constructor() [22:52:39.748] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.748] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_9.jpg [22:52:39.762] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.763] AnimatedImageFrame[aif] :: _init(), END [22:52:39.764] AnimatedImageFrame[aif] :: constructor() [22:52:39.764] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.764] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_10.jpg [22:52:39.778] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.779] AnimatedImageFrame[aif] :: _init(), END [22:52:39.779] AnimatedImageFrame[aif] :: constructor() [22:52:39.779] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.780] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_11.jpg [22:52:39.795] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.796] AnimatedImageFrame[aif] :: _init(), END [22:52:39.797] AnimatedImageFrame[aif] :: constructor() [22:52:39.797] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.797] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_12.jpg [22:52:39.811] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.812] AnimatedImageFrame[aif] :: _init(), END [22:52:39.813] AnimatedImageFrame[aif] :: constructor() [22:52:39.813] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.813] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_13.jpg [22:52:39.828] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.829] AnimatedImageFrame[aif] :: _init(), END [22:52:39.830] AnimatedImageFrame[aif] :: constructor() [22:52:39.830] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.830] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_14.jpg [22:52:39.845] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.845] AnimatedImageFrame[aif] :: _init(), END [22:52:39.846] AnimatedImageFrame[aif] :: constructor() [22:52:39.846] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.846] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_15.jpg [22:52:39.861] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.862] AnimatedImageFrame[aif] :: _init(), END [22:52:39.863] AnimatedImageFrame[aif] :: constructor() [22:52:39.863] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.863] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_16.jpg [22:52:39.878] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.879] AnimatedImageFrame[aif] :: _init(), END [22:52:39.880] AnimatedImageFrame[aif] :: constructor() [22:52:39.880] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.880] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_17.jpg [22:52:39.894] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.895] AnimatedImageFrame[aif] :: _init(), END [22:52:39.895] AnimatedImageFrame[aif] :: constructor() [22:52:39.896] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.896] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_18.jpg [22:52:39.909] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.910] AnimatedImageFrame[aif] :: _init(), END [22:52:39.910] AnimatedImageFrame[aif] :: constructor() [22:52:39.910] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.910] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_19.jpg [22:52:39.927] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.928] AnimatedImageFrame[aif] :: _init(), END [22:52:39.929] AnimatedImageFrame[aif] :: constructor() [22:52:39.929] AnimatedImageFrame[aif] :: _init(), BEGIN [22:52:39.929] CanvasClip :: LoadImageWithPromise(), src: 55CD1E89-3443-709C-E1C5-447B58B3926F_20.jpg [22:52:39.948] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [22:52:39.949] AnimatedImageFrame[aif] :: _init(), END [22:52:39.950] Overlay[simplefadedisplay] :: _animate() [22:52:39.951] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [22:52:39.951] CanvasStream[simplefadedisplay] :: _init(), p.then() [22:52:39.951] CanvasStream[canvas_420183253263] :: _init(), promise.all.then() [22:52:39.952] CanvasStream[canvas_420183253263] :: _init(), END [22:52:39.953] StreamMangaer :: init(), stream[canvas_420183253263].then() [22:52:39.953] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_420183253263', progress: 1 } [22:52:39.953] index :: _onStepProgress_vidbot(), percent: 100 [22:52:39.953] StreamManager :: init(), promise.all.then... [22:52:39.953] Vidbot :: StreamMgr.on( 'INITED' ) [22:52:39.953] Vidbot :: _next(), _stepIndex:2 of 4 [22:52:39.953] index :: _onStepCompleted_vidbot(), step: 2 [22:52:39.954] index :: _onStepStarted_vidbot(), step: 3 [22:52:39.954] Vidbot :: step[2], label:Rendering Canvas Streams [22:52:39.954] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [22:52:39.954] StreamManager :: render() [22:52:39.955] CanvasStream[canvas_420183253263] :: render() [22:52:40.015] index :: _onStepProgress_vidbot(), percent: 0 [22:52:45.033] index :: _onStepProgress_vidbot(), percent: 5 [22:52:55.769] index :: _onStepProgress_vidbot(), percent: 10 [22:53:12.711] index :: _onStepProgress_vidbot(), percent: 15 [22:53:24.982] index :: _onStepProgress_vidbot(), percent: 20 [22:53:37.309] index :: _onStepProgress_vidbot(), percent: 25 [22:53:49.416] index :: _onStepProgress_vidbot(), percent: 30 [22:54:02.060] index :: _onStepProgress_vidbot(), percent: 35 [22:54:14.225] index :: _onStepProgress_vidbot(), percent: 40 [22:54:26.550] index :: _onStepProgress_vidbot(), percent: 45 [22:54:37.125] index :: _onStepProgress_vidbot(), percent: 50 [22:54:49.654] index :: _onStepProgress_vidbot(), percent: 55 [22:55:01.599] index :: _onStepProgress_vidbot(), percent: 60 [22:55:16.100] index :: _onStepProgress_vidbot(), percent: 65 [22:55:30.749] index :: _onStepProgress_vidbot(), percent: 70 [22:55:44.795] index :: _onStepProgress_vidbot(), percent: 75 [22:55:58.836] index :: _onStepProgress_vidbot(), percent: 80 [22:56:11.793] index :: _onStepProgress_vidbot(), percent: 85 [22:56:23.926] index :: _onStepProgress_vidbot(), percent: 90 [22:56:37.152] index :: _onStepProgress_vidbot(), percent: 95 [22:57:01.644] index :: _onStepProgress_vidbot(), percent: 100 [22:57:03.916] StreamManager :: render(), Promise.all.then... [22:57:03.917] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [22:57:03.917] Vidbot :: _next(), _stepIndex:3 of 4 [22:57:03.918] index :: _onStepCompleted_vidbot(), step: 3 [22:57:03.918] index :: _onStepStarted_vidbot(), step: 4 [22:57:03.919] Vidbot :: step[3], label:Encoding Media [22:57:03.922] VideoStream[intro] :: inputOptions() [22:57:03.923] VideoFilters :: Scale() [22:57:03.923] VideoFilters :: Overlay() [22:57:03.924] CanvasFilters :: Overlay() [22:57:03.925] AudioStream[audio_vo] :: inputOptions() [22:57:03.925] AudioFilters :: Volume() [22:57:03.925] filter: [3:a]volume=1[3_vol] [22:57:03.925] AudioFilters :: Delay() [22:57:03.925] filter: [3_vol]adelay=5030|5030[3_del] [22:57:03.926] AudioStream[bg_music] :: inputOptions() [22:57:03.926] AudioFilters :: Volume() [22:57:03.926] filter: [4:a]volume=0.25[4_vol] [22:57:03.926] AudioFilters :: FadeOut() [22:57:03.926] filter: [4_vol]afade=t=out:st=60:d=1[4_fadeout] [22:57:03.926] AudioFilters :: Delay() [22:57:03.926] filter: [4_fadeout]adelay=5030|5030[4_del] [22:57:03.927] VideoStream[intro] :: inputOptions() [22:57:03.927] AudioFilters :: Volume() [22:57:03.927] filter: [5:a]volume=1[5_vol] [22:57:03.927] AudioFilters :: Delay() [22:57:03.927] filter: [5_vol]adelay=0|0[5_del] [22:57:03.928] AudioFilters :: Mix() [22:57:03.928] filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [22:57:03.928] mixed filter: [3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] [22:57:03.931] hang.time: 60 [22:57:04.084] Vidbot :: ffmpeg.on( 'start' ) [22:57:04.085] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=65.03 -to 00:00:05.030 -i file:///var/www/html/clients/9660/library/960_intro.mp4 -r 30 -i . [22:57:04.085] /tmp/canvas_420183253263_%05d.png -to 00:01:00.000 -i file:///var/www/html/clients/9660/audio/55CD1E89-3443-709C-E1C5-447B58B3926F.mp3 -to 00:01:00.00 [22:57:04.085] 0 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Orchestra-3_30.mp3 -to 00:00:05.030 -i file:///var/www/html/clients/9660/library/9 [22:57:04.085] 60_intro.mp4 -y -filter_complex [1:v]scale=w=960:h=540[1_scaled];[0:v][1_scaled]overlay=x=0:y=0:enable='between(t,0,5.03)'[1_out];[1_out][2:v]overlay= [22:57:04.085] x=0:y=0[2_out];[3:a]volume=1[3_vol];[3_vol]adelay=5030|5030[3_del];[4:a]volume=0.25[4_vol];[4_vol]afade=t=out:st=60:d=1[4_fadeout];[4_fadeout]adelay=5 [22:57:04.085] 030|5030[4_del];[5:a]volume=1[5_vol];[5_vol]adelay=0|0[5_del];[3_del][4_del][5_del]amix=inputs=3:duration=longest[a_out] -acodec aac -vcodec libx264 - [22:57:04.085] r 30 -f mp4 -map [a_out] -map [2_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/9660/video/55 [22:57:04.085] CD1E89-3443-709C-E1C5-447B58B3926F.mp4 [22:57:04.760] index :: _onStepProgress_vidbot(), percent: -3194292568 [22:57:05.190] index :: _onStepProgress_vidbot(), percent: 1 [22:57:09.041] index :: _onStepProgress_vidbot(), percent: 5 [22:57:11.043] index :: _onStepProgress_vidbot(), percent: 10 [22:57:12.582] index :: _onStepProgress_vidbot(), percent: 16 [22:57:13.593] index :: _onStepProgress_vidbot(), percent: 20 [22:57:15.107] index :: _onStepProgress_vidbot(), percent: 26 [22:57:16.108] index :: _onStepProgress_vidbot(), percent: 30 [22:57:17.645] index :: _onStepProgress_vidbot(), percent: 36 [22:57:18.652] index :: _onStepProgress_vidbot(), percent: 40 [22:57:19.663] index :: _onStepProgress_vidbot(), percent: 45 [22:57:20.674] index :: _onStepProgress_vidbot(), percent: 51 [22:57:21.679] index :: _onStepProgress_vidbot(), percent: 56 [22:57:22.682] index :: _onStepProgress_vidbot(), percent: 61 [22:57:23.689] index :: _onStepProgress_vidbot(), percent: 66 [22:57:24.697] index :: _onStepProgress_vidbot(), percent: 71 [22:57:25.715] index :: _onStepProgress_vidbot(), percent: 76 [22:57:26.722] index :: _onStepProgress_vidbot(), percent: 80 [22:57:28.253] index :: _onStepProgress_vidbot(), percent: 87 [22:57:29.259] index :: _onStepProgress_vidbot(), percent: 91 [22:57:30.271] index :: _onStepProgress_vidbot(), percent: 97 [22:57:30.994] index :: _onStepProgress_vidbot(), percent: 100 [22:57:31.067] Vidbot :: ffmpeg.on( 'end' ), Done! [22:57:31.067] StreamManager :: dispose() [22:57:31.068] CanvasStream[canvas_420183253263] :: dispose() [22:57:31.073] Vidbot :: fflog.on( 'finish' ) [22:57:31.073] fflog.path: /var/www/html/clients/9660/video/55CD1E89-3443-709C-E1C5-447B58B3926F.mp4.fflog [22:57:31.073] Vidbot :: _next(), _stepIndex:4 of 4 [22:57:31.073] index :: _onStepCompleted_vidbot(), step: 4 [22:57:31.073] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 291.625, output: '/var/www/html/clients/9660/video/55CD1E89-3443-709C-E1C5-447B58B3926F.mp4', duration: 65.03 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/9660/video/55CD1E89-3443-709C-E1C5-447B58B3926F.mp4 Media Duration : 00:01:05.030 Generation Time : 00:04:51.625 ---------------------------------------------------------------------------------------------------------------