add reader stat to torrent stat

This commit is contained in:
YouROK
2021-05-27 08:34:19 +03:00
parent bd44ebaf2b
commit 2af1752a00
5 changed files with 23 additions and 9 deletions

View File

@@ -1,5 +1,9 @@
package state package state
import (
"server/torr/storage/reader"
)
type TorrentStat int type TorrentStat int
func (t TorrentStat) String() string { func (t TorrentStat) String() string {
@@ -62,6 +66,8 @@ type TorrentStatus struct {
PiecesDirtiedGood int64 `json:"pieces_dirtied_good,omitempty"` PiecesDirtiedGood int64 `json:"pieces_dirtied_good,omitempty"`
PiecesDirtiedBad int64 `json:"pieces_dirtied_bad,omitempty"` PiecesDirtiedBad int64 `json:"pieces_dirtied_bad,omitempty"`
Readers []*reader.ReaderState `json:"readers,omitempty"`
FileStats []*TorrentFileStat `json:"file_stats,omitempty"` FileStats []*TorrentFileStat `json:"file_stats,omitempty"`
} }

View File

@@ -0,0 +1,7 @@
package reader
type ReaderState struct {
Start int
End int
Reader int
}

View File

@@ -2,6 +2,7 @@ package state
import ( import (
"server/torr/state" "server/torr/state"
"server/torr/storage/reader"
) )
type CacheState struct { type CacheState struct {
@@ -12,7 +13,7 @@ type CacheState struct {
PiecesCount int PiecesCount int
Torrent *state.TorrentStatus Torrent *state.TorrentStatus
Pieces map[int]ItemState Pieces map[int]ItemState
Readers []*ReaderState Readers []*reader.ReaderState
} }
type ItemState struct { type ItemState struct {
@@ -21,9 +22,3 @@ type ItemState struct {
Size int64 Size int64
Completed bool Completed bool
} }
type ReaderState struct {
Start int
End int
Reader int
}

View File

@@ -13,6 +13,7 @@ import (
"server/log" "server/log"
"server/settings" "server/settings"
"server/torr/storage/reader"
"server/torr/storage/state" "server/torr/storage/state"
"server/torr/utils" "server/torr/utils"
@@ -149,12 +150,12 @@ func (c *Cache) GetState() *state.CacheState {
} }
} }
readersState := make([]*state.ReaderState, 0) readersState := make([]*reader.ReaderState, 0)
c.muReaders.Lock() c.muReaders.Lock()
for r, _ := range c.readers { for r, _ := range c.readers {
rng := r.getPiecesRange() rng := r.getPiecesRange()
pc := r.getReaderPiece() pc := r.getReaderPiece()
readersState = append(readersState, &state.ReaderState{ readersState = append(readersState, &reader.ReaderState{
Start: rng.Start, Start: rng.Start,
End: rng.End, End: rng.End,
Reader: pc, Reader: pc,

View File

@@ -427,6 +427,11 @@ func (t *Torrent) Status() *state.TorrentStatus {
} }
} }
} }
if t.cache != nil {
st.Readers = t.cache.GetState().Readers
}
return st return st
} }