---------------------------------------------------------------------------------------------------------------
INITIALIZING VIDBOT, v1.7.0...
---------------------------------------------------------------------------------------------------------------
[18:48:54.559] Vidbot :: start()
[18:48:54.560] Vidbot :: _next(), _stepIndex:0 of 4
[18:48:54.560] index :: _onStepStarted_vidbot(), step: 1
[18:48:54.561] Vidbot :: step[0], label:Initializing Core
[18:48:54.573] index :: _onStepProgress_vidbot(), percent: 20
[18:48:54.573] Vidbot :: _parse()
[18:48:54.575] index :: _onStepProgress_vidbot(), percent: 40
[18:48:54.575] Vidbot :: _validate()
[18:48:54.576] index :: _onStepProgress_vidbot(), percent: 60
[18:48:54.576] Vidbot :: _fonts()
[18:48:54.576] FabricFontManager :: add(), id: SourceSansPro-Bold
[18:48:54.576]   src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf
[18:48:54.585] FabricFontManager :: add(), id: SourceSansPro-Light
[18:48:54.585]   src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf
[18:48:54.586] FabricFontManager :: add(), id: DINOT-Bold
[18:48:54.586]   src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf
[18:48:54.587] FabricFontManager :: add(), id: DINOT-Light
[18:48:54.587]   src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf
[18:48:54.588] FabricFontManager :: add(), id: TradeGothicLTStd-Regular
[18:48:54.588]   src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf
[18:48:54.588] FabricFontManager :: add(), id: TradeGothicLTStd-Bold
[18:48:54.589]   src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf
[18:48:54.590] index :: _onStepProgress_vidbot(), percent: 80
[18:48:54.590] Vidbot :: _clips()
[18:48:54.591] StreamManager :: add(), id:audio_vo, type:audio
[18:48:54.591] AudioClip[audio_vo] :: constructor()
[18:48:54.591] InputStream[audio_vo] :: constructor()
[18:48:54.591] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null }
[18:48:54.594] StreamManager :: add(), id:bg_music, type:audio
[18:48:54.594] AudioClip[bg_music] :: constructor()
[18:48:54.594] InputStream[bg_music] :: constructor()
[18:48:54.595] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null }
[18:48:54.595] StreamManager :: add(), id:simplefadedisplay, type:canvas
[18:48:54.595] CanvasStream[canvas_326188695989] :: constructor()
[18:48:54.595] InputStream[canvas_326188695989] :: constructor()
[18:48:54.676] KenBurnsSlideshow[simplefadedisplay] :: constructor()
[18:48:54.676] Overlay[simplefadedisplay] :: constructor()
[18:48:54.676] CanvasClip[simplefadedisplay] :: constructor()
[18:48:54.676] Clip[simplefadedisplay] :: constructor()
[18:48:54.676]   clip:"simplefadedisplay" added to stream:"canvas_326188695989"
[18:48:54.676] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_326188695989', clipId: 'simplefadedisplay' }
[18:48:54.677] StreamManager :: add(), id:caption, type:canvas
[18:48:54.677] RenCaption[caption] :: constructor()
[18:48:54.677] Ren[caption] :: constructor()
[18:48:54.677] Overlay[caption] :: constructor()
[18:48:54.677] CanvasClip[caption] :: constructor()
[18:48:54.677] Clip[caption] :: constructor()
[18:48:54.677]   clip:"caption" added to stream:"canvas_326188695989"
[18:48:54.677] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_326188695989', clipId: 'caption' }
[18:48:54.677]   all added...
[18:48:54.677] Vidbot :: _next(), _stepIndex:1 of 4
[18:48:54.678] index :: _onStepCompleted_vidbot(), step: 1
[18:48:54.678] index :: _onStepStarted_vidbot(), step: 2
[18:48:54.678] Vidbot :: step[1], label:Initializing Input Streams
[18:48:54.679] StreamManager :: init()
[18:48:54.679] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 }
[18:48:54.679] index :: _onStepProgress_vidbot(), percent: 33
[18:48:54.679] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 }
[18:48:54.679] index :: _onStepProgress_vidbot(), percent: 67
[18:48:54.680] CanvasStream[canvas_326188695989] :: _init(), BEGIN
[18:48:54.680]   i:0, c.id:simplefadedisplay
[18:48:54.680] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN
[18:48:54.680] KenBurnsSlideshow[simplefadedisplay] ::  _validate()
[18:48:54.681] KenBurnsSlideshow[undefined] :: _validateAnim()
[18:48:54.681] KenBurnsSlideshow[undefined] :: _validateTheme()
[18:48:54.682]   i:1, c.id:caption
[18:48:54.683] RenCaption[caption] :: _init()
[18:48:54.683] RenCaption[caption] :: _validate()
[18:48:54.684] KenBurnsSlideshow[simplefadedisplay] :: _build()
[18:48:54.690] AnimatedImageFrame[aif] :: constructor()
[18:48:54.691] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.691] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_1.jpg
[18:48:54.703] RenCaption[caption] :: _build()
[18:48:54.722] Overlay[caption] :: _animate()
[18:48:54.724] CanvasStream[caption] :: _init(), p.then()
[18:48:54.745] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.748] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.749] AnimatedImageFrame[aif] :: constructor()
[18:48:54.749] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.749] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_2.jpg
[18:48:54.767] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.768] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.769] AnimatedImageFrame[aif] :: constructor()
[18:48:54.769] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.769] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_3.jpg
[18:48:54.786] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.788] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.788] AnimatedImageFrame[aif] :: constructor()
[18:48:54.788] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.789] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_4.jpg
[18:48:54.808] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.809] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.809] AnimatedImageFrame[aif] :: constructor()
[18:48:54.809] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.809] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_5.jpg
[18:48:54.826] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.827] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.828] AnimatedImageFrame[aif] :: constructor()
[18:48:54.828] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.828] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_6.jpg
[18:48:54.845] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.846] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.847] AnimatedImageFrame[aif] :: constructor()
[18:48:54.847] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.847] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_7.jpg
[18:48:54.863] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.864] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.865] AnimatedImageFrame[aif] :: constructor()
[18:48:54.865] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.865] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_8.jpg
[18:48:54.881] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.882] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.883] AnimatedImageFrame[aif] :: constructor()
[18:48:54.883] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.883] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_9.jpg
[18:48:54.897] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.898] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.899] AnimatedImageFrame[aif] :: constructor()
[18:48:54.899] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.899] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_10.jpg
[18:48:54.914] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.915] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.916] AnimatedImageFrame[aif] :: constructor()
[18:48:54.916] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.916] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_11.jpg
[18:48:54.932] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.933] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.934] AnimatedImageFrame[aif] :: constructor()
[18:48:54.934] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.934] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_12.jpg
[18:48:54.950] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.950] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.951] AnimatedImageFrame[aif] :: constructor()
[18:48:54.951] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.951] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_13.jpg
[18:48:54.968] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.969] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.969] AnimatedImageFrame[aif] :: constructor()
[18:48:54.969] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.970] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_14.jpg
[18:48:54.984] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:54.984] AnimatedImageFrame[aif] :: _init(), END
[18:48:54.985] AnimatedImageFrame[aif] :: constructor()
[18:48:54.985] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:54.985] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_15.jpg
[18:48:55.001] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:55.002] AnimatedImageFrame[aif] :: _init(), END
[18:48:55.002] AnimatedImageFrame[aif] :: constructor()
[18:48:55.002] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:55.003] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_16.jpg
[18:48:55.017] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:55.017] AnimatedImageFrame[aif] :: _init(), END
[18:48:55.018] AnimatedImageFrame[aif] :: constructor()
[18:48:55.018] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:55.018] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_17.jpg
[18:48:55.032] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:55.033] AnimatedImageFrame[aif] :: _init(), END
[18:48:55.034] AnimatedImageFrame[aif] :: constructor()
[18:48:55.034] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:55.034] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_18.jpg
[18:48:55.049] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:55.050] AnimatedImageFrame[aif] :: _init(), END
[18:48:55.050] AnimatedImageFrame[aif] :: constructor()
[18:48:55.051] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:55.051] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_19.jpg
[18:48:55.069] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:55.070] AnimatedImageFrame[aif] :: _init(), END
[18:48:55.071] AnimatedImageFrame[aif] :: constructor()
[18:48:55.071] AnimatedImageFrame[aif] :: _init(), BEGIN
[18:48:55.071] CanvasClip :: LoadImageWithPromise(), src: 2BD34C0F-049A-7380-FF58-99EB57A36165_20.jpg
[18:48:55.084] CanvasClip :: LoadImageWithPromise(), loaded, isError: false
[18:48:55.085] AnimatedImageFrame[aif] :: _init(), END
[18:48:55.086] Overlay[simplefadedisplay] :: _animate()
[18:48:55.086] KenBurnsSlideshow[simplefadedisplay] :: _init(), END
[18:48:55.086] CanvasStream[simplefadedisplay] :: _init(), p.then()
[18:48:55.087] CanvasStream[canvas_326188695989] :: _init(), promise.all.then()
[18:48:55.089] CanvasStream[canvas_326188695989] :: _init(), END
[18:48:55.089] StreamMangaer :: init(), stream[canvas_326188695989].then()
[18:48:55.089] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_326188695989', progress: 1 }
[18:48:55.089] index :: _onStepProgress_vidbot(), percent: 100
[18:48:55.089] StreamManager :: init(), promise.all.then...
[18:48:55.089] Vidbot :: StreamMgr.on( 'INITED' )
[18:48:55.090] Vidbot :: _next(), _stepIndex:2 of 4
[18:48:55.090] index :: _onStepCompleted_vidbot(), step: 2
[18:48:55.090] index :: _onStepStarted_vidbot(), step: 3
[18:48:55.090] Vidbot :: step[2], label:Rendering Canvas Streams
[18:48:55.090] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined
[18:48:55.090] StreamManager :: render()
[18:48:55.091] CanvasStream[canvas_326188695989] :: render()
[18:48:55.121] index :: _onStepProgress_vidbot(), percent: 0
[18:49:06.643] index :: _onStepProgress_vidbot(), percent: 5
[18:49:24.880] index :: _onStepProgress_vidbot(), percent: 10
[18:49:44.779] index :: _onStepProgress_vidbot(), percent: 15
[18:50:04.475] index :: _onStepProgress_vidbot(), percent: 20
[18:50:23.932] index :: _onStepProgress_vidbot(), percent: 25
[18:50:42.446] index :: _onStepProgress_vidbot(), percent: 30
[18:51:02.103] index :: _onStepProgress_vidbot(), percent: 35
[18:51:20.011] index :: _onStepProgress_vidbot(), percent: 40
[18:51:36.313] index :: _onStepProgress_vidbot(), percent: 45
[18:51:52.700] index :: _onStepProgress_vidbot(), percent: 50
[18:52:09.723] index :: _onStepProgress_vidbot(), percent: 55
[18:52:28.321] index :: _onStepProgress_vidbot(), percent: 60
[18:52:46.353] index :: _onStepProgress_vidbot(), percent: 65
[18:53:01.307] index :: _onStepProgress_vidbot(), percent: 70
[18:53:17.315] index :: _onStepProgress_vidbot(), percent: 75
[18:53:33.506] index :: _onStepProgress_vidbot(), percent: 80
[18:53:49.663] index :: _onStepProgress_vidbot(), percent: 85
[18:54:03.860] index :: _onStepProgress_vidbot(), percent: 90
[18:54:19.667] index :: _onStepProgress_vidbot(), percent: 95
[18:54:32.781] index :: _onStepProgress_vidbot(), percent: 100
[18:54:33.924] StreamManager :: render(), Promise.all.then...
[18:54:33.924] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined
[18:54:33.925] Vidbot :: _next(), _stepIndex:3 of 4
[18:54:33.925] index :: _onStepCompleted_vidbot(), step: 3
[18:54:33.926] index :: _onStepStarted_vidbot(), step: 4
[18:54:33.927] Vidbot :: step[3], label:Encoding Media
[18:54:33.929] CanvasFilters :: Overlay()
[18:54:33.930] AudioStream[audio_vo] :: inputOptions()
[18:54:33.930] AudioFilters :: Volume()
[18:54:33.930]   filter: [2:a]volume=1[2_vol]
[18:54:33.931] AudioFilters :: Delay()
[18:54:33.931]   filter: [2_vol]adelay=0|0[2_del]
[18:54:33.931] AudioStream[bg_music] :: inputOptions()
[18:54:33.931] AudioFilters :: Volume()
[18:54:33.931]   filter: [3:a]volume=0.25[3_vol]
[18:54:33.931] AudioFilters :: FadeOut()
[18:54:33.931]   filter: [3_vol]afade=t=out:st=60:d=1[3_fadeout]
[18:54:33.931] AudioFilters :: Delay()
[18:54:33.931]   filter: [3_fadeout]adelay=0|0[3_del]
[18:54:33.932] AudioFilters :: Mix()
[18:54:33.932]   filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out]
[18:54:33.939]   mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out]
[18:54:33.942]   hang.time: 60
[18:54:34.038] Vidbot :: ffmpeg.on( 'start' )
[18:54:34.038]   ffmpeg -f lavfi -i color=c=000000:s=640x360:r=30:duration=60 -r 30 -i ./tmp/canvas_326188695989_%05d.png -to 00:01:00.000 -i file:///var/www/html/clie
[18:54:34.038]   nts/6921/audio/2BD34C0F-049A-7380-FF58-99EB57A36165.mp3 -to 00:01:00.000 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/RF8_EDM_1.m
[18:54:34.038]   p3 -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:
[18:54:34.038]   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 [a_out] 
[18:54:34.038]   -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/6921/video/2BD34C0F-049A-7380-FF58-99E
[18:54:34.039]   B57A36165.mp4
[18:54:34.201] index :: _onStepProgress_vidbot(), percent: -3462080762
[18:54:34.633] index :: _onStepProgress_vidbot(), percent: 1
[18:54:35.643] index :: _onStepProgress_vidbot(), percent: 8
[18:54:36.146] index :: _onStepProgress_vidbot(), percent: 11
[18:54:37.157] index :: _onStepProgress_vidbot(), percent: 18
[18:54:37.659] index :: _onStepProgress_vidbot(), percent: 22
[18:54:38.170] index :: _onStepProgress_vidbot(), percent: 26
[18:54:38.687] index :: _onStepProgress_vidbot(), percent: 30
[18:54:39.697] index :: _onStepProgress_vidbot(), percent: 38
[18:54:40.198] index :: _onStepProgress_vidbot(), percent: 42
[18:54:40.701] index :: _onStepProgress_vidbot(), percent: 46
[18:54:41.703] index :: _onStepProgress_vidbot(), percent: 53
[18:54:42.204] index :: _onStepProgress_vidbot(), percent: 57
[18:54:42.707] index :: _onStepProgress_vidbot(), percent: 60
[18:54:43.721] index :: _onStepProgress_vidbot(), percent: 68
[18:54:44.211] index :: _onStepProgress_vidbot(), percent: 72
[18:54:44.713] index :: _onStepProgress_vidbot(), percent: 75
[18:54:45.718] index :: _onStepProgress_vidbot(), percent: 83
[18:54:46.217] index :: _onStepProgress_vidbot(), percent: 87
[18:54:46.725] index :: _onStepProgress_vidbot(), percent: 92
[18:54:47.224] index :: _onStepProgress_vidbot(), percent: 96
[18:54:47.656] index :: _onStepProgress_vidbot(), percent: 100
[18:54:47.689] Vidbot :: ffmpeg.on( 'end' ), Done!
[18:54:47.689] StreamManager :: dispose()
[18:54:47.690] CanvasStream[canvas_326188695989] :: dispose()
[18:54:47.695] Vidbot :: fflog.on( 'finish' )
[18:54:47.695]   fflog.path: /var/www/html/clients/6921/video/2BD34C0F-049A-7380-FF58-99EB57A36165.mp4.fflog
[18:54:47.695] Vidbot :: _next(), _stepIndex:4 of 4
[18:54:47.695] index :: _onStepCompleted_vidbot(), step: 4
[18:54:47.696] index :: _onComplete_vidbot(), data: {
  stepTime: 0,
  appTime: 353.154,
  output: '/var/www/html/clients/6921/video/2BD34C0F-049A-7380-FF58-99EB57A36165.mp4',
  duration: 60
}
---------------------------------------------------------------------------------------------------------------
 Output File     :  /var/app/video_pre_processor/jobs/postp//var/www/html/clients/6921/video/2BD34C0F-049A-7380-FF58-99EB57A36165.mp4
 Media Duration  :  00:01:00.000
 Generation Time :  00:05:53.153
---------------------------------------------------------------------------------------------------------------