mirror of
https://github.com/bettercap/bettercap
synced 2025-08-20 13:33:21 -07:00
refact: refactored module SetRunning method (fixes #49)
This commit is contained in:
parent
76d6977967
commit
9c6eb70eb3
15 changed files with 103 additions and 174 deletions
|
@ -173,14 +173,11 @@ func (p *ArpSpoofer) Configure() error {
|
|||
}
|
||||
|
||||
func (p *ArpSpoofer) Start() error {
|
||||
if p.Running() == true {
|
||||
return session.ErrAlreadyStarted
|
||||
} else if err := p.Configure(); err != nil {
|
||||
if err := p.Configure(); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
p.SetRunning(true)
|
||||
go func() {
|
||||
return p.SetRunning(true, func() {
|
||||
from := p.Session.Gateway.IP
|
||||
from_hw := p.Session.Interface.HW
|
||||
|
||||
|
@ -192,24 +189,14 @@ func (p *ArpSpoofer) Start() error {
|
|||
}
|
||||
|
||||
p.done <- true
|
||||
}()
|
||||
|
||||
return nil
|
||||
})
|
||||
}
|
||||
|
||||
func (p *ArpSpoofer) Stop() error {
|
||||
if p.Running() == false {
|
||||
return session.ErrAlreadyStopped
|
||||
}
|
||||
|
||||
log.Info("Waiting for ARP spoofer to stop ...")
|
||||
|
||||
p.SetRunning(false)
|
||||
|
||||
<-p.done
|
||||
|
||||
p.unSpoof()
|
||||
p.ban = false
|
||||
|
||||
return nil
|
||||
return p.SetRunning(false, func() {
|
||||
log.Info("Waiting for ARP spoofer to stop ...")
|
||||
<-p.done
|
||||
p.unSpoof()
|
||||
p.ban = false
|
||||
})
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue