nuclei/v2/internal/progress/progress.go

113 lines
2.2 KiB
Go
Raw Normal View History

2020-07-04 23:00:11 +02:00
package progress
import (
"fmt"
"github.com/logrusorgru/aurora"
"github.com/vbauerster/mpb/v5"
"github.com/vbauerster/mpb/v5/cwriter"
"github.com/vbauerster/mpb/v5/decor"
"os"
"strings"
"sync"
)
type Progress struct {
progress *mpb.Progress
2020-07-05 23:38:58 +02:00
bar *mpb.Bar
total int64
initialTotal int64
2020-07-04 23:00:11 +02:00
captureData *captureData
termWidth int
2020-07-08 23:13:05 +02:00
mutex *sync.Mutex
stdout *strings.Builder
stderr *strings.Builder
2020-07-04 23:00:11 +02:00
}
func NewProgress(group *sync.WaitGroup) *Progress {
w := cwriter.New(os.Stderr)
2020-07-04 23:00:11 +02:00
tw, err := w.GetWidth()
if err != nil {
tw = 80
2020-07-04 23:00:11 +02:00
}
p := &Progress{
progress: mpb.New(
mpb.WithWaitGroup(group),
mpb.WithOutput(os.Stderr),
mpb.PopCompletedMode(),
),
termWidth: tw,
2020-07-08 23:13:05 +02:00
mutex: &sync.Mutex{},
stdout: &strings.Builder{},
stderr: &strings.Builder{},
2020-07-04 23:00:11 +02:00
}
return p
}
2020-07-05 23:38:58 +02:00
func (p *Progress) SetupProgressBar(name string, total int64) *mpb.Bar {
2020-07-05 17:22:21 +02:00
barname := "[" + aurora.Green(name).String() + "]"
2020-07-05 23:38:58 +02:00
bar := p.progress.AddBar(
2020-07-04 23:00:11 +02:00
total,
mpb.BarNoPop(),
2020-07-05 20:11:53 +02:00
mpb.BarRemoveOnComplete(),
2020-07-04 23:00:11 +02:00
mpb.PrependDecorators(
2020-07-05 17:22:21 +02:00
decor.Name(barname),
2020-07-04 23:00:11 +02:00
decor.CountersNoUnit(aurora.Blue(" %d/%d").String()),
decor.NewPercentage(aurora.Bold("%d").String(), decor.WCSyncSpace),
),
mpb.AppendDecorators(
decor.AverageSpeed(0, aurora.Yellow("%.2f req/s ").String()),
2020-07-04 23:00:11 +02:00
decor.OnComplete(
decor.AverageETA(decor.ET_STYLE_GO), aurora.Bold("done!").String(),
2020-07-04 23:00:11 +02:00
),
),
)
2020-07-05 23:38:58 +02:00
p.bar = bar
p.total = total
p.initialTotal = total
2020-07-05 23:38:58 +02:00
return bar
}
func (p *Progress) Update() {
p.bar.Increment()
2020-07-04 23:00:11 +02:00
}
func (p *Progress) Abort(remaining int64) {
atomic.AddInt64(&p.total, -remaining)
p.bar.SetTotal(atomic.LoadInt64(&p.total), false)
}
2020-07-04 23:00:11 +02:00
func (p *Progress) Wait() {
if p.initialTotal != p.total {
p.bar.SetTotal(p.total, true)
}
2020-07-04 23:00:11 +02:00
p.progress.Wait()
}
//
func (p *Progress) StartStdCapture() {
2020-07-08 23:13:05 +02:00
p.mutex.Lock()
2020-07-04 23:00:11 +02:00
p.captureData = startStdCapture()
}
func (p *Progress) StopStdCapture() {
2020-07-04 23:00:11 +02:00
stopStdCapture(p.captureData)
p.stdout.Write(p.captureData.DataStdOut.Bytes())
p.stderr.Write(p.captureData.DataStdErr.Bytes())
p.mutex.Unlock()
}
func (p *Progress) ShowStdOut() {
if p.stdout.Len() > 0 {
fmt.Fprint(os.Stdout, p.stdout.String())
2020-07-04 23:00:11 +02:00
}
}
func (p *Progress) ShowStdErr() {
if p.stderr.Len() > 0 {
fmt.Fprint(os.Stderr, p.stderr.String())
}
2020-07-04 23:00:11 +02:00
}