--------------------------------------------------------------------------------------------------------------- INITIALIZING VIDBOT, v1.7.1... --------------------------------------------------------------------------------------------------------------- [01:30:35.102] Vidbot :: start() [01:30:35.103] Vidbot :: _next(), _stepIndex:0 of 4 [01:30:35.104] index :: _onStepStarted_vidbot(), step: 1 [01:30:35.105] Vidbot :: step[0], label:Initializing Core [01:30:35.114] index :: _onStepProgress_vidbot(), percent: 20 [01:30:35.114] Vidbot :: _parse() [01:30:35.116] index :: _onStepProgress_vidbot(), percent: 40 [01:30:35.116] Vidbot :: _validate() [01:30:35.117] index :: _onStepProgress_vidbot(), percent: 60 [01:30:35.117] Vidbot :: _fonts() [01:30:35.117] FabricFontManager :: add(), id: SourceSansPro-Bold [01:30:35.118] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Bold.ttf [01:30:35.126] FabricFontManager :: add(), id: SourceSansPro-Light [01:30:35.126] src: /var/app/Vidbot-V2/assets/fonts/SourceSansPro/SourceSansPro-Light.ttf [01:30:35.127] FabricFontManager :: add(), id: DINOT-Bold [01:30:35.127] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Bold.otf [01:30:35.128] FabricFontManager :: add(), id: DINOT-Light [01:30:35.128] src: /var/app/Vidbot-V2/assets/fonts/DINOT/DINOT-Light.otf [01:30:35.129] FabricFontManager :: add(), id: TradeGothicLTStd-Regular [01:30:35.129] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Regular.otf [01:30:35.130] FabricFontManager :: add(), id: TradeGothicLTStd-Bold [01:30:35.130] src: /var/app/Vidbot-V2/assets/fonts/TradeGothicCond/TradeGothicLTStd-Bold.otf [01:30:35.131] index :: _onStepProgress_vidbot(), percent: 80 [01:30:35.131] Vidbot :: _clips() [01:30:35.132] StreamManager :: add(), id:audio_vo, type:audio [01:30:35.132] AudioClip[audio_vo] :: constructor() [01:30:35.132] InputStream[audio_vo] :: constructor() [01:30:35.133] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'audio_vo', clipId: null } [01:30:35.135] StreamManager :: add(), id:bg_music, type:audio [01:30:35.136] AudioClip[bg_music] :: constructor() [01:30:35.136] InputStream[bg_music] :: constructor() [01:30:35.136] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'bg_music', clipId: null } [01:30:35.136] StreamManager :: add(), id:simplefadedisplay, type:canvas [01:30:35.136] CanvasStream[canvas_1358270784072] :: constructor() [01:30:35.137] InputStream[canvas_1358270784072] :: constructor() [01:30:35.222] KenBurnsSlideshow[simplefadedisplay] :: constructor() [01:30:35.222] Overlay[simplefadedisplay] :: constructor() [01:30:35.223] CanvasClip[simplefadedisplay] :: constructor() [01:30:35.223] Clip[simplefadedisplay] :: constructor() [01:30:35.223] clip:"simplefadedisplay" added to stream:"canvas_1358270784072" [01:30:35.223] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1358270784072', clipId: 'simplefadedisplay' } [01:30:35.223] StreamManager :: add(), id:infosheet, type:canvas [01:30:35.223] RenInfosheet[infosheet] :: constructor() [01:30:35.224] Ren[infosheet] :: constructor() [01:30:35.224] Overlay[infosheet] :: constructor() [01:30:35.224] CanvasClip[infosheet] :: constructor() [01:30:35.224] Clip[infosheet] :: constructor() [01:30:35.224] clip:"infosheet" added to stream:"canvas_1358270784072" [01:30:35.224] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1358270784072', clipId: 'infosheet' } [01:30:35.224] StreamManager :: add(), id:caption, type:canvas [01:30:35.224] RenCaption[caption] :: constructor() [01:30:35.224] Ren[caption] :: constructor() [01:30:35.224] Overlay[caption] :: constructor() [01:30:35.224] CanvasClip[caption] :: constructor() [01:30:35.225] Clip[caption] :: constructor() [01:30:35.225] clip:"caption" added to stream:"canvas_1358270784072" [01:30:35.225] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1358270784072', clipId: 'caption' } [01:30:35.225] StreamManager :: add(), id:options, type:canvas [01:30:35.225] RenOptions[options] :: constructor() [01:30:35.225] Ren[options] :: constructor() [01:30:35.225] Overlay[options] :: constructor() [01:30:35.225] CanvasClip[options] :: constructor() [01:30:35.225] Clip[options] :: constructor() [01:30:35.225] clip:"options" added to stream:"canvas_1358270784072" [01:30:35.226] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1358270784072', clipId: 'options' } [01:30:35.226] StreamManager :: add(), id:map, type:canvas [01:30:35.226] RenMap[map] :: constructor() [01:30:35.226] Ren[map] :: constructor() [01:30:35.226] Overlay[map] :: constructor() [01:30:35.226] CanvasClip[map] :: constructor() [01:30:35.226] Clip[map] :: constructor() [01:30:35.226] clip:"map" added to stream:"canvas_1358270784072" [01:30:35.226] Vidbot :: StreamMgr.on( 'ADDED' ), data: { streamID: 'canvas_1358270784072', clipId: 'map' } [01:30:35.226] all added... [01:30:35.227] Vidbot :: _next(), _stepIndex:1 of 4 [01:30:35.227] index :: _onStepCompleted_vidbot(), step: 1 [01:30:35.227] index :: _onStepStarted_vidbot(), step: 2 [01:30:35.227] Vidbot :: step[1], label:Initializing Input Streams [01:30:35.228] StreamManager :: init() [01:30:35.228] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'audio_vo', progress: 0.3333333333333333 } [01:30:35.228] index :: _onStepProgress_vidbot(), percent: 33 [01:30:35.229] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'bg_music', progress: 0.6666666666666666 } [01:30:35.229] index :: _onStepProgress_vidbot(), percent: 67 [01:30:35.229] CanvasStream[canvas_1358270784072] :: _init(), BEGIN [01:30:35.229] i:0, c.id:simplefadedisplay [01:30:35.230] KenBurnsSlideshow[simplefadedisplay] :: _init(), BEGIN [01:30:35.230] KenBurnsSlideshow[simplefadedisplay] :: _validate() [01:30:35.230] KenBurnsSlideshow[undefined] :: _validateAnim() [01:30:35.231] KenBurnsSlideshow[undefined] :: _validateTheme() [01:30:35.232] i:1, c.id:infosheet [01:30:35.232] RenInfosheet[infosheet] :: _init() [01:30:35.232] RenInfosheet[infosheet] :: _validate() [01:30:35.233] i:2, c.id:caption [01:30:35.233] RenCaption[caption] :: _init() [01:30:35.234] RenCaption[caption] :: _validate() [01:30:35.234] i:3, c.id:options [01:30:35.234] RenPrice[options] :: _init() [01:30:35.235] RenOptions[options] :: _validate() [01:30:35.235] i:4, c.id:map [01:30:35.235] RenMap[map] :: _init() [01:30:35.236] RenMap[map] :: _validate() [01:30:35.236] KenBurnsSlideshow[simplefadedisplay] :: _build() [01:30:35.242] AnimatedImageFrame[aif] :: constructor() [01:30:35.243] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.243] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_1.jpg [01:30:35.254] RenInfosheet[infosheet] :: _assets() [01:30:35.255] CanvasClip :: LoadSVGFromStringWithPromise() [01:30:35.274] CanvasClip :: LoadSVGFromString(), loaded [01:30:35.275] RenCaption[caption] :: _build() [01:30:35.289] RenOptions[options] :: _assets() [01:30:35.289] CanvasClip :: LoadSVGFromStringWithPromise() [01:30:35.302] CanvasClip :: LoadSVGFromString(), loaded [01:30:35.304] RenMap[map] :: _assets() [01:30:35.304] CanvasClip :: LoadSVGFromStringWithPromise() [01:30:35.313] CanvasClip :: LoadSVGFromString(), loaded [01:30:35.315] CanvasClip :: LoadImageWithPromise(), src: map_540.jpg [01:30:35.317] Overlay[caption] :: _animate() [01:30:35.320] RenInfosheet[infosheet] :: _build() [01:30:35.340] RenOptions[options] :: _build() [01:30:35.434] Overlay[infosheet] :: _animate() [01:30:35.435] CanvasStream[caption] :: _init(), p.then() [01:30:35.436] RenOptions[options] :: _animate() [01:30:35.436] Overlay[options] :: _animate() [01:30:35.436] CanvasStream[infosheet] :: _init(), p.then() [01:30:35.436] CanvasStream[options] :: _init(), p.then() [01:30:35.485] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.489] AnimatedImageFrame[aif] :: _init(), END [01:30:35.490] AnimatedImageFrame[aif] :: constructor() [01:30:35.491] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.491] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_2.jpg [01:30:35.511] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.513] RenMap[map] :: _build() [01:30:35.527] Overlay[map] :: _animate() [01:30:35.527] CanvasStream[map] :: _init(), p.then() [01:30:35.570] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.571] AnimatedImageFrame[aif] :: _init(), END [01:30:35.572] AnimatedImageFrame[aif] :: constructor() [01:30:35.572] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.572] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_3.jpg [01:30:35.620] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.622] AnimatedImageFrame[aif] :: _init(), END [01:30:35.622] AnimatedImageFrame[aif] :: constructor() [01:30:35.623] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.623] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_4.jpg [01:30:35.665] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.666] AnimatedImageFrame[aif] :: _init(), END [01:30:35.666] AnimatedImageFrame[aif] :: constructor() [01:30:35.666] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.667] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_5.jpg [01:30:35.709] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.710] AnimatedImageFrame[aif] :: _init(), END [01:30:35.710] AnimatedImageFrame[aif] :: constructor() [01:30:35.711] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.711] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_6.jpg [01:30:35.745] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.746] AnimatedImageFrame[aif] :: _init(), END [01:30:35.746] AnimatedImageFrame[aif] :: constructor() [01:30:35.747] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.747] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_7.jpg [01:30:35.783] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.784] AnimatedImageFrame[aif] :: _init(), END [01:30:35.785] AnimatedImageFrame[aif] :: constructor() [01:30:35.785] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.785] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_1.jpg [01:30:35.824] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.825] AnimatedImageFrame[aif] :: _init(), END [01:30:35.825] AnimatedImageFrame[aif] :: constructor() [01:30:35.825] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.825] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_2.jpg [01:30:35.874] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.875] AnimatedImageFrame[aif] :: _init(), END [01:30:35.876] AnimatedImageFrame[aif] :: constructor() [01:30:35.876] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.876] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_3.jpg [01:30:35.916] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.917] AnimatedImageFrame[aif] :: _init(), END [01:30:35.917] AnimatedImageFrame[aif] :: constructor() [01:30:35.917] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.917] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_4.jpg [01:30:35.953] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.954] AnimatedImageFrame[aif] :: _init(), END [01:30:35.954] AnimatedImageFrame[aif] :: constructor() [01:30:35.955] AnimatedImageFrame[aif] :: _init(), BEGIN [01:30:35.955] CanvasClip :: LoadImageWithPromise(), src: 0A9F323B-B88F-629E-4878-216D302F6ED8_5.jpg [01:30:35.986] CanvasClip :: LoadImageWithPromise(), loaded, isError: false [01:30:35.987] AnimatedImageFrame[aif] :: _init(), END [01:30:35.988] Overlay[simplefadedisplay] :: _animate() [01:30:35.988] KenBurnsSlideshow[simplefadedisplay] :: _init(), END [01:30:35.988] CanvasStream[simplefadedisplay] :: _init(), p.then() [01:30:35.989] CanvasStream[canvas_1358270784072] :: _init(), promise.all.then() [01:30:35.991] CanvasStream[canvas_1358270784072] :: _init(), END [01:30:35.992] StreamMangaer :: init(), stream[canvas_1358270784072].then() [01:30:35.992] Vidbot :: StreamMgr.on( 'STREAM_INITED' ), data: { streamID: 'canvas_1358270784072', progress: 1 } [01:30:35.992] index :: _onStepProgress_vidbot(), percent: 100 [01:30:35.992] StreamManager :: init(), promise.all.then... [01:30:35.992] Vidbot :: StreamMgr.on( 'INITED' ) [01:30:35.992] Vidbot :: _next(), _stepIndex:2 of 4 [01:30:35.992] index :: _onStepCompleted_vidbot(), step: 2 [01:30:35.993] index :: _onStepStarted_vidbot(), step: 3 [01:30:35.993] Vidbot :: step[2], label:Rendering Canvas Streams [01:30:35.993] Vidbot :: StreamMgr.on( 'RENDER_STARTED' ), data: undefined [01:30:35.993] StreamManager :: render() [01:30:35.994] CanvasStream[canvas_1358270784072] :: render() [01:30:36.055] index :: _onStepProgress_vidbot(), percent: 0 [01:30:54.293] index :: _onStepProgress_vidbot(), percent: 5 [01:31:17.715] index :: _onStepProgress_vidbot(), percent: 10 [01:31:44.077] index :: _onStepProgress_vidbot(), percent: 15 [01:32:13.943] index :: _onStepProgress_vidbot(), percent: 20 [01:32:42.674] index :: _onStepProgress_vidbot(), percent: 25 [01:33:13.765] index :: _onStepProgress_vidbot(), percent: 30 [01:33:46.338] index :: _onStepProgress_vidbot(), percent: 35 [01:34:13.953] index :: _onStepProgress_vidbot(), percent: 40 [01:34:39.996] index :: _onStepProgress_vidbot(), percent: 45 [01:35:01.903] index :: _onStepProgress_vidbot(), percent: 50 [01:35:25.137] index :: _onStepProgress_vidbot(), percent: 55 [01:35:46.242] index :: _onStepProgress_vidbot(), percent: 60 [01:36:05.839] index :: _onStepProgress_vidbot(), percent: 65 [01:36:34.802] index :: _onStepProgress_vidbot(), percent: 70 [01:37:05.802] index :: _onStepProgress_vidbot(), percent: 75 [01:37:34.458] index :: _onStepProgress_vidbot(), percent: 80 [01:38:02.585] index :: _onStepProgress_vidbot(), percent: 85 [01:38:29.231] index :: _onStepProgress_vidbot(), percent: 90 [01:38:49.193] index :: _onStepProgress_vidbot(), percent: 95 [01:39:03.058] index :: _onStepProgress_vidbot(), percent: 100 [01:39:04.096] StreamManager :: render(), Promise.all.then... [01:39:04.096] Vidbot :: StreamMgr.on( 'RENDER_COMPLETED' ), data: undefined [01:39:04.097] Vidbot :: _next(), _stepIndex:3 of 4 [01:39:04.097] index :: _onStepCompleted_vidbot(), step: 3 [01:39:04.098] index :: _onStepStarted_vidbot(), step: 4 [01:39:04.099] Vidbot :: step[3], label:Encoding Media [01:39:04.102] CanvasFilters :: Overlay() [01:39:04.102] AudioStream[audio_vo] :: inputOptions() [01:39:04.103] AudioFilters :: Volume() [01:39:04.103] filter: [2:a]volume=1[2_vol] [01:39:04.103] AudioFilters :: Delay() [01:39:04.103] filter: [2_vol]adelay=0|0[2_del] [01:39:04.103] AudioStream[bg_music] :: inputOptions() [01:39:04.103] AudioFilters :: Volume() [01:39:04.103] filter: [3:a]volume=0.15[3_vol] [01:39:04.104] AudioFilters :: FadeOut() [01:39:04.104] filter: [3_vol]afade=t=out:st=33.62:d=1[3_fadeout] [01:39:04.104] AudioFilters :: Delay() [01:39:04.104] filter: [3_fadeout]adelay=0|0[3_del] [01:39:04.105] AudioFilters :: Mix() [01:39:04.105] filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [01:39:04.105] mixed filter: [2_del][3_del]amix=inputs=2:duration=longest[a_out] [01:39:04.108] hang.time: 60 [01:39:04.240] Vidbot :: ffmpeg.on( 'start' ) [01:39:04.241] ffmpeg -f lavfi -i color=c=000000:s=960x540:r=30:duration=36.62 -r 30 -i ./tmp/canvas_1358270784072_%05d.png -to 00:00:39.619 -i file:///var/www/html/ [01:39:04.241] clients/22529/audio/0A9F323B-B88F-629E-4878-216D302F6ED8.mp3 -to 00:00:33.619 -i file:///var/app/video_pre_processor/assets/vidbot/_files/audio/Orches [01:39:04.241] tra-4_30.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= [01:39:04.241] out:st=33.62: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 [01:39:04.241] -map [a_out] -map [1_out] -preset veryfast -crf 18 -movflags frag_keyframe+empty_moov -pix_fmt yuv420p /var/www/html/clients/22529/video/0A9F323B-B88F [01:39:04.241] -629E-4878-216D302F6ED8.mp4 [01:39:04.485] index :: _onStepProgress_vidbot(), percent: -5672442537 [01:39:04.868] index :: _onStepProgress_vidbot(), percent: 2 [01:39:05.375] index :: _onStepProgress_vidbot(), percent: 6 [01:39:05.879] index :: _onStepProgress_vidbot(), percent: 10 [01:39:06.883] index :: _onStepProgress_vidbot(), percent: 18 [01:39:07.391] index :: _onStepProgress_vidbot(), percent: 22 [01:39:07.891] index :: _onStepProgress_vidbot(), percent: 26 [01:39:08.391] index :: _onStepProgress_vidbot(), percent: 30 [01:39:09.409] index :: _onStepProgress_vidbot(), percent: 38 [01:39:09.929] index :: _onStepProgress_vidbot(), percent: 41 [01:39:10.433] index :: _onStepProgress_vidbot(), percent: 45 [01:39:11.446] index :: _onStepProgress_vidbot(), percent: 51 [01:39:11.947] index :: _onStepProgress_vidbot(), percent: 55 [01:39:12.958] index :: _onStepProgress_vidbot(), percent: 61 [01:39:13.978] index :: _onStepProgress_vidbot(), percent: 67 [01:39:14.489] index :: _onStepProgress_vidbot(), percent: 71 [01:39:15.508] index :: _onStepProgress_vidbot(), percent: 78 [01:39:16.010] index :: _onStepProgress_vidbot(), percent: 82 [01:39:16.515] index :: _onStepProgress_vidbot(), percent: 86 [01:39:17.520] index :: _onStepProgress_vidbot(), percent: 92 [01:39:18.509] index :: _onStepProgress_vidbot(), percent: 100 [01:39:18.539] Vidbot :: ffmpeg.on( 'end' ), Done! [01:39:18.539] StreamManager :: dispose() [01:39:18.539] CanvasStream[canvas_1358270784072] :: dispose() [01:39:18.544] Vidbot :: fflog.on( 'finish' ) [01:39:18.544] fflog.path: /var/www/html/clients/22529/video/0A9F323B-B88F-629E-4878-216D302F6ED8.mp4.fflog [01:39:18.544] Vidbot :: _next(), _stepIndex:4 of 4 [01:39:18.544] index :: _onStepCompleted_vidbot(), step: 4 [01:39:18.545] index :: _onComplete_vidbot(), data: { stepTime: 0.001, appTime: 523.473, output: '/var/www/html/clients/22529/video/0A9F323B-B88F-629E-4878-216D302F6ED8.mp4', duration: 36.62 } --------------------------------------------------------------------------------------------------------------- Output File : /var/app/video_pre_processor/jobs/postp//var/www/html/clients/22529/video/0A9F323B-B88F-629E-4878-216D302F6ED8.mp4 Media Duration : 00:00:36.619 Generation Time : 00:08:43.472 ---------------------------------------------------------------------------------------------------------------