mirror of
https://github.com/LBRYFoundation/tracker.git
synced 2025-09-11 21:19:52 +00:00
Refactor setting up writes in the redis driver
This commit is contained in:
parent
5084a2ac94
commit
55d2c4ae84
1 changed files with 30 additions and 80 deletions
|
@ -113,6 +113,16 @@ func (tx *Tx) close() {
|
||||||
tx.Conn.Close()
|
tx.Conn.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (tx *Tx) initiateWrite() error {
|
||||||
|
if tx.done {
|
||||||
|
return storage.ErrTxDone
|
||||||
|
}
|
||||||
|
if tx.multi != true {
|
||||||
|
return tx.Send("MULTI")
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func (tx *Tx) Commit() error {
|
func (tx *Tx) Commit() error {
|
||||||
if tx.done {
|
if tx.done {
|
||||||
return storage.ErrTxDone
|
return storage.ErrTxDone
|
||||||
|
@ -213,150 +223,90 @@ func (tx *Tx) ClientWhitelisted(peerID string) (exists bool, err error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) RecordSnatch(user *storage.User, torrent *storage.Torrent) error {
|
func (tx *Tx) RecordSnatch(user *storage.User, torrent *storage.Torrent) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) MarkActive(t *storage.Torrent) error {
|
func (tx *Tx) MarkActive(t *storage.Torrent) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) AddLeecher(t *storage.Torrent, p *storage.Peer) error {
|
func (tx *Tx) AddLeecher(t *storage.Torrent, p *storage.Peer) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) SetLeecher(t *storage.Torrent, p *storage.Peer) error {
|
func (tx *Tx) SetLeecher(t *storage.Torrent, p *storage.Peer) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) RemoveLeecher(t *storage.Torrent, p *storage.Peer) error {
|
func (tx *Tx) RemoveLeecher(t *storage.Torrent, p *storage.Peer) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) AddSeeder(t *storage.Torrent, p *storage.Peer) error {
|
func (tx *Tx) AddSeeder(t *storage.Torrent, p *storage.Peer) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) SetSeeder(t *storage.Torrent, p *storage.Peer) error {
|
func (tx *Tx) SetSeeder(t *storage.Torrent, p *storage.Peer) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) RemoveSeeder(t *storage.Torrent, p *storage.Peer) error {
|
func (tx *Tx) RemoveSeeder(t *storage.Torrent, p *storage.Peer) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) IncrementSlots(u *storage.User) error {
|
func (tx *Tx) IncrementSlots(u *storage.User) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *Tx) DecrementSlots(u *storage.User) error {
|
func (tx *Tx) DecrementSlots(u *storage.User) error {
|
||||||
if tx.done {
|
if err := tx.initiateWrite(); err != nil {
|
||||||
return storage.ErrTxDone
|
|
||||||
}
|
|
||||||
if tx.multi != true {
|
|
||||||
err := tx.Send("MULTI")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// TODO
|
// TODO
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Add table
Reference in a new issue