seaweedfs/weed/filer/arangodb/arangodb_store_kv.go

55 lines
1.4 KiB
Go
Raw Normal View History

2022-03-17 17:49:26 +08:00
package arangodb
import (
"context"
"fmt"
2022-03-18 10:12:25 +08:00
"github.com/arangodb/go-driver"
2022-03-17 17:49:26 +08:00
"github.com/chrislusf/seaweedfs/weed/filer"
"github.com/chrislusf/seaweedfs/weed/glog"
)
func (store *ArangodbStore) KvPut(ctx context.Context, key []byte, value []byte) (err error) {
model := &Model{
2022-03-18 10:12:25 +08:00
Key: hashString(".kvstore." + string(key)),
Directory: ".kvstore." + string(key),
2022-03-17 17:49:26 +08:00
Meta: bytesToArray(value),
}
exists, err := store.kvCollection.DocumentExists(ctx, model.Key)
2022-03-17 17:49:26 +08:00
if err != nil {
return fmt.Errorf("kv put: %v", err)
}
if exists {
_, err = store.kvCollection.UpdateDocument(ctx, model.Key, model)
2022-03-17 17:49:26 +08:00
} else {
_, err = store.kvCollection.CreateDocument(ctx, model)
2022-03-17 17:49:26 +08:00
}
if err != nil {
return fmt.Errorf("kv put: %v", err)
}
return nil
}
func (store *ArangodbStore) KvGet(ctx context.Context, key []byte) (value []byte, err error) {
var model Model
_, err = store.kvCollection.ReadDocument(ctx, hashString(".kvstore."+string(key)), &model)
2022-03-18 10:12:25 +08:00
if driver.IsNotFound(err) {
return nil, filer.ErrKvNotFound
}
2022-03-17 17:49:26 +08:00
if err != nil {
2022-03-18 10:12:25 +08:00
glog.Errorf("kv get: %s %v", string(key), err)
2022-03-17 17:49:26 +08:00
return nil, filer.ErrKvNotFound
}
return arrayToBytes(model.Meta), nil
}
func (store *ArangodbStore) KvDelete(ctx context.Context, key []byte) (err error) {
_, err = store.kvCollection.RemoveDocument(ctx, hashString(".kvstore."+string(key)))
2022-03-17 17:49:26 +08:00
if err != nil {
glog.Errorf("kv del: %v", err)
return filer.ErrKvNotFound
}
return nil
}