mirror of
https://github.com/bettercap/bettercap
synced 2025-08-21 05:53:20 -07:00
new: new c2 module, first draft
This commit is contained in:
parent
35dbb8a368
commit
583a54c194
23 changed files with 579 additions and 163 deletions
|
@ -37,6 +37,19 @@ func (e Event) Label() string {
|
|||
return color + label + tui.RESET
|
||||
}
|
||||
|
||||
type EventBus <-chan Event
|
||||
|
||||
type PrintCallback func(format string, args ...interface{})
|
||||
|
||||
type PrintWriter struct {
|
||||
pool *EventPool
|
||||
}
|
||||
|
||||
func (w PrintWriter) Write(p []byte) (n int, err error) {
|
||||
w.pool.Printf("%s", string(p))
|
||||
return len(p), nil
|
||||
}
|
||||
|
||||
type EventPool struct {
|
||||
*sync.Mutex
|
||||
|
||||
|
@ -44,19 +57,35 @@ type EventPool struct {
|
|||
silent bool
|
||||
events []Event
|
||||
listeners []chan Event
|
||||
printLock sync.Mutex
|
||||
printCbs []PrintCallback
|
||||
Stdout PrintWriter
|
||||
}
|
||||
|
||||
func NewEventPool(debug bool, silent bool) *EventPool {
|
||||
return &EventPool{
|
||||
pool := &EventPool{
|
||||
Mutex: &sync.Mutex{},
|
||||
debug: debug,
|
||||
silent: silent,
|
||||
events: make([]Event, 0),
|
||||
listeners: make([]chan Event, 0),
|
||||
printCbs: make([]PrintCallback, 0),
|
||||
}
|
||||
|
||||
pool.Stdout = PrintWriter{
|
||||
pool: pool,
|
||||
}
|
||||
|
||||
return pool
|
||||
}
|
||||
|
||||
func (p *EventPool) Listen() <-chan Event {
|
||||
func (p *EventPool) OnPrint(cb PrintCallback) {
|
||||
p.printLock.Lock()
|
||||
defer p.printLock.Unlock()
|
||||
p.printCbs = append(p.printCbs, cb)
|
||||
}
|
||||
|
||||
func (p *EventPool) Listen() EventBus {
|
||||
p.Lock()
|
||||
defer p.Unlock()
|
||||
l := make(chan Event)
|
||||
|
@ -76,7 +105,7 @@ func (p *EventPool) Listen() <-chan Event {
|
|||
return l
|
||||
}
|
||||
|
||||
func (p *EventPool) Unlisten(listener <-chan Event) {
|
||||
func (p *EventPool) Unlisten(listener EventBus) {
|
||||
p.Lock()
|
||||
defer p.Unlock()
|
||||
|
||||
|
@ -123,6 +152,16 @@ func (p *EventPool) Add(tag string, data interface{}) {
|
|||
}
|
||||
}
|
||||
|
||||
func (p *EventPool) Printf(format string, a ...interface{}) {
|
||||
p.printLock.Lock()
|
||||
defer p.printLock.Unlock()
|
||||
|
||||
for _, cb := range p.printCbs {
|
||||
cb(format, a...)
|
||||
}
|
||||
fmt.Printf(format, a...)
|
||||
}
|
||||
|
||||
func (p *EventPool) Log(level log.Verbosity, format string, args ...interface{}) {
|
||||
if level == log.DEBUG && !p.debug {
|
||||
return
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue