X-Git-Url: http://www.git.cypherpunks.ru/?a=blobdiff_plain;ds=sidebyside;f=src%2Fcall.go;h=de1ce4f6796e12f1490cef36455c69dbc1f03426;hb=e068d88291cd45a4d6b748e258077dd6c0ffb9c2;hp=c52fc419ecafe6a75e45afaf9a14e99bd8c5a6ee;hpb=655146e4ee2bde72c9e8daa1361010fefe016df9;p=nncp.git diff --git a/src/call.go b/src/call.go index c52fc41..de1ce4f 100644 --- a/src/call.go +++ b/src/call.go @@ -22,12 +22,15 @@ import ( "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 @@ -83,11 +86,16 @@ func (ctx *Ctx) CallNode( 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