/
lease.go
97 lines (74 loc) · 2.32 KB
/
lease.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package zetcd
import (
"context"
"fmt"
clientv3 "go.etcd.io/etcd/client/v3"
)
func CreateLease(ctx context.Context, client *clientv3.Client, leaseTTL int64) (*clientv3.LeaseGrantResponse, clientv3.LeaseID, error) {
if client == nil {
return nil, 0, fmt.Errorf("client is nil")
}
response, err := client.Grant(ctx, leaseTTL)
if err != nil {
return nil, 0, err
}
leaseID := response.ID
return response, leaseID, nil
}
func RevokeLease(ctx context.Context, client *clientv3.Client, leaseID clientv3.LeaseID) (*clientv3.LeaseRevokeResponse, error) {
if client == nil {
return nil, fmt.Errorf("client is nil")
}
response, err := client.Revoke(ctx, leaseID)
if err != nil {
return nil, err
}
return response, nil
}
// KeepAliveAways keep a lease aways.
func KeepAliveAways(ctx context.Context, client *clientv3.Client, leaseID clientv3.LeaseID) (<-chan *clientv3.LeaseKeepAliveResponse, error) {
if client == nil {
return nil, fmt.Errorf("client is nil")
}
ch, err := client.KeepAlive(ctx, leaseID)
if err != nil {
return nil, err
}
return ch, nil
}
// KeepAliveOnce keep a lease once.
func KeepAliveOnce(ctx context.Context, client *clientv3.Client, leaseID clientv3.LeaseID) (*clientv3.LeaseKeepAliveResponse, error) {
if client == nil {
return nil, fmt.Errorf("client is nil")
}
response, err := client.KeepAliveOnce(ctx, leaseID)
if err != nil {
return nil, err
}
return response, nil
}
// LeaseTimeToLive retrieves the lease information of the given lease ID.
func LeaseTimeToLive(ctx context.Context, client *clientv3.Client, leaseID clientv3.LeaseID) (*clientv3.LeaseTimeToLiveResponse, map[string]string, error) {
if client == nil {
return nil, nil, fmt.Errorf("client is nil")
}
data := make(map[string]string)
response, err := client.TimeToLive(ctx, leaseID, clientv3.WithAttachedKeys())
if err != nil {
return nil, data, err
}
if response.ID != leaseID {
return nil, data, fmt.Errorf("leaseID expected %d, got %d", leaseID, response.ID)
}
if response.TTL == 0 || response.TTL > response.GrantedTTL {
return nil, data, fmt.Errorf("unexpected TTL %d (granted %d)", response.TTL, response.GrantedTTL)
}
ks := make([]string, len(response.Keys))
for i := range response.Keys {
ks[i] = string(response.Keys[i])
}
for _, key := range ks {
data[key] = ""
}
return response, data, nil
}