forked from OpenBazaar/openbazaar-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
watched_scripts.go
71 lines (65 loc) · 1.63 KB
/
watched_scripts.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package db
import (
"database/sql"
"encoding/hex"
"github.com/OpenBazaar/openbazaar-go/repo"
"github.com/OpenBazaar/wallet-interface"
"sync"
)
type WatchedScriptsDB struct {
modelStore
coinType wallet.CoinType
}
func NewWatchedScriptStore(db *sql.DB, lock *sync.Mutex, coinType wallet.CoinType) repo.WatchedScriptStore {
return &WatchedScriptsDB{modelStore{db, lock}, coinType}
}
func (w *WatchedScriptsDB) Put(scriptPubKey []byte) error {
w.lock.Lock()
defer w.lock.Unlock()
tx, _ := w.db.Begin()
stmt, err := tx.Prepare("insert or replace into watchedscripts(coin, scriptPubKey) values(?,?)")
if err != nil {
tx.Rollback()
return err
}
defer stmt.Close()
_, err = stmt.Exec(w.coinType.CurrencyCode(), hex.EncodeToString(scriptPubKey))
if err != nil {
tx.Rollback()
return err
}
tx.Commit()
return nil
}
func (w *WatchedScriptsDB) GetAll() ([][]byte, error) {
w.lock.Lock()
defer w.lock.Unlock()
var ret [][]byte
stm := "select scriptPubKey from watchedscripts where coin=?"
rows, err := w.db.Query(stm, w.coinType.CurrencyCode())
if err != nil {
return ret, err
}
defer rows.Close()
for rows.Next() {
var scriptHex string
if err := rows.Scan(&scriptHex); err != nil {
continue
}
scriptPubKey, err := hex.DecodeString(scriptHex)
if err != nil {
continue
}
ret = append(ret, scriptPubKey)
}
return ret, nil
}
func (w *WatchedScriptsDB) Delete(scriptPubKey []byte) error {
w.lock.Lock()
defer w.lock.Unlock()
_, err := w.db.Exec("delete from watchedscripts where scriptPubKey=? and coin=?", hex.EncodeToString(scriptPubKey), w.coinType.CurrencyCode())
if err != nil {
return err
}
return nil
}