X-Git-Url: http://www.git.cypherpunks.ru/?a=blobdiff_plain;f=src%2Fcall.go;h=95a70d6dcc502e03484c2385d8a665dde3b78bf8;hb=7696544068749db54f07c21cd658557905302fe4;hp=de1ce4f6796e12f1490cef36455c69dbc1f03426;hpb=e068d88291cd45a4d6b748e258077dd6c0ffb9c2;p=nncp.git diff --git a/src/call.go b/src/call.go index de1ce4f..95a70d6 100644 --- a/src/call.go +++ b/src/call.go @@ -27,10 +27,9 @@ import ( "github.com/dustin/go-humanize" "github.com/gorhill/cronexpr" + nncpYggdrasil "go.cypherpunks.ru/nncp/v8/yggdrasil" ) -const YggdrasilPrefix = "yggdrasil:" - type Call struct { Cron *cronexpr.Expression Nice uint8 @@ -51,6 +50,7 @@ type Call struct { AutoTossNoExec bool AutoTossNoTrns bool AutoTossNoArea bool + AutoTossNoACK bool } func (ctx *Ctx) CallNode( @@ -86,11 +86,8 @@ func (ctx *Ctx) CallNode( if addr == "" { addr = UCSPITCPClient } - } else if strings.HasPrefix(addr, YggdrasilPrefix) { - conn, err = NewYggdrasilConn( - ctx.YggdrasilAliases, - strings.TrimPrefix(addr, YggdrasilPrefix), - ) + } else if strings.HasPrefix(addr, "yggdrasilc://") { + conn, err = nncpYggdrasil.NewConn(ctx.YggdrasilAliases, addr) } else { conn, err = net.Dial("tcp", addr) } @@ -120,7 +117,7 @@ func (ctx *Ctx) CallNode( ctx.LogI("call-started", les, func(les LEs) string { return fmt.Sprintf("Connection to %s (%s)", node.Name, addr) }) - state.Wait() + isGood = state.Wait() ctx.LogI("call-finished", append( les, LE{"Duration", int64(state.Duration.Seconds())}, @@ -141,7 +138,6 @@ func (ctx *Ctx) CallNode( humanize.IBytes(uint64(state.TxSpeed)), ) }) - isGood = true conn.Close() break } else {