mirror of
https://github.com/gofiber/storage.git
synced 2025-10-24 08:53:08 +08:00
121 lines
2.5 KiB
Go
121 lines
2.5 KiB
Go
package couchbase
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/couchbase/gocb/v2"
|
|
)
|
|
|
|
type Storage struct {
|
|
cb *gocb.Cluster
|
|
bucket *gocb.Bucket
|
|
}
|
|
|
|
func New(config ...Config) *Storage {
|
|
// Set default config
|
|
cfg := configDefault(config...)
|
|
|
|
cb, err := gocb.Connect(cfg.Host, gocb.ClusterOptions{
|
|
Authenticator: gocb.PasswordAuthenticator{
|
|
Username: cfg.Username,
|
|
Password: cfg.Password,
|
|
},
|
|
TimeoutsConfig: gocb.TimeoutsConfig{
|
|
ConnectTimeout: cfg.ConnectionTimeout,
|
|
KVTimeout: cfg.KVTimeout,
|
|
},
|
|
Transcoder: gocb.NewLegacyTranscoder(),
|
|
})
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
_, err = cb.Ping(&gocb.PingOptions{
|
|
Timeout: cfg.ConnectionTimeout,
|
|
})
|
|
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
b := cb.Bucket(cfg.Bucket)
|
|
|
|
return &Storage{cb: cb, bucket: b}
|
|
}
|
|
|
|
func (s *Storage) GetWithContext(ctx context.Context, key string) ([]byte, error) {
|
|
out, err := s.bucket.DefaultCollection().Get(key, &gocb.GetOptions{
|
|
Context: ctx,
|
|
})
|
|
if err != nil {
|
|
switch e := err.(type) {
|
|
case *gocb.KeyValueError:
|
|
if e.InnerError.Error() == gocb.ErrDocumentNotFound.Error() {
|
|
return nil, nil
|
|
}
|
|
default: //*gocb.TimeoutError,...
|
|
return nil, err
|
|
}
|
|
|
|
return nil, err
|
|
}
|
|
|
|
var value []byte
|
|
if err := out.Content(&value); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return value, nil
|
|
}
|
|
|
|
func (s *Storage) Get(key string) ([]byte, error) {
|
|
return s.GetWithContext(context.Background(), key)
|
|
}
|
|
|
|
func (s *Storage) SetWithContext(ctx context.Context, key string, val []byte, exp time.Duration) error {
|
|
if _, err := s.bucket.DefaultCollection().Upsert(key, val, &gocb.UpsertOptions{
|
|
Context: ctx,
|
|
Expiry: exp,
|
|
}); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (s *Storage) Set(key string, val []byte, exp time.Duration) error {
|
|
return s.SetWithContext(context.Background(), key, val, exp)
|
|
}
|
|
|
|
func (s *Storage) DeleteWithContext(ctx context.Context, key string) error {
|
|
if _, err := s.bucket.DefaultCollection().Remove(key, &gocb.RemoveOptions{
|
|
Context: ctx,
|
|
}); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (s *Storage) Delete(key string) error {
|
|
return s.DeleteWithContext(context.Background(), key)
|
|
}
|
|
|
|
func (s *Storage) ResetWithContext(ctx context.Context) error {
|
|
return s.cb.Buckets().FlushBucket(s.bucket.Name(), &gocb.FlushBucketOptions{
|
|
Context: ctx,
|
|
})
|
|
}
|
|
|
|
func (s *Storage) Reset() error {
|
|
return s.ResetWithContext(context.Background())
|
|
}
|
|
|
|
func (s *Storage) Close() error {
|
|
return s.cb.Close(nil)
|
|
}
|
|
|
|
func (s *Storage) Conn() *gocb.Cluster {
|
|
return s.cb
|
|
}
|