/*
NNCP -- Node to Node copy, utilities for store-and-forward data exchange
-Copyright (C) 2016-2020 Sergey Matveev <stargrave@stargrave.org>
+Copyright (C) 2016-2021 Sergey Matveev <stargrave@stargrave.org>
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
"os"
"time"
- "go.cypherpunks.ru/nncp/v5"
+ "go.cypherpunks.ru/nncp/v7"
)
func usage() {
dryRun = flag.Bool("dryrun", false, "Do not actually write any tossed data")
doSeen = flag.Bool("seen", false, "Create .seen files")
cycle = flag.Uint("cycle", 0, "Repeat tossing after N seconds in infinite loop")
- noFile = flag.Bool("nofile", false, "Do not process packets with type: file")
- noFreq = flag.Bool("nofreq", false, "Do not process packets with type: freq")
- noExec = flag.Bool("noexec", false, "Do not process packets with type: exec")
- noTrns = flag.Bool("notrns", false, "Do not process packets with type: transitional")
+ noFile = flag.Bool("nofile", false, "Do not process \"file\" packets")
+ noFreq = flag.Bool("nofreq", false, "Do not process \"freq\" packets")
+ noExec = flag.Bool("noexec", false, "Do not process \"exec\" packets")
+ noTrns = flag.Bool("notrns", false, "Do not process \"transitional\" packets")
+ noArea = flag.Bool("noarea", false, "Do not process \"area\" packets")
spoolPath = flag.String("spool", "", "Override path to spool")
logPath = flag.String("log", "", "Override path to logfile")
quiet = flag.Bool("quiet", false, "Print only errors")
version = flag.Bool("version", false, "Print version information")
warranty = flag.Bool("warranty", false, "Print warranty information")
)
+ log.SetFlags(log.Lshortfile)
flag.Usage = usage
flag.Parse()
if *warranty {
}
isBad = ctx.Toss(
node.Id,
+ nncp.TRx,
nice,
- *dryRun,
- *doSeen,
- *noFile,
- *noFreq,
- *noExec,
- *noTrns,
- )
+ *dryRun, *doSeen, *noFile, *noFreq, *noExec, *noTrns, *noArea,
+ ) || isBad
+ if nodeId == *ctx.SelfId {
+ isBad = ctx.Toss(
+ node.Id,
+ nncp.TTx,
+ nice,
+ *dryRun, false, true, true, true, true, *noArea,
+ ) || isBad
+ }
}
if *cycle > 0 {
time.Sleep(time.Duration(*cycle) * time.Second)