diff --git a/modules/http_proxy/http_proxy_base.go b/modules/http_proxy/http_proxy_base.go index 5d4eebef..7ace2122 100644 --- a/modules/http_proxy/http_proxy_base.go +++ b/modules/http_proxy/http_proxy_base.go @@ -27,6 +27,8 @@ import ( "github.com/evilsocket/islazy/log" "github.com/evilsocket/islazy/str" "github.com/evilsocket/islazy/tui" + + "github.com/robertkrimen/otto" ) const ( @@ -432,6 +434,14 @@ func (p *HTTPProxy) Start() { } func (p *HTTPProxy) Stop() error { + if p.Script != nil { + if p.Script.Plugin.HasFunc("onExit") { + if _, err := p.Script.Call("onExit"); err != nil { + log.Error("Error while executing onExit callback: %s", "\nTraceback:\n "+err.(*otto.Error).String()) + } + } + } + if p.doRedirect && p.Redirection != nil { p.Debug("disabling redirection %s", p.Redirection.String()) if err := p.Sess.Firewall.EnableRedirection(p.Redirection, false); err != nil {