2014-12-07 20:21:12 +00:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
|
|
|
//
|
2015-03-07 21:36:35 +01:00
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
2017-02-09 07:52:18 +01:00
|
|
|
// You can obtain one at https://mozilla.org/MPL/2.0/.
|
2014-12-07 20:21:12 +00:00
|
|
|
|
|
|
|
package stats
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2015-08-06 11:29:25 +02:00
|
|
|
"github.com/syncthing/syncthing/lib/db"
|
2014-12-07 20:21:12 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type FolderStatistics struct {
|
2016-06-02 19:26:52 +00:00
|
|
|
LastFile LastFile `json:"lastFile"`
|
|
|
|
LastScan time.Time `json:"lastScan"`
|
2014-12-07 20:21:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type FolderStatisticsReference struct {
|
2015-01-17 20:53:33 +01:00
|
|
|
ns *db.NamespacedKV
|
2014-12-07 20:21:12 +00:00
|
|
|
folder string
|
|
|
|
}
|
|
|
|
|
2015-01-17 20:53:33 +01:00
|
|
|
type LastFile struct {
|
2015-03-10 23:45:43 +01:00
|
|
|
At time.Time `json:"at"`
|
|
|
|
Filename string `json:"filename"`
|
2015-06-16 12:12:34 +01:00
|
|
|
Deleted bool `json:"deleted"`
|
2015-01-17 20:53:33 +01:00
|
|
|
}
|
|
|
|
|
2018-10-10 11:34:24 +02:00
|
|
|
func NewFolderStatisticsReference(ldb *db.Lowlevel, folder string) *FolderStatisticsReference {
|
2014-12-07 20:21:12 +00:00
|
|
|
return &FolderStatisticsReference{
|
2018-10-10 11:34:24 +02:00
|
|
|
ns: db.NewFolderStatisticsNamespace(ldb, folder),
|
2014-12-07 20:21:12 +00:00
|
|
|
folder: folder,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-30 13:03:24 +01:00
|
|
|
func (s *FolderStatisticsReference) GetLastFile() (LastFile, error) {
|
|
|
|
at, ok, err := s.ns.Time("lastFileAt")
|
|
|
|
if err != nil {
|
|
|
|
return LastFile{}, err
|
|
|
|
} else if !ok {
|
|
|
|
return LastFile{}, nil
|
2014-12-07 20:21:12 +00:00
|
|
|
}
|
2019-11-30 13:03:24 +01:00
|
|
|
file, ok, err := s.ns.String("lastFileName")
|
|
|
|
if err != nil {
|
|
|
|
return LastFile{}, err
|
|
|
|
} else if !ok {
|
|
|
|
return LastFile{}, nil
|
|
|
|
}
|
|
|
|
deleted, _, err := s.ns.Bool("lastFileDeleted")
|
|
|
|
if err != nil {
|
|
|
|
return LastFile{}, err
|
2015-01-17 20:53:33 +01:00
|
|
|
}
|
|
|
|
return LastFile{
|
|
|
|
At: at,
|
|
|
|
Filename: file,
|
2015-06-16 12:12:34 +01:00
|
|
|
Deleted: deleted,
|
2019-11-30 13:03:24 +01:00
|
|
|
}, nil
|
2014-12-07 20:21:12 +00:00
|
|
|
}
|
|
|
|
|
2019-11-30 13:03:24 +01:00
|
|
|
func (s *FolderStatisticsReference) ReceivedFile(file string, deleted bool) error {
|
2015-10-03 17:25:21 +02:00
|
|
|
l.Debugln("stats.FolderStatisticsReference.ReceivedFile:", s.folder, file)
|
2021-03-12 10:35:10 +01:00
|
|
|
if err := s.ns.PutTime("lastFileAt", time.Now().Truncate(time.Second)); err != nil {
|
2019-11-30 13:03:24 +01:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := s.ns.PutString("lastFileName", file); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := s.ns.PutBool("lastFileDeleted", deleted); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return nil
|
2014-12-07 20:21:12 +00:00
|
|
|
}
|
|
|
|
|
2019-11-30 13:03:24 +01:00
|
|
|
func (s *FolderStatisticsReference) ScanCompleted() error {
|
2021-03-12 10:35:10 +01:00
|
|
|
return s.ns.PutTime("lastScan", time.Now().Truncate(time.Second))
|
2016-06-02 19:26:52 +00:00
|
|
|
}
|
|
|
|
|
2019-11-30 13:03:24 +01:00
|
|
|
func (s *FolderStatisticsReference) GetLastScanTime() (time.Time, error) {
|
|
|
|
lastScan, ok, err := s.ns.Time("lastScan")
|
|
|
|
if err != nil {
|
|
|
|
return time.Time{}, err
|
|
|
|
} else if !ok {
|
|
|
|
return time.Time{}, nil
|
2016-06-02 19:26:52 +00:00
|
|
|
}
|
2019-11-30 13:03:24 +01:00
|
|
|
return lastScan, nil
|
2016-06-02 19:26:52 +00:00
|
|
|
}
|
|
|
|
|
2019-11-30 13:03:24 +01:00
|
|
|
func (s *FolderStatisticsReference) GetStatistics() (FolderStatistics, error) {
|
|
|
|
lastFile, err := s.GetLastFile()
|
|
|
|
if err != nil {
|
|
|
|
return FolderStatistics{}, err
|
2014-12-07 20:21:12 +00:00
|
|
|
}
|
2019-11-30 13:03:24 +01:00
|
|
|
lastScanTime, err := s.GetLastScanTime()
|
|
|
|
if err != nil {
|
|
|
|
return FolderStatistics{}, err
|
|
|
|
}
|
|
|
|
return FolderStatistics{
|
|
|
|
LastFile: lastFile,
|
|
|
|
LastScan: lastScanTime,
|
|
|
|
}, nil
|
2014-12-07 20:21:12 +00:00
|
|
|
}
|