/vendor/github.com/anacrolix/torrent/storage/sqlitePieceCompletion.go

https://github.com/yunionio/onecloud · Go · 55 lines · 45 code · 9 blank · 1 comment · 9 complexity · 5c3d25b66b6f92929c1a020ebdd4c8dc MD5 · raw file

  1. // +build cgo
  2. package storage
  3. import (
  4. "database/sql"
  5. "path/filepath"
  6. "github.com/anacrolix/torrent/metainfo"
  7. _ "github.com/mattn/go-sqlite3"
  8. )
  9. type sqlitePieceCompletion struct {
  10. db *sql.DB
  11. }
  12. var _ PieceCompletion = (*sqlitePieceCompletion)(nil)
  13. func NewSqlitePieceCompletion(dir string) (ret *sqlitePieceCompletion, err error) {
  14. p := filepath.Join(dir, ".torrent.db")
  15. db, err := sql.Open("sqlite3", p)
  16. if err != nil {
  17. return
  18. }
  19. db.SetMaxOpenConns(1)
  20. db.Exec(`PRAGMA journal_mode=WAL`)
  21. db.Exec(`PRAGMA synchronous=1`)
  22. _, err = db.Exec(`create table if not exists piece_completion(infohash, "index", complete, unique(infohash, "index"))`)
  23. if err != nil {
  24. db.Close()
  25. return
  26. }
  27. ret = &sqlitePieceCompletion{db}
  28. return
  29. }
  30. func (me *sqlitePieceCompletion) Get(pk metainfo.PieceKey) (c Completion, err error) {
  31. row := me.db.QueryRow(`select complete from piece_completion where infohash=? and "index"=?`, pk.InfoHash.HexString(), pk.Index)
  32. err = row.Scan(&c.Complete)
  33. if err == sql.ErrNoRows {
  34. err = nil
  35. } else if err == nil {
  36. c.Ok = true
  37. }
  38. return
  39. }
  40. func (me *sqlitePieceCompletion) Set(pk metainfo.PieceKey, b bool) error {
  41. _, err := me.db.Exec(`insert or replace into piece_completion(infohash, "index", complete) values(?, ?, ?)`, pk.InfoHash.HexString(), pk.Index, b)
  42. return err
  43. }
  44. func (me *sqlitePieceCompletion) Close() error {
  45. return me.db.Close()
  46. }