]> Cypherpunks.ru repositories - nncp.git/blob - src/check.go
Operations progress
[nncp.git] / src / check.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, version 3 of the License.
8
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 GNU General Public License for more details.
13
14 You should have received a copy of the GNU General Public License
15 along with this program.  If not, see <http://www.gnu.org/licenses/>.
16 */
17
18 package nncp
19
20 import (
21         "bufio"
22         "bytes"
23         "errors"
24         "io"
25         "log"
26
27         "golang.org/x/crypto/blake2b"
28 )
29
30 func Check(src io.Reader, checksum []byte, sds SDS, showPrgrs bool) (bool, error) {
31         hsh, err := blake2b.New256(nil)
32         if err != nil {
33                 log.Fatalln(err)
34         }
35         if _, err = CopyProgressed(hsh, bufio.NewReader(src), sds, showPrgrs); err != nil {
36                 return false, err
37         }
38         return bytes.Compare(hsh.Sum(nil), checksum) == 0, nil
39 }
40
41 func (ctx *Ctx) checkXxIsBad(nodeId *NodeId, xx TRxTx) bool {
42         isBad := false
43         for job := range ctx.Jobs(nodeId, xx) {
44                 sds := SDS{
45                         "xx":       string(xx),
46                         "node":     nodeId,
47                         "pkt":      ToBase32(job.HshValue[:]),
48                         "fullsize": job.Size,
49                 }
50                 gut, err := Check(job.Fd, job.HshValue[:], sds, ctx.ShowPrgrs)
51                 job.Fd.Close()
52                 if err != nil {
53                         ctx.LogE("check", sds, err, "")
54                         return true
55                 }
56                 if !gut {
57                         isBad = true
58                         ctx.LogE("check", sds, errors.New("bad"), "")
59                 }
60         }
61         return isBad
62 }
63
64 func (ctx *Ctx) Check(nodeId *NodeId) bool {
65         return !(ctx.checkXxIsBad(nodeId, TRx) || ctx.checkXxIsBad(nodeId, TTx))
66 }