--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.0... --------------------------------------------------------------------------------------------------------------- [10:01:13.735] Vidbot :: start() [10:01:13.735] Vidbot :: _next(), _stepIndex:0 of 4 [10:01:13.735] index :: _onStepStarted_vidbot(), step: 1 [10:01:13.737] Vidbot :: step[0], label:Initializing Core [10:01:13.744] index :: _onStepProgress_vidbot(), percent: 20 [10:01:13.745] Vidbot :: _parse() [10:01:13.746] index :: _onStepProgress_vidbot(), percent: 40 [10:01:13.746] Vidbot :: _validate() [10:01:13.747] index :: _onStepProgress_vidbot(), percent: 60 [10:01:13.747] Vidbot :: _fonts() [10:01:13.747] FabricFontManager :: add(), id: SourceSansPro-Bold [10:01:13.747] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [10:01:13.755] FabricFontManager :: add(), id: SourceSansPro-Light [10:01:13.755] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [10:01:13.756] FabricFontManager :: add(), id: DINOT-Bold [10:01:13.756] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [10:01:13.757] FabricFontManager :: add(), id: DINOT-Light [10:01:13.757] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [10:01:13.758] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [10:01:13.758] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [10:01:13.759] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [10:01:13.759] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [10:01:13.760] index :: _onStepProgress_vidbot(), percent: 80 [10:01:13.760] Vidbot :: _clips() [10:01:13.760] StreamManager :: add(), id:audio_vo, type:audio [10:01:13.761] AudioClip[audio_vo] :: constructor() [10:01:13.761] InputStream[audio_vo] :: constructor() [10:01:13.761] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [10:01:13.764] StreamManager :: add(), id:bg_music, type:audio [10:01:13.764] AudioClip[bg_music] :: constructor() [10:01:13.764] InputStream[bg_music] :: constructor() [10:01:13.764] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [10:01:13.764] StreamManager :: add(), id:simplefadedisplay, type:canvas [10:01:13.765] CanvasStream[canvas_1508707201993] :: constructor() [10:01:13.765] InputStream[canvas_1508707201993] :: constructor() [10:01:13.841] KenBurnsSlideshow[simplefadedisplay] :: constructor() [10:01:13.841] Overlay[simplefadedisplay] :: constructor() [10:01:13.841] CanvasClip[simplefadedisplay] :: constructor() [10:01:13.841] Clip[simplefadedisplay] :: constructor() [10:01:13.841] clip:"simplefadedisplay" added to stream:"canvas_1508707201993" [10:01:13.842] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1508707201993', clipId: 'simplefadedisplay' } [10:01:13.842] StreamManager :: add(), id:caption, type:canvas [10:01:13.842] RenCaption[caption] :: constructor() [10:01:13.842] Ren[caption] :: constructor() [10:01:13.842] Overlay[caption] :: constructor() [10:01:13.842] CanvasClip[caption] :: constructor() [10:01:13.842] Clip[caption] :: constructor() [10:01:13.843] clip:"caption" added to stream:"canvas_1508707201993" [10:01:13.843] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1508707201993', clipId: 'caption' } [10:01:13.843] all added... [10:01:13.843] Vidbot :: _next(), _stepIndex:1 of 4 [10:01:13.843] index :: _onStepCompleted_vidbot(), step: 1 [10:01:13.843] index :: _onStepStarted_vidbot(), step: 2 [10:01:13.844] Vidbot :: step[1], label:Initializing Input Streams [10:01:13.844] StreamManager :: init() [10:01:13.845] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [10:01:13.845] index :: _onStepProgress_vidbot(), percent: 33 [10:01:13.845] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [10:01:13.845] index :: _onStepProgress_vidbot(), percent: 67 [10:01:13.845] CanvasStream[canvas_1508707201993] :: _init(), BEGIN [10:01:13.846] i:0, c.id:simplefadedisplay [10:01:13.846] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [10:01:13.846] KenBurnsSlideshow[simplefadedisplay] :: _validate() [10:01:13.847] KenBurnsSlideshow[undefined] :: _validateAnim() [10:01:13.847] KenBurnsSlideshow[undefined] :: _validateTheme() [10:01:13.849] i:1, c.id:caption [10:01:13.849] RenCaption[caption] :: _init() [10:01:13.849] RenCaption[caption] :: _validate() [10:01:13.850] KenBurnsSlideshow[simplefadedisplay] :: _build() [10:01:13.857] AnimatedImageFrame[aif] :: constructor() [10:01:13.858] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:13.858] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_1.jpg [10:01:13.870] RenCaption[caption] :: _build() [10:01:13.887] Overlay[caption] :: _animate() [10:01:13.889] CanvasStream[caption] :: _init(), p.then() [10:01:13.906] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:13.909] AnimatedImageFrame[aif] :: _init(), END [10:01:13.910] AnimatedImageFrame[aif] :: constructor() [10:01:13.910] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:13.910] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_2.jpg [10:01:13.929] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:13.930] AnimatedImageFrame[aif] :: _init(), END [10:01:13.931] AnimatedImageFrame[aif] :: constructor() [10:01:13.931] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:13.931] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_3.jpg [10:01:13.947] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:13.949] AnimatedImageFrame[aif] :: _init(), END [10:01:13.949] AnimatedImageFrame[aif] :: constructor() [10:01:13.950] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:13.950] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_4.jpg [10:01:13.967] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:13.968] AnimatedImageFrame[aif] :: _init(), END [10:01:13.968] AnimatedImageFrame[aif] :: constructor() [10:01:13.969] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:13.969] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_5.jpg [10:01:13.986] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:13.987] AnimatedImageFrame[aif] :: _init(), END [10:01:13.988] AnimatedImageFrame[aif] :: constructor() [10:01:13.988] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:13.988] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_6.jpg [10:01:14.005] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.006] AnimatedImageFrame[aif] :: _init(), END [10:01:14.007] AnimatedImageFrame[aif] :: constructor() [10:01:14.007] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.007] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_7.jpg [10:01:14.023] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.024] AnimatedImageFrame[aif] :: _init(), END [10:01:14.025] AnimatedImageFrame[aif] :: constructor() [10:01:14.025] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.025] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_8.jpg [10:01:14.042] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.043] AnimatedImageFrame[aif] :: _init(), END [10:01:14.044] AnimatedImageFrame[aif] :: constructor() [10:01:14.044] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.044] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_9.jpg [10:01:14.059] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.060] AnimatedImageFrame[aif] :: _init(), END [10:01:14.060] AnimatedImageFrame[aif] :: constructor() [10:01:14.061] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.061] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_10.jpg [10:01:14.077] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.078] AnimatedImageFrame[aif] :: _init(), END [10:01:14.079] AnimatedImageFrame[aif] :: constructor() [10:01:14.079] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.079] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_11.jpg [10:01:14.097] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.098] AnimatedImageFrame[aif] :: _init(), END [10:01:14.099] AnimatedImageFrame[aif] :: constructor() [10:01:14.099] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.099] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_12.jpg [10:01:14.116] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.117] AnimatedImageFrame[aif] :: _init(), END [10:01:14.117] AnimatedImageFrame[aif] :: constructor() [10:01:14.117] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.117] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_13.jpg [10:01:14.134] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.135] AnimatedImageFrame[aif] :: _init(), END [10:01:14.136] AnimatedImageFrame[aif] :: constructor() [10:01:14.136] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.136] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_14.jpg [10:01:14.155] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.156] AnimatedImageFrame[aif] :: _init(), END [10:01:14.156] AnimatedImageFrame[aif] :: constructor() [10:01:14.156] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.156] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_15.jpg [10:01:14.173] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.174] AnimatedImageFrame[aif] :: _init(), END [10:01:14.174] AnimatedImageFrame[aif] :: constructor() [10:01:14.175] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.175] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_16.jpg [10:01:14.190] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.191] AnimatedImageFrame[aif] :: _init(), END [10:01:14.192] AnimatedImageFrame[aif] :: constructor() [10:01:14.192] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.192] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_17.jpg [10:01:14.208] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.209] AnimatedImageFrame[aif] :: _init(), END [10:01:14.210] AnimatedImageFrame[aif] :: constructor() [10:01:14.210] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.210] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_18.jpg [10:01:14.227] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.228] AnimatedImageFrame[aif] :: _init(), END [10:01:14.229] AnimatedImageFrame[aif] :: constructor() [10:01:14.229] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.229] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_19.jpg [10:01:14.248] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.249] AnimatedImageFrame[aif] :: _init(), END [10:01:14.250] AnimatedImageFrame[aif] :: constructor() [10:01:14.250] AnimatedImageFrame[aif] :: _init(), BEGIN [10:01:14.250] CanvasClip :: LoadImageWithPromise(), src: D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5_20.jpg [10:01:14.265] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [10:01:14.266] AnimatedImageFrame[aif] :: _init(), END [10:01:14.266] Overlay[simplefadedisplay] :: _animate() [10:01:14.267] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [10:01:14.267] CanvasStream[simplefadedisplay] :: _init(), p.then() [10:01:14.267] CanvasStream[canvas_1508707201993] :: _init(), promise.all.then() [10:01:14.269] CanvasStream[canvas_1508707201993] :: _init(), END [10:01:14.270] StreamMangaer :: init(), stream[canvas_1508707201993].then() [10:01:14.270] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1508707201993', progress: 1 } [10:01:14.270] index :: _onStepProgress_vidbot(), percent: 100 [10:01:14.270] StreamManager :: init(), promise.all.then... [10:01:14.270] Vidbot :: StreamMgr.on( 'INITED' ) [10:01:14.270] Vidbot :: _next(), _stepIndex:2 of 4 [10:01:14.270] index :: _onStepCompleted_vidbot(), step: 2 [10:01:14.270] index :: _onStepStarted_vidbot(), step: 3 [10:01:14.271] Vidbot :: step[2], label:Rendering Canvas Streams [10:01:14.271] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [10:01:14.271] StreamManager :: render() [10:01:14.272] CanvasStream[canvas_1508707201993] :: render() [10:01:14.303] index :: _onStepProgress_vidbot(), percent: 0 [10:01:20.369] index :: _onStepProgress_vidbot(), percent: 5 [10:01:38.152] index :: _onStepProgress_vidbot(), percent: 10 [10:01:59.093] index :: _onStepProgress_vidbot(), percent: 15 [10:02:19.101] index :: _onStepProgress_vidbot(), percent: 20 [10:02:42.088] index :: _onStepProgress_vidbot(), percent: 25 [10:03:02.936] index :: _onStepProgress_vidbot(), percent: 30 [10:03:23.226] index :: _onStepProgress_vidbot(), percent: 35 [10:03:44.221] index :: _onStepProgress_vidbot(), percent: 40 [10:04:03.208] index :: _onStepProgress_vidbot(), percent: 45 [10:04:22.431] index :: _onStepProgress_vidbot(), percent: 50 [10:04:43.300] index :: _onStepProgress_vidbot(), percent: 55 [10:05:02.607] index :: _onStepProgress_vidbot(), percent: 60 [10:05:20.648] index :: _onStepProgress_vidbot(), percent: 65 [10:05:38.170] index :: _onStepProgress_vidbot(), percent: 70 [10:05:54.960] index :: _onStepProgress_vidbot(), percent: 75 [10:06:13.211] index :: _onStepProgress_vidbot(), percent: 80 [10:06:32.852] index :: _onStepProgress_vidbot(), percent: 85 [10:06:53.128] index :: _onStepProgress_vidbot(), percent: 90 [10:07:11.339] index :: _onStepProgress_vidbot(), percent: 95 [10:07:31.485] index :: _onStepProgress_vidbot(), percent: 100 [10:07:33.552] StreamManager :: render(), Promise.all.then... [10:07:33.552] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [10:07:33.553] Vidbot :: _next(), _stepIndex:3 of 4 [10:07:33.553] index :: _onStepCompleted_vidbot(), step: 3 [10:07:33.554] index :: _onStepStarted_vidbot(), step: 4 [10:07:33.555] Vidbot :: step[3], label:Encoding Media [10:07:33.557] CanvasFilters :: Overlay() [10:07:33.558] AudioStream[audio_vo] :: inputOptions() [10:07:33.558] AudioFilters :: Volume() [10:07:33.558] filter: [2:a]volume=1[2_vol] [10:07:33.558] AudioFilters :: Delay() [10:07:33.558] filter: [2_vol]adelay=0|0[2_del] [10:07:33.559] AudioStream[bg_music] :: inputOptions() [10:07:33.559] AudioFilters :: Volume() [10:07:33.559] filter: [3:a]volume=0.25[3_vol] [10:07:33.559] AudioFilters :: FadeOut() [10:07:33.559] filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout] [10:07:33.559] AudioFilters :: Delay() [10:07:33.559] filter: [3_fadeout]adelay=0|0[3_del] [10:07:33.559] AudioFilters :: Mix() [10:07:33.559] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [10:07:33.560] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [10:07:33.562] hang.time: 60 [10:07:33.704] Vidbot :: ffmpeg.on( 'start' ) [10:07:33.705] ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60 -r 30 -i ./tmp/canvas_1508707201993_%05d.png -to 00:01:00.000 -i file:///var/www/html/cli [10:07:33.705] ents/16182/audio/D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Rock.mp3 [10:07:33.705] -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=out:st=60:d=1 [10:07:33.705] [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] -ma [10:07:33.705] p [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/16182/video/D5EA1EB6-3D6C-0ABF-AB6F-E08A6 [10:07:33.705] DA3C9E5.mp4 [10:07:33.982] index :: _onStepProgress_vidbot(), percent: -3462080762 [10:07:34.318] index :: _onStepProgress_vidbot(), percent: 1 [10:07:35.872] index :: _onStepProgress_vidbot(), percent: 6 [10:07:36.876] index :: _onStepProgress_vidbot(), percent: 11 [10:07:37.879] index :: _onStepProgress_vidbot(), percent: 17 [10:07:38.380] index :: _onStepProgress_vidbot(), percent: 20 [10:07:39.391] index :: _onStepProgress_vidbot(), percent: 25 [10:07:40.907] index :: _onStepProgress_vidbot(), percent: 31 [10:07:41.913] index :: _onStepProgress_vidbot(), percent: 36 [10:07:42.926] index :: _onStepProgress_vidbot(), percent: 41 [10:07:44.430] index :: _onStepProgress_vidbot(), percent: 47 [10:07:44.939] index :: _onStepProgress_vidbot(), percent: 50 [10:07:45.945] index :: _onStepProgress_vidbot(), percent: 55 [10:07:46.952] index :: _onStepProgress_vidbot(), percent: 60 [10:07:47.955] index :: _onStepProgress_vidbot(), percent: 65 [10:07:48.959] index :: _onStepProgress_vidbot(), percent: 70 [10:07:49.975] index :: _onStepProgress_vidbot(), percent: 75 [10:07:50.990] index :: _onStepProgress_vidbot(), percent: 81 [10:07:51.993] index :: _onStepProgress_vidbot(), percent: 87 [10:07:52.503] index :: _onStepProgress_vidbot(), percent: 90 [10:07:53.506] index :: _onStepProgress_vidbot(), percent: 95 [10:07:54.415] index :: _onStepProgress_vidbot(), percent: 100 [10:07:54.448] Vidbot :: ffmpeg.on( 'end' ), Done! [10:07:54.448] StreamManager :: dispose() [10:07:54.449] CanvasStream[canvas_1508707201993] :: dispose() [10:07:54.453] Vidbot :: fflog.on( 'finish' ) [10:07:54.454] fflog.path: /var/www/html/clients/16182/video/D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5.mp4.fflog [10:07:54.454] Vidbot :: _next(), _stepIndex:4 of 4 [10:07:54.454] index :: _onStepCompleted_vidbot(), step: 4 [10:07:54.454] index :: _onComplete_vidbot(), data: { stepTime: 0, appTime: 400.738, output: '/var/www/html/clients/16182/video/D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5.mp4', duration: 60 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/16182/video/D5EA1EB6-3D6C-0ABF-AB6F-E08A6DA3C9E5.mp4 Media Duration : 00:01:00.000 Generation Time : 00:06:40.737 ---------------------------------------------------------------------------------------------------------------