1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-05 10:20:53 +02:00
go-micro/store/store.go
2019-10-11 14:08:50 +01:00

35 lines
642 B
Go

// Package store is an interface for distribute data storage.
package store
import (
"errors"
"time"
"github.com/micro/go-micro/config/options"
)
var (
ErrNotFound = errors.New("not found")
)
// Store is a data storage interface
type Store interface {
// embed options
options.Options
// Sync all the known records
Sync() ([]*Record, error)
// Read a record with key
Read(keys ...string) ([]*Record, error)
// Write a record
Write(recs ...*Record) error
// Delete a record with key
Delete(keys ...string) error
}
// Record represents a data record
type Record struct {
Key string
Value []byte
Expiry time.Duration
}