2019-10-11 14:08:50 +01:00
|
|
|
package handler
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/micro/go-micro/errors"
|
|
|
|
"github.com/micro/go-micro/store"
|
|
|
|
pb "github.com/micro/go-micro/store/service/proto"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Store struct {
|
|
|
|
Store store.Store
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Store) Read(ctx context.Context, req *pb.ReadRequest, rsp *pb.ReadResponse) error {
|
|
|
|
vals, err := s.Store.Read(req.Keys...)
|
|
|
|
if err != nil {
|
|
|
|
return errors.InternalServerError("go.micro.store", err.Error())
|
|
|
|
}
|
|
|
|
for _, val := range vals {
|
|
|
|
rsp.Records = append(rsp.Records, &pb.Record{
|
|
|
|
Key: val.Key,
|
|
|
|
Value: val.Value,
|
|
|
|
Expiry: int64(val.Expiry.Seconds()),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Store) Write(ctx context.Context, req *pb.WriteRequest, rsp *pb.WriteResponse) error {
|
2019-12-03 22:59:44 +03:00
|
|
|
records := make([]*store.Record, 0, len(req.Records))
|
2019-10-11 14:08:50 +01:00
|
|
|
|
|
|
|
for _, record := range req.Records {
|
|
|
|
records = append(records, &store.Record{
|
|
|
|
Key: record.Key,
|
|
|
|
Value: record.Value,
|
|
|
|
Expiry: time.Duration(record.Expiry) * time.Second,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
err := s.Store.Write(records...)
|
|
|
|
if err != nil {
|
|
|
|
return errors.InternalServerError("go.micro.store", err.Error())
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Store) Delete(ctx context.Context, req *pb.DeleteRequest, rsp *pb.DeleteResponse) error {
|
|
|
|
err := s.Store.Delete(req.Keys...)
|
|
|
|
if err != nil {
|
|
|
|
return errors.InternalServerError("go.micro.store", err.Error())
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2019-10-23 22:05:39 +01:00
|
|
|
func (s *Store) List(ctx context.Context, req *pb.ListRequest, stream pb.Store_ListStream) error {
|
2019-10-11 14:08:50 +01:00
|
|
|
var vals []*store.Record
|
|
|
|
var err error
|
|
|
|
|
|
|
|
if len(req.Key) > 0 {
|
|
|
|
vals, err = s.Store.Read(req.Key)
|
|
|
|
} else {
|
2019-10-23 22:05:39 +01:00
|
|
|
vals, err = s.Store.List()
|
2019-10-11 14:08:50 +01:00
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return errors.InternalServerError("go.micro.store", err.Error())
|
|
|
|
}
|
2019-10-23 22:05:39 +01:00
|
|
|
rsp := new(pb.ListResponse)
|
2019-10-11 14:08:50 +01:00
|
|
|
|
|
|
|
// TODO: batch sync
|
|
|
|
for _, val := range vals {
|
|
|
|
rsp.Records = append(rsp.Records, &pb.Record{
|
|
|
|
Key: val.Key,
|
|
|
|
Value: val.Value,
|
|
|
|
Expiry: int64(val.Expiry.Seconds()),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
err = stream.Send(rsp)
|
|
|
|
if err == io.EOF {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
return errors.InternalServerError("go.micro.store", err.Error())
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|