]> Cypherpunks.ru repositories - nncp.git/blob - src/cypherpunks.ru/nncp/cmd/nncp-log/main.go
aea1d8b63e346aa96ea251faa73d2ce23bf797f3
[nncp.git] / src / cypherpunks.ru / nncp / cmd / nncp-log / main.go
1 /*
2 NNCP -- Node to Node copy, utilities for store-and-forward data exchange
3 Copyright (C) 2016-2019 Sergey Matveev <stargrave@stargrave.org>
4
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program.  If not, see <http://www.gnu.org/licenses/>.
17 */
18
19 // Read NNCP logs.
20 package main
21
22 import (
23         "bufio"
24         "flag"
25         "fmt"
26         "log"
27         "os"
28
29         "cypherpunks.ru/nncp"
30 )
31
32 func usage() {
33         fmt.Fprintf(os.Stderr, nncp.UsageHeader())
34         fmt.Fprintf(os.Stderr, "nncp-log -- read logs\n\n")
35         fmt.Fprintf(os.Stderr, "Usage: %s [options]\nOptions:\n", os.Args[0])
36         flag.PrintDefaults()
37 }
38
39 func main() {
40         var (
41                 cfgPath  = flag.String("cfg", nncp.DefaultCfgPath, "Path to configuration file")
42                 logPath  = flag.String("log", "", "Override path to logfile")
43                 debug    = flag.Bool("debug", false, "Print debug messages")
44                 version  = flag.Bool("version", false, "Print version information")
45                 warranty = flag.Bool("warranty", false, "Print warranty information")
46         )
47         flag.Usage = usage
48         flag.Parse()
49         if *warranty {
50                 fmt.Println(nncp.Warranty)
51                 return
52         }
53         if *version {
54                 fmt.Println(nncp.VersionGet())
55                 return
56         }
57
58         ctx, err := nncp.CtxFromCmdline(*cfgPath, "", *logPath, false, *debug)
59         if err != nil {
60                 log.Fatalln("Error during initialization:", err)
61         }
62
63         fd, err := os.Open(ctx.LogPath)
64         if err != nil {
65                 log.Fatalln("Can not open log:", err)
66         }
67         scanner := bufio.NewScanner(fd)
68         for scanner.Scan() {
69                 t := scanner.Text()
70                 if *debug {
71                         fmt.Println(t)
72                 }
73                 fmt.Println(ctx.Humanize(t))
74         }
75         if err = scanner.Err(); err != nil {
76                 log.Fatalln("Can not read log:", err)
77         }
78 }