X-Git-Url: http://www.git.cypherpunks.ru/?a=blobdiff_plain;f=src%2Fcall.go;h=de1ce4f6796e12f1490cef36455c69dbc1f03426;hb=e068d88291cd45a4d6b748e258077dd6c0ffb9c2;hp=a201825f82358777700b3af793a9f4905526debd;hpb=2ed1fcb19bc568750e58094230df4144080ae171;p=nncp.git diff --git a/src/call.go b/src/call.go index a201825..de1ce4f 100644 --- a/src/call.go +++ b/src/call.go @@ -1,6 +1,6 @@ /* NNCP -- Node to Node copy, utilities for store-and-forward data exchange -Copyright (C) 2016-2021 Sergey Matveev +Copyright (C) 2016-2022 Sergey Matveev This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -18,14 +18,19 @@ along with this program. If not, see . package nncp import ( + "errors" "fmt" "net" + "os" + "strings" "time" "github.com/dustin/go-humanize" "github.com/gorhill/cronexpr" ) +const YggdrasilPrefix = "yggdrasil:" + type Call struct { Cron *cronexpr.Expression Nice uint8 @@ -45,6 +50,7 @@ type Call struct { AutoTossNoFreq bool AutoTossNoExec bool AutoTossNoTrns bool + AutoTossNoArea bool } func (ctx *Ctx) CallNode( @@ -56,7 +62,7 @@ func (ctx *Ctx) CallNode( onlineDeadline, maxOnlineTime time.Duration, listOnly bool, noCK bool, - onlyPkts map[[32]byte]bool, + onlyPkts map[[MTHSize]byte]bool, ) (isGood bool) { for _, addr := range addrs { les := LEs{{"Node", node.Id}, {"Addr", addr}} @@ -67,11 +73,29 @@ func (ctx *Ctx) CallNode( var err error if addr[0] == '|' { conn, err = NewPipeConn(addr[1:]) + } else if addr == UCSPITCPClient { + ucspiConn := UCSPIConn{R: os.NewFile(6, "R"), W: os.NewFile(7, "W")} + if ucspiConn.R == nil { + err = errors.New("no 6 file descriptor") + } + if ucspiConn.W == nil { + err = errors.New("no 7 file descriptor") + } + conn = ucspiConn + addr = UCSPITCPRemoteAddr() + if addr == "" { + addr = UCSPITCPClient + } + } else if strings.HasPrefix(addr, YggdrasilPrefix) { + conn, err = NewYggdrasilConn( + ctx.YggdrasilAliases, + strings.TrimPrefix(addr, YggdrasilPrefix), + ) } else { conn, err = net.Dial("tcp", addr) } if err != nil { - ctx.LogD("calling", append(les, LE{"Err", err}), func(les LEs) string { + ctx.LogE("calling", les, err, func(les LEs) string { return fmt.Sprintf("Calling %s (%s)", node.Name, addr) }) continue @@ -110,7 +134,7 @@ func (ctx *Ctx) CallNode( node.Name, int(state.Duration.Hours()), int(state.Duration.Minutes()), - int(state.Duration.Seconds()/60), + int(state.Duration.Seconds())%60, humanize.IBytes(uint64(state.RxBytes)), humanize.IBytes(uint64(state.RxSpeed)), humanize.IBytes(uint64(state.TxBytes)), @@ -118,13 +142,13 @@ func (ctx *Ctx) CallNode( ) }) isGood = true - conn.Close() // #nosec G104 + conn.Close() break } else { ctx.LogE("call-started", les, err, func(les LEs) string { return fmt.Sprintf("Connection to %s (%s)", node.Name, addr) }) - conn.Close() // #nosec G104 + conn.Close() } } return