mirror of
https://github.com/Ernous/TorrServerJellyfin.git
synced 2025-12-19 13:36:09 +05:00
add reader stat to torrent stat
This commit is contained in:
@@ -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"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
7
server/torr/storage/reader/state.go
Normal file
7
server/torr/storage/reader/state.go
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
package reader
|
||||||
|
|
||||||
|
type ReaderState struct {
|
||||||
|
Start int
|
||||||
|
End int
|
||||||
|
Reader int
|
||||||
|
}
|
||||||
@@ -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
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -427,6 +427,11 @@ func (t *Torrent) Status() *state.TorrentStatus {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if t.cache != nil {
|
||||||
|
st.Readers = t.cache.GetState().Readers
|
||||||
|
}
|
||||||
|
|
||||||
return st
|
return st
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user