| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- // Copyright 2016 CoreOS, Inc.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- package clientv3
- import (
- pb "github.com/coreos/etcd/etcdserver/etcdserverpb"
- "github.com/coreos/etcd/lease"
- )
- type opType int
- const (
- // A default Op has opType 0, which is invalid.
- tRange opType = iota + 1
- tPut
- tDeleteRange
- )
- // Op represents an Operation that kv can execute.
- type Op struct {
- t opType
- key []byte
- end []byte
- // for range
- limit int64
- rev int64
- sort *SortOption
- // for put
- val []byte
- leaseID lease.LeaseID
- }
- func (op Op) toRequestUnion() *pb.RequestUnion {
- switch op.t {
- case tRange:
- r := &pb.RangeRequest{Key: op.key, RangeEnd: op.end, Limit: op.limit, Revision: op.rev}
- if op.sort != nil {
- r.SortOrder = pb.RangeRequest_SortOrder(op.sort.Order)
- r.SortTarget = pb.RangeRequest_SortTarget(op.sort.Target)
- }
- return &pb.RequestUnion{Request: &pb.RequestUnion_RequestRange{RequestRange: r}}
- case tPut:
- r := &pb.PutRequest{Key: op.key, Value: op.val, Lease: int64(op.leaseID)}
- return &pb.RequestUnion{Request: &pb.RequestUnion_RequestPut{RequestPut: r}}
- case tDeleteRange:
- r := &pb.DeleteRangeRequest{Key: op.key, RangeEnd: op.end}
- return &pb.RequestUnion{Request: &pb.RequestUnion_RequestDeleteRange{RequestDeleteRange: r}}
- default:
- panic("Unknown Op")
- }
- }
- func (op Op) isWrite() bool {
- return op.t != tRange
- }
- func OpGet(key string, opts ...OpOption) Op {
- ret := Op{t: tRange, key: []byte(key)}
- ret.applyOpts(opts)
- return ret
- }
- func OpDelete(key string, opts ...OpOption) Op {
- ret := Op{t: tDeleteRange, key: []byte(key)}
- ret.applyOpts(opts)
- switch {
- case ret.leaseID != 0:
- panic("unexpected lease in delete")
- case ret.limit != 0:
- panic("unexpected limit in delete")
- case ret.rev != 0:
- panic("unexpected revision in delete")
- case ret.sort != nil:
- panic("unexpected sort in delete")
- }
- return ret
- }
- func OpPut(key, val string, opts ...OpOption) Op {
- ret := Op{t: tPut, key: []byte(key), val: []byte(val)}
- ret.applyOpts(opts)
- switch {
- case ret.end != nil:
- panic("unexpected range in put")
- case ret.limit != 0:
- panic("unexpected limit in put")
- case ret.rev != 0:
- panic("unexpected revision in put")
- case ret.sort != nil:
- panic("unexpected sort in put")
- }
- return ret
- }
- func (op *Op) applyOpts(opts []OpOption) {
- for _, opt := range opts {
- opt(op)
- }
- }
- type OpOption func(*Op)
- func WithLease(leaseID lease.LeaseID) OpOption {
- return func(op *Op) { op.leaseID = leaseID }
- }
- func WithLimit(n int64) OpOption { return func(op *Op) { op.limit = n } }
- func WithRev(rev int64) OpOption { return func(op *Op) { op.rev = rev } }
- func WithSort(tgt SortTarget, order SortOrder) OpOption {
- return func(op *Op) {
- op.sort = &SortOption{tgt, order}
- }
- }
- func WithRange(endKey string) OpOption {
- return func(op *Op) { op.end = []byte(endKey) }
- }
|