2015-05-23 20:04:16 +01:00
|
|
|
package etcd
|
2015-02-07 20:12:57 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
"github.com/coreos/go-etcd/etcd"
|
2015-05-23 20:04:16 +01:00
|
|
|
"github.com/myodc/go-micro/store"
|
2015-02-07 20:12:57 +00:00
|
|
|
)
|
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
type estore struct {
|
2015-02-07 20:12:57 +00:00
|
|
|
Client *etcd.Client
|
|
|
|
}
|
|
|
|
|
2015-05-23 21:25:55 +01:00
|
|
|
func (e *estore) Get(key string) (*store.Item, error) {
|
2015-02-07 20:12:57 +00:00
|
|
|
kv, err := e.Client.Get(key, false, false)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if kv == nil {
|
|
|
|
return nil, errors.New("key not found")
|
|
|
|
}
|
|
|
|
|
2015-05-23 21:25:55 +01:00
|
|
|
return &store.Item{
|
|
|
|
Key: kv.Node.Key,
|
|
|
|
Value: []byte(kv.Node.Value),
|
2015-02-07 20:12:57 +00:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
func (e *estore) Del(key string) error {
|
2015-02-07 20:12:57 +00:00
|
|
|
_, err := e.Client.Delete(key, false)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2015-05-23 21:25:55 +01:00
|
|
|
func (e *estore) Put(item *store.Item) error {
|
|
|
|
_, err := e.Client.Set(item.Key, string(item.Value), 0)
|
2015-02-07 20:12:57 +00:00
|
|
|
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
func NewStore(addrs []string, opts ...store.Option) store.Store {
|
2015-05-16 00:34:02 +01:00
|
|
|
if len(addrs) == 0 {
|
|
|
|
addrs = []string{"127.0.0.1:2379"}
|
|
|
|
}
|
|
|
|
|
|
|
|
client := etcd.NewClient(addrs)
|
2015-02-07 20:12:57 +00:00
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
return &estore{
|
2015-02-07 20:12:57 +00:00
|
|
|
Client: client,
|
|
|
|
}
|
|
|
|
}
|