mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-12-18 11:00:25 +00:00
rebase: update vault/api to v1.1.1
Signed-off-by: Niels de Vos <ndevos@redhat.com>
This commit is contained in:
parent
b85076365c
commit
bb68cc9bee
5
go.mod
5
go.mod
@ -12,10 +12,10 @@ require (
|
|||||||
github.com/grpc-ecosystem/go-grpc-middleware v1.3.0
|
github.com/grpc-ecosystem/go-grpc-middleware v1.3.0
|
||||||
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0
|
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0
|
||||||
github.com/hashicorp/golang-lru v0.5.4 // indirect
|
github.com/hashicorp/golang-lru v0.5.4 // indirect
|
||||||
github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a
|
github.com/hashicorp/vault/api v1.1.1
|
||||||
github.com/kubernetes-csi/csi-lib-utils v0.10.0
|
github.com/kubernetes-csi/csi-lib-utils v0.10.0
|
||||||
github.com/kubernetes-csi/external-snapshotter/client/v4 v4.2.0
|
github.com/kubernetes-csi/external-snapshotter/client/v4 v4.2.0
|
||||||
github.com/libopenstorage/secrets v0.0.0-20210709082113-dde442ea20ec
|
github.com/libopenstorage/secrets v0.0.0-20210908194121-a1d19aa9713a
|
||||||
github.com/onsi/ginkgo v1.16.4
|
github.com/onsi/ginkgo v1.16.4
|
||||||
github.com/onsi/gomega v1.16.0
|
github.com/onsi/gomega v1.16.0
|
||||||
github.com/pborman/uuid v1.2.1
|
github.com/pborman/uuid v1.2.1
|
||||||
@ -38,7 +38,6 @@ require (
|
|||||||
replace (
|
replace (
|
||||||
code.cloudfoundry.org/gofileutils => github.com/cloudfoundry/gofileutils v0.0.0-20170111115228-4d0c80011a0f
|
code.cloudfoundry.org/gofileutils => github.com/cloudfoundry/gofileutils v0.0.0-20170111115228-4d0c80011a0f
|
||||||
github.com/golang/protobuf => github.com/golang/protobuf v1.4.3
|
github.com/golang/protobuf => github.com/golang/protobuf v1.4.3
|
||||||
github.com/hashicorp/vault/api => github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a
|
|
||||||
github.com/hashicorp/vault/sdk => github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b
|
github.com/hashicorp/vault/sdk => github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b
|
||||||
github.com/portworx/sched-ops => github.com/portworx/sched-ops v0.20.4-openstorage-rc3
|
github.com/portworx/sched-ops => github.com/portworx/sched-ops v0.20.4-openstorage-rc3
|
||||||
gomodules.xyz/jsonpatch/v2 => github.com/gomodules/jsonpatch/v2 v2.2.0
|
gomodules.xyz/jsonpatch/v2 => github.com/gomodules/jsonpatch/v2 v2.2.0
|
||||||
|
20
go.sum
20
go.sum
@ -155,7 +155,10 @@ github.com/bmizerany/assert v0.0.0-20160611221934-b7ed37b82869/go.mod h1:Ekp36dR
|
|||||||
github.com/boltdb/bolt v1.3.1/go.mod h1:clJnj/oiGkjum5o1McbSZDSLxVThjynRyGBgiAx27Ps=
|
github.com/boltdb/bolt v1.3.1/go.mod h1:clJnj/oiGkjum5o1McbSZDSLxVThjynRyGBgiAx27Ps=
|
||||||
github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8=
|
github.com/boombuler/barcode v1.0.1-0.20190219062509-6c824513bacc/go.mod h1:paBWMcWSl3LHKBqUq+rly7CNSldXjb2rDl3JlRe0mD8=
|
||||||
github.com/briankassouf/jose v0.9.2-0.20180619214549-d2569464773f/go.mod h1:HQhVmdUf7dBNwIIdBTivnCDxcf6IZY3/zrb+uKSJz6Y=
|
github.com/briankassouf/jose v0.9.2-0.20180619214549-d2569464773f/go.mod h1:HQhVmdUf7dBNwIIdBTivnCDxcf6IZY3/zrb+uKSJz6Y=
|
||||||
|
github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4=
|
||||||
github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM=
|
github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM=
|
||||||
|
github.com/cenkalti/backoff/v3 v3.0.0 h1:ske+9nBpD9qZsTBoF41nW5L+AIuFBKMeze18XQ3eG1c=
|
||||||
|
github.com/cenkalti/backoff/v3 v3.0.0/go.mod h1:cIeZDE3IrqwwJl6VUwCN6trj1oXrTS4rc0ij+ULvLYs=
|
||||||
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
||||||
github.com/centrify/cloud-golang-sdk v0.0.0-20190214225812-119110094d0f/go.mod h1:C0rtzmGXgN78pYR0tGJFhtHgkbAs0lIbHwkB81VxDQE=
|
github.com/centrify/cloud-golang-sdk v0.0.0-20190214225812-119110094d0f/go.mod h1:C0rtzmGXgN78pYR0tGJFhtHgkbAs0lIbHwkB81VxDQE=
|
||||||
github.com/ceph/go-ceph v0.11.0 h1:A1pphV40LL8GQKDPpU4XqCa7gkmozsst7rhCC730/nk=
|
github.com/ceph/go-ceph v0.11.0 h1:A1pphV40LL8GQKDPpU4XqCa7gkmozsst7rhCC730/nk=
|
||||||
@ -486,8 +489,9 @@ github.com/hashicorp/go-hclog v0.9.1/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrj
|
|||||||
github.com/hashicorp/go-hclog v0.9.2/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ=
|
github.com/hashicorp/go-hclog v0.9.2/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ=
|
||||||
github.com/hashicorp/go-hclog v0.10.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
github.com/hashicorp/go-hclog v0.10.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
||||||
github.com/hashicorp/go-hclog v0.12.0/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
github.com/hashicorp/go-hclog v0.12.0/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
||||||
github.com/hashicorp/go-hclog v0.14.1 h1:nQcJDQwIAGnmoUWp8ubocEX40cCml/17YkF6csQLReU=
|
|
||||||
github.com/hashicorp/go-hclog v0.14.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
github.com/hashicorp/go-hclog v0.14.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
||||||
|
github.com/hashicorp/go-hclog v0.16.1 h1:IVQwpTGNRRIHafnTs2dQLIk4ENtneRIEEJWOVDqz99o=
|
||||||
|
github.com/hashicorp/go-hclog v0.16.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
||||||
github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
||||||
github.com/hashicorp/go-immutable-radix v1.1.0 h1:vN9wG1D6KG6YHRTWr8512cxGOVgTMEfgEdSj/hr8MPc=
|
github.com/hashicorp/go-immutable-radix v1.1.0 h1:vN9wG1D6KG6YHRTWr8512cxGOVgTMEfgEdSj/hr8MPc=
|
||||||
github.com/hashicorp/go-immutable-radix v1.1.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
github.com/hashicorp/go-immutable-radix v1.1.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
||||||
@ -508,6 +512,7 @@ github.com/hashicorp/go-plugin v1.0.1/go.mod h1:++UyYGoz3o5w9ZzAdZxtQKrWWP+iqPBn
|
|||||||
github.com/hashicorp/go-raftchunking v0.6.3-0.20191002164813-7e9e8525653a h1:FmnBDwGwlTgugDGbVxwV8UavqSMACbGrUpfc98yFLR4=
|
github.com/hashicorp/go-raftchunking v0.6.3-0.20191002164813-7e9e8525653a h1:FmnBDwGwlTgugDGbVxwV8UavqSMACbGrUpfc98yFLR4=
|
||||||
github.com/hashicorp/go-raftchunking v0.6.3-0.20191002164813-7e9e8525653a/go.mod h1:xbXnmKqX9/+RhPkJ4zrEx4738HacP72aaUPlT2RZ4sU=
|
github.com/hashicorp/go-raftchunking v0.6.3-0.20191002164813-7e9e8525653a/go.mod h1:xbXnmKqX9/+RhPkJ4zrEx4738HacP72aaUPlT2RZ4sU=
|
||||||
github.com/hashicorp/go-retryablehttp v0.5.3/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
|
github.com/hashicorp/go-retryablehttp v0.5.3/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
|
||||||
|
github.com/hashicorp/go-retryablehttp v0.5.4/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.2/go.mod h1:gEx6HMUGxYYhJScX7W1Il64m6cc2C1mDaW3NQ9sY1FY=
|
github.com/hashicorp/go-retryablehttp v0.6.2/go.mod h1:gEx6HMUGxYYhJScX7W1Il64m6cc2C1mDaW3NQ9sY1FY=
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.6 h1:HJunrbHTDDbBb/ay4kxa1n+dLmttUlnP3V9oNE4hmsM=
|
github.com/hashicorp/go-retryablehttp v0.6.6 h1:HJunrbHTDDbBb/ay4kxa1n+dLmttUlnP3V9oNE4hmsM=
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.6/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
github.com/hashicorp/go-retryablehttp v0.6.6/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
||||||
@ -570,8 +575,15 @@ github.com/hashicorp/vault-plugin-secrets-gcpkms v0.5.5/go.mod h1:b6RwFD1bny1zbf
|
|||||||
github.com/hashicorp/vault-plugin-secrets-kv v0.5.5/go.mod h1:oNyUoMMQq6uNTwyYPnkldiedaknYbPfQIdKoyKQdy2g=
|
github.com/hashicorp/vault-plugin-secrets-kv v0.5.5/go.mod h1:oNyUoMMQq6uNTwyYPnkldiedaknYbPfQIdKoyKQdy2g=
|
||||||
github.com/hashicorp/vault-plugin-secrets-mongodbatlas v0.1.2/go.mod h1:YRW9zn9NZNitRlPYNAWRp/YEdKCF/X8aOg8IYSxFT5Y=
|
github.com/hashicorp/vault-plugin-secrets-mongodbatlas v0.1.2/go.mod h1:YRW9zn9NZNitRlPYNAWRp/YEdKCF/X8aOg8IYSxFT5Y=
|
||||||
github.com/hashicorp/vault-plugin-secrets-openldap v0.1.3-0.20200518214608-746aba5fead6/go.mod h1:9Cy4Jp779BjuIOhYLjEfH3M3QCUxZgPnvJ3tAOOmof4=
|
github.com/hashicorp/vault-plugin-secrets-openldap v0.1.3-0.20200518214608-746aba5fead6/go.mod h1:9Cy4Jp779BjuIOhYLjEfH3M3QCUxZgPnvJ3tAOOmof4=
|
||||||
github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a h1:1DIoo5Mqq4RKFpL2iOmrX7DJIdMLiAt1Tv5f8nMJqRI=
|
github.com/hashicorp/vault/api v1.0.1/go.mod h1:AV/+M5VPDpB90arloVX0rVDUIHkONiwz5Uza9HRtpUE=
|
||||||
|
github.com/hashicorp/vault/api v1.0.5-0.20190730042357-746c0b111519/go.mod h1:i9PKqwFko/s/aihU1uuHGh/FaQS+Xcgvd9dvnfAvQb0=
|
||||||
|
github.com/hashicorp/vault/api v1.0.5-0.20191122173911-80fcc7907c78/go.mod h1:Uf8LaHyrYsgVgHzO2tMZKhqRGlL3UJ6XaSwW2EA1Iqo=
|
||||||
|
github.com/hashicorp/vault/api v1.0.5-0.20200215224050-f6547fa8e820/go.mod h1:3f12BMfgDGjTsTtIUj+ZKZwSobQpZtYGFIEehOv5z1o=
|
||||||
|
github.com/hashicorp/vault/api v1.0.5-0.20200317185738-82f498082f02/go.mod h1:3f12BMfgDGjTsTtIUj+ZKZwSobQpZtYGFIEehOv5z1o=
|
||||||
|
github.com/hashicorp/vault/api v1.0.5-0.20200519221902-385fac77e20f/go.mod h1:euTFbi2YJgwcju3imEt919lhJKF68nN1cQPq3aA+kBE=
|
||||||
github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a/go.mod h1:R3Umvhlxi2TN7Ex2hzOowyeNb+SfbVWI973N+ctaFMk=
|
github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a/go.mod h1:R3Umvhlxi2TN7Ex2hzOowyeNb+SfbVWI973N+ctaFMk=
|
||||||
|
github.com/hashicorp/vault/api v1.1.1 h1:907ld+Z9cALyvbZK2qUX9cLwvSaEQsMVQB3x2KE8+AI=
|
||||||
|
github.com/hashicorp/vault/api v1.1.1/go.mod h1:29UXcn/1cLOPHQNMWA7bCz2By4PSd0VKPAydKXS5yN0=
|
||||||
github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b h1:vQeIf4LdAqtYoD3N6KSiYilntYZq0F0vxcBTlx/69wg=
|
github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b h1:vQeIf4LdAqtYoD3N6KSiYilntYZq0F0vxcBTlx/69wg=
|
||||||
github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b/go.mod h1:cAGI4nVnEfAyMeqt9oB+Mase8DNn3qA/LDNHURiwssY=
|
github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b/go.mod h1:cAGI4nVnEfAyMeqt9oB+Mase8DNn3qA/LDNHURiwssY=
|
||||||
github.com/hashicorp/yamux v0.0.0-20180604194846-3520598351bb/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM=
|
github.com/hashicorp/yamux v0.0.0-20180604194846-3520598351bb/go.mod h1:+NfK9FKeTrX5uv1uIXGdwYDTeHna2qgaIlx54MXqjAM=
|
||||||
@ -662,8 +674,8 @@ github.com/libopenstorage/autopilot-api v0.6.1-0.20210128210103-5fbb67948648/go.
|
|||||||
github.com/libopenstorage/openstorage v1.0.0/go.mod h1:Sp1sIObHjat1BeXhfMqLZ14wnOzEhNx2YQedreMcUyc=
|
github.com/libopenstorage/openstorage v1.0.0/go.mod h1:Sp1sIObHjat1BeXhfMqLZ14wnOzEhNx2YQedreMcUyc=
|
||||||
github.com/libopenstorage/openstorage v8.0.0+incompatible/go.mod h1:Sp1sIObHjat1BeXhfMqLZ14wnOzEhNx2YQedreMcUyc=
|
github.com/libopenstorage/openstorage v8.0.0+incompatible/go.mod h1:Sp1sIObHjat1BeXhfMqLZ14wnOzEhNx2YQedreMcUyc=
|
||||||
github.com/libopenstorage/operator v0.0.0-20200725001727-48d03e197117/go.mod h1:Qh+VXOB6hj60VmlgsmY+R1w+dFuHK246UueM4SAqZG0=
|
github.com/libopenstorage/operator v0.0.0-20200725001727-48d03e197117/go.mod h1:Qh+VXOB6hj60VmlgsmY+R1w+dFuHK246UueM4SAqZG0=
|
||||||
github.com/libopenstorage/secrets v0.0.0-20210709082113-dde442ea20ec h1:ezv9ybzCRb86E8aMgG7/GcNSRU/72D0BVEhkNjnCEz8=
|
github.com/libopenstorage/secrets v0.0.0-20210908194121-a1d19aa9713a h1:A4GqCY7+LrLmO0F1EK27iLqa5ZuvWeaVwGvhmzFb12s=
|
||||||
github.com/libopenstorage/secrets v0.0.0-20210709082113-dde442ea20ec/go.mod h1:gE8rSd6lwLNXNbiW3DrRZjFMs+y4fDHy/6uiOO9cdzY=
|
github.com/libopenstorage/secrets v0.0.0-20210908194121-a1d19aa9713a/go.mod h1:gE8rSd6lwLNXNbiW3DrRZjFMs+y4fDHy/6uiOO9cdzY=
|
||||||
github.com/libopenstorage/stork v1.3.0-beta1.0.20200630005842-9255e7a98775/go.mod h1:qBSzYTJVHlOMg5RINNiHD1kBzlasnrc2uKLPZLgu1Qs=
|
github.com/libopenstorage/stork v1.3.0-beta1.0.20200630005842-9255e7a98775/go.mod h1:qBSzYTJVHlOMg5RINNiHD1kBzlasnrc2uKLPZLgu1Qs=
|
||||||
github.com/liggitt/tabwriter v0.0.0-20181228230101-89fcab3d43de/go.mod h1:zAbeS9B/r2mtpb6U+EI2rYA5OAXxsYw6wTamcNW+zcE=
|
github.com/liggitt/tabwriter v0.0.0-20181228230101-89fcab3d43de/go.mod h1:zAbeS9B/r2mtpb6U+EI2rYA5OAXxsYw6wTamcNW+zcE=
|
||||||
github.com/lithammer/dedent v1.1.0/go.mod h1:jrXYCQtgg0nJiN+StA2KgR7w6CiQNv9Fd/Z9BP0jIOc=
|
github.com/lithammer/dedent v1.1.0/go.mod h1:jrXYCQtgg0nJiN+StA2KgR7w6CiQNv9Fd/Z9BP0jIOc=
|
||||||
|
22
vendor/github.com/cenkalti/backoff/v3/.gitignore
generated
vendored
Normal file
22
vendor/github.com/cenkalti/backoff/v3/.gitignore
generated
vendored
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
# Compiled Object files, Static and Dynamic libs (Shared Objects)
|
||||||
|
*.o
|
||||||
|
*.a
|
||||||
|
*.so
|
||||||
|
|
||||||
|
# Folders
|
||||||
|
_obj
|
||||||
|
_test
|
||||||
|
|
||||||
|
# Architecture specific extensions/prefixes
|
||||||
|
*.[568vq]
|
||||||
|
[568vq].out
|
||||||
|
|
||||||
|
*.cgo1.go
|
||||||
|
*.cgo2.c
|
||||||
|
_cgo_defun.c
|
||||||
|
_cgo_gotypes.go
|
||||||
|
_cgo_export.*
|
||||||
|
|
||||||
|
_testmain.go
|
||||||
|
|
||||||
|
*.exe
|
10
vendor/github.com/cenkalti/backoff/v3/.travis.yml
generated
vendored
Normal file
10
vendor/github.com/cenkalti/backoff/v3/.travis.yml
generated
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
language: go
|
||||||
|
go:
|
||||||
|
- 1.7
|
||||||
|
- 1.x
|
||||||
|
- tip
|
||||||
|
before_install:
|
||||||
|
- go get github.com/mattn/goveralls
|
||||||
|
- go get golang.org/x/tools/cmd/cover
|
||||||
|
script:
|
||||||
|
- $HOME/gopath/bin/goveralls -service=travis-ci
|
20
vendor/github.com/cenkalti/backoff/v3/LICENSE
generated
vendored
Normal file
20
vendor/github.com/cenkalti/backoff/v3/LICENSE
generated
vendored
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2014 Cenk Altı
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
||||||
|
the Software, and to permit persons to whom the Software is furnished to do so,
|
||||||
|
subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
||||||
|
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
||||||
|
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
||||||
|
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
||||||
|
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
30
vendor/github.com/cenkalti/backoff/v3/README.md
generated
vendored
Normal file
30
vendor/github.com/cenkalti/backoff/v3/README.md
generated
vendored
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# Exponential Backoff [![GoDoc][godoc image]][godoc] [![Build Status][travis image]][travis] [![Coverage Status][coveralls image]][coveralls]
|
||||||
|
|
||||||
|
This is a Go port of the exponential backoff algorithm from [Google's HTTP Client Library for Java][google-http-java-client].
|
||||||
|
|
||||||
|
[Exponential backoff][exponential backoff wiki]
|
||||||
|
is an algorithm that uses feedback to multiplicatively decrease the rate of some process,
|
||||||
|
in order to gradually find an acceptable rate.
|
||||||
|
The retries exponentially increase and stop increasing when a certain threshold is met.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
See https://godoc.org/github.com/cenkalti/backoff#pkg-examples
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
|
||||||
|
* I would like to keep this library as small as possible.
|
||||||
|
* Please don't send a PR without opening an issue and discussing it first.
|
||||||
|
* If proposed change is not a common use case, I will probably not accept it.
|
||||||
|
|
||||||
|
[godoc]: https://godoc.org/github.com/cenkalti/backoff
|
||||||
|
[godoc image]: https://godoc.org/github.com/cenkalti/backoff?status.png
|
||||||
|
[travis]: https://travis-ci.org/cenkalti/backoff
|
||||||
|
[travis image]: https://travis-ci.org/cenkalti/backoff.png?branch=master
|
||||||
|
[coveralls]: https://coveralls.io/github/cenkalti/backoff?branch=master
|
||||||
|
[coveralls image]: https://coveralls.io/repos/github/cenkalti/backoff/badge.svg?branch=master
|
||||||
|
|
||||||
|
[google-http-java-client]: https://github.com/google/google-http-java-client/blob/da1aa993e90285ec18579f1553339b00e19b3ab5/google-http-client/src/main/java/com/google/api/client/util/ExponentialBackOff.java
|
||||||
|
[exponential backoff wiki]: http://en.wikipedia.org/wiki/Exponential_backoff
|
||||||
|
|
||||||
|
[advanced example]: https://godoc.org/github.com/cenkalti/backoff#example_
|
66
vendor/github.com/cenkalti/backoff/v3/backoff.go
generated
vendored
Normal file
66
vendor/github.com/cenkalti/backoff/v3/backoff.go
generated
vendored
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
// Package backoff implements backoff algorithms for retrying operations.
|
||||||
|
//
|
||||||
|
// Use Retry function for retrying operations that may fail.
|
||||||
|
// If Retry does not meet your needs,
|
||||||
|
// copy/paste the function into your project and modify as you wish.
|
||||||
|
//
|
||||||
|
// There is also Ticker type similar to time.Ticker.
|
||||||
|
// You can use it if you need to work with channels.
|
||||||
|
//
|
||||||
|
// See Examples section below for usage examples.
|
||||||
|
package backoff
|
||||||
|
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
// BackOff is a backoff policy for retrying an operation.
|
||||||
|
type BackOff interface {
|
||||||
|
// NextBackOff returns the duration to wait before retrying the operation,
|
||||||
|
// or backoff. Stop to indicate that no more retries should be made.
|
||||||
|
//
|
||||||
|
// Example usage:
|
||||||
|
//
|
||||||
|
// duration := backoff.NextBackOff();
|
||||||
|
// if (duration == backoff.Stop) {
|
||||||
|
// // Do not retry operation.
|
||||||
|
// } else {
|
||||||
|
// // Sleep for duration and retry operation.
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
NextBackOff() time.Duration
|
||||||
|
|
||||||
|
// Reset to initial state.
|
||||||
|
Reset()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Stop indicates that no more retries should be made for use in NextBackOff().
|
||||||
|
const Stop time.Duration = -1
|
||||||
|
|
||||||
|
// ZeroBackOff is a fixed backoff policy whose backoff time is always zero,
|
||||||
|
// meaning that the operation is retried immediately without waiting, indefinitely.
|
||||||
|
type ZeroBackOff struct{}
|
||||||
|
|
||||||
|
func (b *ZeroBackOff) Reset() {}
|
||||||
|
|
||||||
|
func (b *ZeroBackOff) NextBackOff() time.Duration { return 0 }
|
||||||
|
|
||||||
|
// StopBackOff is a fixed backoff policy that always returns backoff.Stop for
|
||||||
|
// NextBackOff(), meaning that the operation should never be retried.
|
||||||
|
type StopBackOff struct{}
|
||||||
|
|
||||||
|
func (b *StopBackOff) Reset() {}
|
||||||
|
|
||||||
|
func (b *StopBackOff) NextBackOff() time.Duration { return Stop }
|
||||||
|
|
||||||
|
// ConstantBackOff is a backoff policy that always returns the same backoff delay.
|
||||||
|
// This is in contrast to an exponential backoff policy,
|
||||||
|
// which returns a delay that grows longer as you call NextBackOff() over and over again.
|
||||||
|
type ConstantBackOff struct {
|
||||||
|
Interval time.Duration
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *ConstantBackOff) Reset() {}
|
||||||
|
func (b *ConstantBackOff) NextBackOff() time.Duration { return b.Interval }
|
||||||
|
|
||||||
|
func NewConstantBackOff(d time.Duration) *ConstantBackOff {
|
||||||
|
return &ConstantBackOff{Interval: d}
|
||||||
|
}
|
63
vendor/github.com/cenkalti/backoff/v3/context.go
generated
vendored
Normal file
63
vendor/github.com/cenkalti/backoff/v3/context.go
generated
vendored
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
package backoff
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// BackOffContext is a backoff policy that stops retrying after the context
|
||||||
|
// is canceled.
|
||||||
|
type BackOffContext interface {
|
||||||
|
BackOff
|
||||||
|
Context() context.Context
|
||||||
|
}
|
||||||
|
|
||||||
|
type backOffContext struct {
|
||||||
|
BackOff
|
||||||
|
ctx context.Context
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithContext returns a BackOffContext with context ctx
|
||||||
|
//
|
||||||
|
// ctx must not be nil
|
||||||
|
func WithContext(b BackOff, ctx context.Context) BackOffContext {
|
||||||
|
if ctx == nil {
|
||||||
|
panic("nil context")
|
||||||
|
}
|
||||||
|
|
||||||
|
if b, ok := b.(*backOffContext); ok {
|
||||||
|
return &backOffContext{
|
||||||
|
BackOff: b.BackOff,
|
||||||
|
ctx: ctx,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return &backOffContext{
|
||||||
|
BackOff: b,
|
||||||
|
ctx: ctx,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func ensureContext(b BackOff) BackOffContext {
|
||||||
|
if cb, ok := b.(BackOffContext); ok {
|
||||||
|
return cb
|
||||||
|
}
|
||||||
|
return WithContext(b, context.Background())
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *backOffContext) Context() context.Context {
|
||||||
|
return b.ctx
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *backOffContext) NextBackOff() time.Duration {
|
||||||
|
select {
|
||||||
|
case <-b.ctx.Done():
|
||||||
|
return Stop
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
next := b.BackOff.NextBackOff()
|
||||||
|
if deadline, ok := b.ctx.Deadline(); ok && deadline.Sub(time.Now()) < next {
|
||||||
|
return Stop
|
||||||
|
}
|
||||||
|
return next
|
||||||
|
}
|
153
vendor/github.com/cenkalti/backoff/v3/exponential.go
generated
vendored
Normal file
153
vendor/github.com/cenkalti/backoff/v3/exponential.go
generated
vendored
Normal file
@ -0,0 +1,153 @@
|
|||||||
|
package backoff
|
||||||
|
|
||||||
|
import (
|
||||||
|
"math/rand"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
/*
|
||||||
|
ExponentialBackOff is a backoff implementation that increases the backoff
|
||||||
|
period for each retry attempt using a randomization function that grows exponentially.
|
||||||
|
|
||||||
|
NextBackOff() is calculated using the following formula:
|
||||||
|
|
||||||
|
randomized interval =
|
||||||
|
RetryInterval * (random value in range [1 - RandomizationFactor, 1 + RandomizationFactor])
|
||||||
|
|
||||||
|
In other words NextBackOff() will range between the randomization factor
|
||||||
|
percentage below and above the retry interval.
|
||||||
|
|
||||||
|
For example, given the following parameters:
|
||||||
|
|
||||||
|
RetryInterval = 2
|
||||||
|
RandomizationFactor = 0.5
|
||||||
|
Multiplier = 2
|
||||||
|
|
||||||
|
the actual backoff period used in the next retry attempt will range between 1 and 3 seconds,
|
||||||
|
multiplied by the exponential, that is, between 2 and 6 seconds.
|
||||||
|
|
||||||
|
Note: MaxInterval caps the RetryInterval and not the randomized interval.
|
||||||
|
|
||||||
|
If the time elapsed since an ExponentialBackOff instance is created goes past the
|
||||||
|
MaxElapsedTime, then the method NextBackOff() starts returning backoff.Stop.
|
||||||
|
|
||||||
|
The elapsed time can be reset by calling Reset().
|
||||||
|
|
||||||
|
Example: Given the following default arguments, for 10 tries the sequence will be,
|
||||||
|
and assuming we go over the MaxElapsedTime on the 10th try:
|
||||||
|
|
||||||
|
Request # RetryInterval (seconds) Randomized Interval (seconds)
|
||||||
|
|
||||||
|
1 0.5 [0.25, 0.75]
|
||||||
|
2 0.75 [0.375, 1.125]
|
||||||
|
3 1.125 [0.562, 1.687]
|
||||||
|
4 1.687 [0.8435, 2.53]
|
||||||
|
5 2.53 [1.265, 3.795]
|
||||||
|
6 3.795 [1.897, 5.692]
|
||||||
|
7 5.692 [2.846, 8.538]
|
||||||
|
8 8.538 [4.269, 12.807]
|
||||||
|
9 12.807 [6.403, 19.210]
|
||||||
|
10 19.210 backoff.Stop
|
||||||
|
|
||||||
|
Note: Implementation is not thread-safe.
|
||||||
|
*/
|
||||||
|
type ExponentialBackOff struct {
|
||||||
|
InitialInterval time.Duration
|
||||||
|
RandomizationFactor float64
|
||||||
|
Multiplier float64
|
||||||
|
MaxInterval time.Duration
|
||||||
|
// After MaxElapsedTime the ExponentialBackOff stops.
|
||||||
|
// It never stops if MaxElapsedTime == 0.
|
||||||
|
MaxElapsedTime time.Duration
|
||||||
|
Clock Clock
|
||||||
|
|
||||||
|
currentInterval time.Duration
|
||||||
|
startTime time.Time
|
||||||
|
}
|
||||||
|
|
||||||
|
// Clock is an interface that returns current time for BackOff.
|
||||||
|
type Clock interface {
|
||||||
|
Now() time.Time
|
||||||
|
}
|
||||||
|
|
||||||
|
// Default values for ExponentialBackOff.
|
||||||
|
const (
|
||||||
|
DefaultInitialInterval = 500 * time.Millisecond
|
||||||
|
DefaultRandomizationFactor = 0.5
|
||||||
|
DefaultMultiplier = 1.5
|
||||||
|
DefaultMaxInterval = 60 * time.Second
|
||||||
|
DefaultMaxElapsedTime = 15 * time.Minute
|
||||||
|
)
|
||||||
|
|
||||||
|
// NewExponentialBackOff creates an instance of ExponentialBackOff using default values.
|
||||||
|
func NewExponentialBackOff() *ExponentialBackOff {
|
||||||
|
b := &ExponentialBackOff{
|
||||||
|
InitialInterval: DefaultInitialInterval,
|
||||||
|
RandomizationFactor: DefaultRandomizationFactor,
|
||||||
|
Multiplier: DefaultMultiplier,
|
||||||
|
MaxInterval: DefaultMaxInterval,
|
||||||
|
MaxElapsedTime: DefaultMaxElapsedTime,
|
||||||
|
Clock: SystemClock,
|
||||||
|
}
|
||||||
|
b.Reset()
|
||||||
|
return b
|
||||||
|
}
|
||||||
|
|
||||||
|
type systemClock struct{}
|
||||||
|
|
||||||
|
func (t systemClock) Now() time.Time {
|
||||||
|
return time.Now()
|
||||||
|
}
|
||||||
|
|
||||||
|
// SystemClock implements Clock interface that uses time.Now().
|
||||||
|
var SystemClock = systemClock{}
|
||||||
|
|
||||||
|
// Reset the interval back to the initial retry interval and restarts the timer.
|
||||||
|
func (b *ExponentialBackOff) Reset() {
|
||||||
|
b.currentInterval = b.InitialInterval
|
||||||
|
b.startTime = b.Clock.Now()
|
||||||
|
}
|
||||||
|
|
||||||
|
// NextBackOff calculates the next backoff interval using the formula:
|
||||||
|
// Randomized interval = RetryInterval +/- (RandomizationFactor * RetryInterval)
|
||||||
|
func (b *ExponentialBackOff) NextBackOff() time.Duration {
|
||||||
|
// Make sure we have not gone over the maximum elapsed time.
|
||||||
|
if b.MaxElapsedTime != 0 && b.GetElapsedTime() > b.MaxElapsedTime {
|
||||||
|
return Stop
|
||||||
|
}
|
||||||
|
defer b.incrementCurrentInterval()
|
||||||
|
return getRandomValueFromInterval(b.RandomizationFactor, rand.Float64(), b.currentInterval)
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetElapsedTime returns the elapsed time since an ExponentialBackOff instance
|
||||||
|
// is created and is reset when Reset() is called.
|
||||||
|
//
|
||||||
|
// The elapsed time is computed using time.Now().UnixNano(). It is
|
||||||
|
// safe to call even while the backoff policy is used by a running
|
||||||
|
// ticker.
|
||||||
|
func (b *ExponentialBackOff) GetElapsedTime() time.Duration {
|
||||||
|
return b.Clock.Now().Sub(b.startTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Increments the current interval by multiplying it with the multiplier.
|
||||||
|
func (b *ExponentialBackOff) incrementCurrentInterval() {
|
||||||
|
// Check for overflow, if overflow is detected set the current interval to the max interval.
|
||||||
|
if float64(b.currentInterval) >= float64(b.MaxInterval)/b.Multiplier {
|
||||||
|
b.currentInterval = b.MaxInterval
|
||||||
|
} else {
|
||||||
|
b.currentInterval = time.Duration(float64(b.currentInterval) * b.Multiplier)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns a random value from the following interval:
|
||||||
|
// [randomizationFactor * currentInterval, randomizationFactor * currentInterval].
|
||||||
|
func getRandomValueFromInterval(randomizationFactor, random float64, currentInterval time.Duration) time.Duration {
|
||||||
|
var delta = randomizationFactor * float64(currentInterval)
|
||||||
|
var minInterval = float64(currentInterval) - delta
|
||||||
|
var maxInterval = float64(currentInterval) + delta
|
||||||
|
|
||||||
|
// Get a random value from the range [minInterval, maxInterval].
|
||||||
|
// The formula used below has a +1 because if the minInterval is 1 and the maxInterval is 3 then
|
||||||
|
// we want a 33% chance for selecting either 1, 2 or 3.
|
||||||
|
return time.Duration(minInterval + (random * (maxInterval - minInterval + 1)))
|
||||||
|
}
|
3
vendor/github.com/cenkalti/backoff/v3/go.mod
generated
vendored
Normal file
3
vendor/github.com/cenkalti/backoff/v3/go.mod
generated
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
module github.com/cenkalti/backoff/v3
|
||||||
|
|
||||||
|
go 1.12
|
82
vendor/github.com/cenkalti/backoff/v3/retry.go
generated
vendored
Normal file
82
vendor/github.com/cenkalti/backoff/v3/retry.go
generated
vendored
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
package backoff
|
||||||
|
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
// An Operation is executing by Retry() or RetryNotify().
|
||||||
|
// The operation will be retried using a backoff policy if it returns an error.
|
||||||
|
type Operation func() error
|
||||||
|
|
||||||
|
// Notify is a notify-on-error function. It receives an operation error and
|
||||||
|
// backoff delay if the operation failed (with an error).
|
||||||
|
//
|
||||||
|
// NOTE that if the backoff policy stated to stop retrying,
|
||||||
|
// the notify function isn't called.
|
||||||
|
type Notify func(error, time.Duration)
|
||||||
|
|
||||||
|
// Retry the operation o until it does not return error or BackOff stops.
|
||||||
|
// o is guaranteed to be run at least once.
|
||||||
|
//
|
||||||
|
// If o returns a *PermanentError, the operation is not retried, and the
|
||||||
|
// wrapped error is returned.
|
||||||
|
//
|
||||||
|
// Retry sleeps the goroutine for the duration returned by BackOff after a
|
||||||
|
// failed operation returns.
|
||||||
|
func Retry(o Operation, b BackOff) error { return RetryNotify(o, b, nil) }
|
||||||
|
|
||||||
|
// RetryNotify calls notify function with the error and wait duration
|
||||||
|
// for each failed attempt before sleep.
|
||||||
|
func RetryNotify(operation Operation, b BackOff, notify Notify) error {
|
||||||
|
var err error
|
||||||
|
var next time.Duration
|
||||||
|
var t *time.Timer
|
||||||
|
|
||||||
|
cb := ensureContext(b)
|
||||||
|
|
||||||
|
b.Reset()
|
||||||
|
for {
|
||||||
|
if err = operation(); err == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
if permanent, ok := err.(*PermanentError); ok {
|
||||||
|
return permanent.Err
|
||||||
|
}
|
||||||
|
|
||||||
|
if next = cb.NextBackOff(); next == Stop {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if notify != nil {
|
||||||
|
notify(err, next)
|
||||||
|
}
|
||||||
|
|
||||||
|
if t == nil {
|
||||||
|
t = time.NewTimer(next)
|
||||||
|
defer t.Stop()
|
||||||
|
} else {
|
||||||
|
t.Reset(next)
|
||||||
|
}
|
||||||
|
|
||||||
|
select {
|
||||||
|
case <-cb.Context().Done():
|
||||||
|
return err
|
||||||
|
case <-t.C:
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// PermanentError signals that the operation should not be retried.
|
||||||
|
type PermanentError struct {
|
||||||
|
Err error
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *PermanentError) Error() string {
|
||||||
|
return e.Err.Error()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Permanent wraps the given err in a *PermanentError.
|
||||||
|
func Permanent(err error) *PermanentError {
|
||||||
|
return &PermanentError{
|
||||||
|
Err: err,
|
||||||
|
}
|
||||||
|
}
|
82
vendor/github.com/cenkalti/backoff/v3/ticker.go
generated
vendored
Normal file
82
vendor/github.com/cenkalti/backoff/v3/ticker.go
generated
vendored
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
package backoff
|
||||||
|
|
||||||
|
import (
|
||||||
|
"sync"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Ticker holds a channel that delivers `ticks' of a clock at times reported by a BackOff.
|
||||||
|
//
|
||||||
|
// Ticks will continue to arrive when the previous operation is still running,
|
||||||
|
// so operations that take a while to fail could run in quick succession.
|
||||||
|
type Ticker struct {
|
||||||
|
C <-chan time.Time
|
||||||
|
c chan time.Time
|
||||||
|
b BackOffContext
|
||||||
|
stop chan struct{}
|
||||||
|
stopOnce sync.Once
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewTicker returns a new Ticker containing a channel that will send
|
||||||
|
// the time at times specified by the BackOff argument. Ticker is
|
||||||
|
// guaranteed to tick at least once. The channel is closed when Stop
|
||||||
|
// method is called or BackOff stops. It is not safe to manipulate the
|
||||||
|
// provided backoff policy (notably calling NextBackOff or Reset)
|
||||||
|
// while the ticker is running.
|
||||||
|
func NewTicker(b BackOff) *Ticker {
|
||||||
|
c := make(chan time.Time)
|
||||||
|
t := &Ticker{
|
||||||
|
C: c,
|
||||||
|
c: c,
|
||||||
|
b: ensureContext(b),
|
||||||
|
stop: make(chan struct{}),
|
||||||
|
}
|
||||||
|
t.b.Reset()
|
||||||
|
go t.run()
|
||||||
|
return t
|
||||||
|
}
|
||||||
|
|
||||||
|
// Stop turns off a ticker. After Stop, no more ticks will be sent.
|
||||||
|
func (t *Ticker) Stop() {
|
||||||
|
t.stopOnce.Do(func() { close(t.stop) })
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *Ticker) run() {
|
||||||
|
c := t.c
|
||||||
|
defer close(c)
|
||||||
|
|
||||||
|
// Ticker is guaranteed to tick at least once.
|
||||||
|
afterC := t.send(time.Now())
|
||||||
|
|
||||||
|
for {
|
||||||
|
if afterC == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
select {
|
||||||
|
case tick := <-afterC:
|
||||||
|
afterC = t.send(tick)
|
||||||
|
case <-t.stop:
|
||||||
|
t.c = nil // Prevent future ticks from being sent to the channel.
|
||||||
|
return
|
||||||
|
case <-t.b.Context().Done():
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *Ticker) send(tick time.Time) <-chan time.Time {
|
||||||
|
select {
|
||||||
|
case t.c <- tick:
|
||||||
|
case <-t.stop:
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
next := t.b.NextBackOff()
|
||||||
|
if next == Stop {
|
||||||
|
t.Stop()
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return time.After(next)
|
||||||
|
}
|
35
vendor/github.com/cenkalti/backoff/v3/tries.go
generated
vendored
Normal file
35
vendor/github.com/cenkalti/backoff/v3/tries.go
generated
vendored
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
package backoff
|
||||||
|
|
||||||
|
import "time"
|
||||||
|
|
||||||
|
/*
|
||||||
|
WithMaxRetries creates a wrapper around another BackOff, which will
|
||||||
|
return Stop if NextBackOff() has been called too many times since
|
||||||
|
the last time Reset() was called
|
||||||
|
|
||||||
|
Note: Implementation is not thread-safe.
|
||||||
|
*/
|
||||||
|
func WithMaxRetries(b BackOff, max uint64) BackOff {
|
||||||
|
return &backOffTries{delegate: b, maxTries: max}
|
||||||
|
}
|
||||||
|
|
||||||
|
type backOffTries struct {
|
||||||
|
delegate BackOff
|
||||||
|
maxTries uint64
|
||||||
|
numTries uint64
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *backOffTries) NextBackOff() time.Duration {
|
||||||
|
if b.maxTries > 0 {
|
||||||
|
if b.maxTries <= b.numTries {
|
||||||
|
return Stop
|
||||||
|
}
|
||||||
|
b.numTries++
|
||||||
|
}
|
||||||
|
return b.delegate.NextBackOff()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *backOffTries) Reset() {
|
||||||
|
b.numTries = 0
|
||||||
|
b.delegate.Reset()
|
||||||
|
}
|
105
vendor/github.com/hashicorp/go-hclog/interceptlogger.go
generated
vendored
105
vendor/github.com/hashicorp/go-hclog/interceptlogger.go
generated
vendored
@ -18,8 +18,13 @@ type interceptLogger struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NewInterceptLogger(opts *LoggerOptions) InterceptLogger {
|
func NewInterceptLogger(opts *LoggerOptions) InterceptLogger {
|
||||||
|
l := newLogger(opts)
|
||||||
|
if l.callerOffset > 0 {
|
||||||
|
// extra frames for interceptLogger.{Warn,Info,Log,etc...}, and interceptLogger.log
|
||||||
|
l.callerOffset += 2
|
||||||
|
}
|
||||||
intercept := &interceptLogger{
|
intercept := &interceptLogger{
|
||||||
Logger: New(opts),
|
Logger: l,
|
||||||
mu: new(sync.Mutex),
|
mu: new(sync.Mutex),
|
||||||
sinkCount: new(int32),
|
sinkCount: new(int32),
|
||||||
Sinks: make(map[SinkAdapter]struct{}),
|
Sinks: make(map[SinkAdapter]struct{}),
|
||||||
@ -31,6 +36,14 @@ func NewInterceptLogger(opts *LoggerOptions) InterceptLogger {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (i *interceptLogger) Log(level Level, msg string, args ...interface{}) {
|
func (i *interceptLogger) Log(level Level, msg string, args ...interface{}) {
|
||||||
|
i.log(level, msg, args...)
|
||||||
|
}
|
||||||
|
|
||||||
|
// log is used to make the caller stack frame lookup consistent. If Warn,Info,etc
|
||||||
|
// all called Log then direct calls to Log would have a different stack frame
|
||||||
|
// depth. By having all the methods call the same helper we ensure the stack
|
||||||
|
// frame depth is the same.
|
||||||
|
func (i *interceptLogger) log(level Level, msg string, args ...interface{}) {
|
||||||
i.Logger.Log(level, msg, args...)
|
i.Logger.Log(level, msg, args...)
|
||||||
if atomic.LoadInt32(i.sinkCount) == 0 {
|
if atomic.LoadInt32(i.sinkCount) == 0 {
|
||||||
return
|
return
|
||||||
@ -45,72 +58,27 @@ func (i *interceptLogger) Log(level Level, msg string, args ...interface{}) {
|
|||||||
|
|
||||||
// Emit the message and args at TRACE level to log and sinks
|
// Emit the message and args at TRACE level to log and sinks
|
||||||
func (i *interceptLogger) Trace(msg string, args ...interface{}) {
|
func (i *interceptLogger) Trace(msg string, args ...interface{}) {
|
||||||
i.Logger.Trace(msg, args...)
|
i.log(Trace, msg, args...)
|
||||||
if atomic.LoadInt32(i.sinkCount) == 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
i.mu.Lock()
|
|
||||||
defer i.mu.Unlock()
|
|
||||||
for s := range i.Sinks {
|
|
||||||
s.Accept(i.Name(), Trace, msg, i.retrieveImplied(args...)...)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit the message and args at DEBUG level to log and sinks
|
// Emit the message and args at DEBUG level to log and sinks
|
||||||
func (i *interceptLogger) Debug(msg string, args ...interface{}) {
|
func (i *interceptLogger) Debug(msg string, args ...interface{}) {
|
||||||
i.Logger.Debug(msg, args...)
|
i.log(Debug, msg, args...)
|
||||||
if atomic.LoadInt32(i.sinkCount) == 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
i.mu.Lock()
|
|
||||||
defer i.mu.Unlock()
|
|
||||||
for s := range i.Sinks {
|
|
||||||
s.Accept(i.Name(), Debug, msg, i.retrieveImplied(args...)...)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit the message and args at INFO level to log and sinks
|
// Emit the message and args at INFO level to log and sinks
|
||||||
func (i *interceptLogger) Info(msg string, args ...interface{}) {
|
func (i *interceptLogger) Info(msg string, args ...interface{}) {
|
||||||
i.Logger.Info(msg, args...)
|
i.log(Info, msg, args...)
|
||||||
if atomic.LoadInt32(i.sinkCount) == 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
i.mu.Lock()
|
|
||||||
defer i.mu.Unlock()
|
|
||||||
for s := range i.Sinks {
|
|
||||||
s.Accept(i.Name(), Info, msg, i.retrieveImplied(args...)...)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit the message and args at WARN level to log and sinks
|
// Emit the message and args at WARN level to log and sinks
|
||||||
func (i *interceptLogger) Warn(msg string, args ...interface{}) {
|
func (i *interceptLogger) Warn(msg string, args ...interface{}) {
|
||||||
i.Logger.Warn(msg, args...)
|
i.log(Warn, msg, args...)
|
||||||
if atomic.LoadInt32(i.sinkCount) == 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
i.mu.Lock()
|
|
||||||
defer i.mu.Unlock()
|
|
||||||
for s := range i.Sinks {
|
|
||||||
s.Accept(i.Name(), Warn, msg, i.retrieveImplied(args...)...)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Emit the message and args at ERROR level to log and sinks
|
// Emit the message and args at ERROR level to log and sinks
|
||||||
func (i *interceptLogger) Error(msg string, args ...interface{}) {
|
func (i *interceptLogger) Error(msg string, args ...interface{}) {
|
||||||
i.Logger.Error(msg, args...)
|
i.log(Error, msg, args...)
|
||||||
if atomic.LoadInt32(i.sinkCount) == 0 {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
i.mu.Lock()
|
|
||||||
defer i.mu.Unlock()
|
|
||||||
for s := range i.Sinks {
|
|
||||||
s.Accept(i.Name(), Error, msg, i.retrieveImplied(args...)...)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (i *interceptLogger) retrieveImplied(args ...interface{}) []interface{} {
|
func (i *interceptLogger) retrieveImplied(args ...interface{}) []interface{} {
|
||||||
@ -123,17 +91,11 @@ func (i *interceptLogger) retrieveImplied(args ...interface{}) []interface{} {
|
|||||||
return cp
|
return cp
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new sub-Logger that a name decending from the current name.
|
// Create a new sub-Logger that a name descending from the current name.
|
||||||
// This is used to create a subsystem specific Logger.
|
// This is used to create a subsystem specific Logger.
|
||||||
// Registered sinks will subscribe to these messages as well.
|
// Registered sinks will subscribe to these messages as well.
|
||||||
func (i *interceptLogger) Named(name string) Logger {
|
func (i *interceptLogger) Named(name string) Logger {
|
||||||
var sub interceptLogger
|
return i.NamedIntercept(name)
|
||||||
|
|
||||||
sub = *i
|
|
||||||
|
|
||||||
sub.Logger = i.Logger.Named(name)
|
|
||||||
|
|
||||||
return &sub
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new sub-Logger with an explicit name. This ignores the current
|
// Create a new sub-Logger with an explicit name. This ignores the current
|
||||||
@ -141,13 +103,7 @@ func (i *interceptLogger) Named(name string) Logger {
|
|||||||
// within the normal hierarchy. Registered sinks will subscribe
|
// within the normal hierarchy. Registered sinks will subscribe
|
||||||
// to these messages as well.
|
// to these messages as well.
|
||||||
func (i *interceptLogger) ResetNamed(name string) Logger {
|
func (i *interceptLogger) ResetNamed(name string) Logger {
|
||||||
var sub interceptLogger
|
return i.ResetNamedIntercept(name)
|
||||||
|
|
||||||
sub = *i
|
|
||||||
|
|
||||||
sub.Logger = i.Logger.ResetNamed(name)
|
|
||||||
|
|
||||||
return &sub
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new sub-Logger that a name decending from the current name.
|
// Create a new sub-Logger that a name decending from the current name.
|
||||||
@ -157,9 +113,7 @@ func (i *interceptLogger) NamedIntercept(name string) InterceptLogger {
|
|||||||
var sub interceptLogger
|
var sub interceptLogger
|
||||||
|
|
||||||
sub = *i
|
sub = *i
|
||||||
|
|
||||||
sub.Logger = i.Logger.Named(name)
|
sub.Logger = i.Logger.Named(name)
|
||||||
|
|
||||||
return &sub
|
return &sub
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -171,9 +125,7 @@ func (i *interceptLogger) ResetNamedIntercept(name string) InterceptLogger {
|
|||||||
var sub interceptLogger
|
var sub interceptLogger
|
||||||
|
|
||||||
sub = *i
|
sub = *i
|
||||||
|
|
||||||
sub.Logger = i.Logger.ResetNamed(name)
|
sub.Logger = i.Logger.ResetNamed(name)
|
||||||
|
|
||||||
return &sub
|
return &sub
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -210,18 +162,23 @@ func (i *interceptLogger) DeregisterSink(sink SinkAdapter) {
|
|||||||
atomic.AddInt32(i.sinkCount, -1)
|
atomic.AddInt32(i.sinkCount, -1)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a *log.Logger that will send it's data through this Logger. This
|
|
||||||
// allows packages that expect to be using the standard library to log to
|
|
||||||
// actually use this logger, which will also send to any registered sinks.
|
|
||||||
func (i *interceptLogger) StandardLoggerIntercept(opts *StandardLoggerOptions) *log.Logger {
|
func (i *interceptLogger) StandardLoggerIntercept(opts *StandardLoggerOptions) *log.Logger {
|
||||||
|
return i.StandardLogger(opts)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *interceptLogger) StandardLogger(opts *StandardLoggerOptions) *log.Logger {
|
||||||
if opts == nil {
|
if opts == nil {
|
||||||
opts = &StandardLoggerOptions{}
|
opts = &StandardLoggerOptions{}
|
||||||
}
|
}
|
||||||
|
|
||||||
return log.New(i.StandardWriterIntercept(opts), "", 0)
|
return log.New(i.StandardWriter(opts), "", 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (i *interceptLogger) StandardWriterIntercept(opts *StandardLoggerOptions) io.Writer {
|
func (i *interceptLogger) StandardWriterIntercept(opts *StandardLoggerOptions) io.Writer {
|
||||||
|
return i.StandardWriter(opts)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (i *interceptLogger) StandardWriter(opts *StandardLoggerOptions) io.Writer {
|
||||||
return &stdlogAdapter{
|
return &stdlogAdapter{
|
||||||
log: i,
|
log: i,
|
||||||
inferLevels: opts.InferLevels,
|
inferLevels: opts.InferLevels,
|
||||||
|
162
vendor/github.com/hashicorp/go-hclog/intlogger.go
generated
vendored
162
vendor/github.com/hashicorp/go-hclog/intlogger.go
generated
vendored
@ -10,7 +10,6 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
"reflect"
|
||||||
"regexp"
|
|
||||||
"runtime"
|
"runtime"
|
||||||
"sort"
|
"sort"
|
||||||
"strconv"
|
"strconv"
|
||||||
@ -22,10 +21,14 @@ import (
|
|||||||
"github.com/fatih/color"
|
"github.com/fatih/color"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TimeFormat to use for logging. This is a version of RFC3339 that contains
|
// TimeFormat is the time format to use for plain (non-JSON) output.
|
||||||
// contains millisecond precision
|
// This is a version of RFC3339 that contains millisecond precision.
|
||||||
const TimeFormat = "2006-01-02T15:04:05.000Z0700"
|
const TimeFormat = "2006-01-02T15:04:05.000Z0700"
|
||||||
|
|
||||||
|
// TimeFormatJSON is the time format to use for JSON output.
|
||||||
|
// This is a version of RFC3339 that contains microsecond precision.
|
||||||
|
const TimeFormatJSON = "2006-01-02T15:04:05.000000Z07:00"
|
||||||
|
|
||||||
// errJsonUnsupportedTypeMsg is included in log json entries, if an arg cannot be serialized to json
|
// errJsonUnsupportedTypeMsg is included in log json entries, if an arg cannot be serialized to json
|
||||||
const errJsonUnsupportedTypeMsg = "logging contained values that don't serialize to json"
|
const errJsonUnsupportedTypeMsg = "logging contained values that don't serialize to json"
|
||||||
|
|
||||||
@ -54,9 +57,10 @@ var _ Logger = &intLogger{}
|
|||||||
// defined entirely by this package.
|
// defined entirely by this package.
|
||||||
type intLogger struct {
|
type intLogger struct {
|
||||||
json bool
|
json bool
|
||||||
caller bool
|
callerOffset int
|
||||||
name string
|
name string
|
||||||
timeFormat string
|
timeFormat string
|
||||||
|
disableTime bool
|
||||||
|
|
||||||
// This is an interface so that it's shared by any derived loggers, since
|
// This is an interface so that it's shared by any derived loggers, since
|
||||||
// those derived loggers share the bufio.Writer as well.
|
// those derived loggers share the bufio.Writer as well.
|
||||||
@ -67,6 +71,9 @@ type intLogger struct {
|
|||||||
implied []interface{}
|
implied []interface{}
|
||||||
|
|
||||||
exclude func(level Level, msg string, args ...interface{}) bool
|
exclude func(level Level, msg string, args ...interface{}) bool
|
||||||
|
|
||||||
|
// create subloggers with their own level setting
|
||||||
|
independentLevels bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// New returns a configured logger.
|
// New returns a configured logger.
|
||||||
@ -77,7 +84,12 @@ func New(opts *LoggerOptions) Logger {
|
|||||||
// NewSinkAdapter returns a SinkAdapter with configured settings
|
// NewSinkAdapter returns a SinkAdapter with configured settings
|
||||||
// defined by LoggerOptions
|
// defined by LoggerOptions
|
||||||
func NewSinkAdapter(opts *LoggerOptions) SinkAdapter {
|
func NewSinkAdapter(opts *LoggerOptions) SinkAdapter {
|
||||||
return newLogger(opts)
|
l := newLogger(opts)
|
||||||
|
if l.callerOffset > 0 {
|
||||||
|
// extra frames for interceptLogger.{Warn,Info,Log,etc...}, and SinkAdapter.Accept
|
||||||
|
l.callerOffset += 2
|
||||||
|
}
|
||||||
|
return l
|
||||||
}
|
}
|
||||||
|
|
||||||
func newLogger(opts *LoggerOptions) *intLogger {
|
func newLogger(opts *LoggerOptions) *intLogger {
|
||||||
@ -102,28 +114,37 @@ func newLogger(opts *LoggerOptions) *intLogger {
|
|||||||
|
|
||||||
l := &intLogger{
|
l := &intLogger{
|
||||||
json: opts.JSONFormat,
|
json: opts.JSONFormat,
|
||||||
caller: opts.IncludeLocation,
|
|
||||||
name: opts.Name,
|
name: opts.Name,
|
||||||
timeFormat: TimeFormat,
|
timeFormat: TimeFormat,
|
||||||
|
disableTime: opts.DisableTime,
|
||||||
mutex: mutex,
|
mutex: mutex,
|
||||||
writer: newWriter(output, opts.Color),
|
writer: newWriter(output, opts.Color),
|
||||||
level: new(int32),
|
level: new(int32),
|
||||||
exclude: opts.Exclude,
|
exclude: opts.Exclude,
|
||||||
|
independentLevels: opts.IndependentLevels,
|
||||||
|
}
|
||||||
|
if opts.IncludeLocation {
|
||||||
|
l.callerOffset = offsetIntLogger + opts.AdditionalLocationOffset
|
||||||
|
}
|
||||||
|
|
||||||
|
if l.json {
|
||||||
|
l.timeFormat = TimeFormatJSON
|
||||||
|
}
|
||||||
|
if opts.TimeFormat != "" {
|
||||||
|
l.timeFormat = opts.TimeFormat
|
||||||
}
|
}
|
||||||
|
|
||||||
l.setColorization(opts)
|
l.setColorization(opts)
|
||||||
|
|
||||||
if opts.DisableTime {
|
|
||||||
l.timeFormat = ""
|
|
||||||
} else if opts.TimeFormat != "" {
|
|
||||||
l.timeFormat = opts.TimeFormat
|
|
||||||
}
|
|
||||||
|
|
||||||
atomic.StoreInt32(l.level, int32(level))
|
atomic.StoreInt32(l.level, int32(level))
|
||||||
|
|
||||||
return l
|
return l
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// offsetIntLogger is the stack frame offset in the call stack for the caller to
|
||||||
|
// one of the Warn,Info,Log,etc methods.
|
||||||
|
const offsetIntLogger = 3
|
||||||
|
|
||||||
// Log a message and a set of key/value pairs if the given level is at
|
// Log a message and a set of key/value pairs if the given level is at
|
||||||
// or more severe that the threshold configured in the Logger.
|
// or more severe that the threshold configured in the Logger.
|
||||||
func (l *intLogger) log(name string, level Level, msg string, args ...interface{}) {
|
func (l *intLogger) log(name string, level Level, msg string, args ...interface{}) {
|
||||||
@ -178,11 +199,10 @@ func trimCallerPath(path string) string {
|
|||||||
return path[idx+1:]
|
return path[idx+1:]
|
||||||
}
|
}
|
||||||
|
|
||||||
var logImplFile = regexp.MustCompile(`.+intlogger.go|.+interceptlogger.go$`)
|
|
||||||
|
|
||||||
// Non-JSON logging format function
|
// Non-JSON logging format function
|
||||||
func (l *intLogger) logPlain(t time.Time, name string, level Level, msg string, args ...interface{}) {
|
func (l *intLogger) logPlain(t time.Time, name string, level Level, msg string, args ...interface{}) {
|
||||||
if len(l.timeFormat) > 0 {
|
|
||||||
|
if !l.disableTime {
|
||||||
l.writer.WriteString(t.Format(l.timeFormat))
|
l.writer.WriteString(t.Format(l.timeFormat))
|
||||||
l.writer.WriteByte(' ')
|
l.writer.WriteByte(' ')
|
||||||
}
|
}
|
||||||
@ -194,18 +214,8 @@ func (l *intLogger) logPlain(t time.Time, name string, level Level, msg string,
|
|||||||
l.writer.WriteString("[?????]")
|
l.writer.WriteString("[?????]")
|
||||||
}
|
}
|
||||||
|
|
||||||
offset := 3
|
if l.callerOffset > 0 {
|
||||||
if l.caller {
|
if _, file, line, ok := runtime.Caller(l.callerOffset); ok {
|
||||||
// Check if the caller is inside our package and inside
|
|
||||||
// a logger implementation file
|
|
||||||
if _, file, _, ok := runtime.Caller(3); ok {
|
|
||||||
match := logImplFile.MatchString(file)
|
|
||||||
if match {
|
|
||||||
offset = 4
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if _, file, line, ok := runtime.Caller(offset); ok {
|
|
||||||
l.writer.WriteByte(' ')
|
l.writer.WriteByte(' ')
|
||||||
l.writer.WriteString(trimCallerPath(file))
|
l.writer.WriteString(trimCallerPath(file))
|
||||||
l.writer.WriteByte(':')
|
l.writer.WriteByte(':')
|
||||||
@ -251,6 +261,9 @@ func (l *intLogger) logPlain(t time.Time, name string, level Level, msg string,
|
|||||||
switch st := args[i+1].(type) {
|
switch st := args[i+1].(type) {
|
||||||
case string:
|
case string:
|
||||||
val = st
|
val = st
|
||||||
|
if st == "" {
|
||||||
|
val = `""`
|
||||||
|
}
|
||||||
case int:
|
case int:
|
||||||
val = strconv.FormatInt(int64(st), 10)
|
val = strconv.FormatInt(int64(st), 10)
|
||||||
case int64:
|
case int64:
|
||||||
@ -292,20 +305,32 @@ func (l *intLogger) logPlain(t time.Time, name string, level Level, msg string,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
l.writer.WriteByte(' ')
|
var key string
|
||||||
|
|
||||||
switch st := args[i].(type) {
|
switch st := args[i].(type) {
|
||||||
case string:
|
case string:
|
||||||
l.writer.WriteString(st)
|
key = st
|
||||||
default:
|
default:
|
||||||
l.writer.WriteString(fmt.Sprintf("%s", st))
|
key = fmt.Sprintf("%s", st)
|
||||||
}
|
}
|
||||||
l.writer.WriteByte('=')
|
|
||||||
|
|
||||||
if !raw && strings.ContainsAny(val, " \t\n\r") {
|
if strings.Contains(val, "\n") {
|
||||||
|
l.writer.WriteString("\n ")
|
||||||
|
l.writer.WriteString(key)
|
||||||
|
l.writer.WriteString("=\n")
|
||||||
|
writeIndent(l.writer, val, " | ")
|
||||||
|
l.writer.WriteString(" ")
|
||||||
|
} else if !raw && strings.ContainsAny(val, " \t") {
|
||||||
|
l.writer.WriteByte(' ')
|
||||||
|
l.writer.WriteString(key)
|
||||||
|
l.writer.WriteByte('=')
|
||||||
l.writer.WriteByte('"')
|
l.writer.WriteByte('"')
|
||||||
l.writer.WriteString(val)
|
l.writer.WriteString(val)
|
||||||
l.writer.WriteByte('"')
|
l.writer.WriteByte('"')
|
||||||
} else {
|
} else {
|
||||||
|
l.writer.WriteByte(' ')
|
||||||
|
l.writer.WriteString(key)
|
||||||
|
l.writer.WriteByte('=')
|
||||||
l.writer.WriteString(val)
|
l.writer.WriteString(val)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -315,6 +340,26 @@ func (l *intLogger) logPlain(t time.Time, name string, level Level, msg string,
|
|||||||
|
|
||||||
if stacktrace != "" {
|
if stacktrace != "" {
|
||||||
l.writer.WriteString(string(stacktrace))
|
l.writer.WriteString(string(stacktrace))
|
||||||
|
l.writer.WriteString("\n")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func writeIndent(w *writer, str string, indent string) {
|
||||||
|
for {
|
||||||
|
nl := strings.IndexByte(str, "\n"[0])
|
||||||
|
if nl == -1 {
|
||||||
|
if str != "" {
|
||||||
|
w.WriteString(indent)
|
||||||
|
w.WriteString(str)
|
||||||
|
w.WriteString("\n")
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
w.WriteString(indent)
|
||||||
|
w.WriteString(str[:nl])
|
||||||
|
w.WriteString("\n")
|
||||||
|
str = str[nl+1:]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -334,22 +379,19 @@ func (l *intLogger) renderSlice(v reflect.Value) string {
|
|||||||
|
|
||||||
switch sv.Kind() {
|
switch sv.Kind() {
|
||||||
case reflect.String:
|
case reflect.String:
|
||||||
val = sv.String()
|
val = strconv.Quote(sv.String())
|
||||||
case reflect.Int, reflect.Int16, reflect.Int32, reflect.Int64:
|
case reflect.Int, reflect.Int16, reflect.Int32, reflect.Int64:
|
||||||
val = strconv.FormatInt(sv.Int(), 10)
|
val = strconv.FormatInt(sv.Int(), 10)
|
||||||
case reflect.Uint, reflect.Uint16, reflect.Uint32, reflect.Uint64:
|
case reflect.Uint, reflect.Uint16, reflect.Uint32, reflect.Uint64:
|
||||||
val = strconv.FormatUint(sv.Uint(), 10)
|
val = strconv.FormatUint(sv.Uint(), 10)
|
||||||
default:
|
default:
|
||||||
val = fmt.Sprintf("%v", sv.Interface())
|
val = fmt.Sprintf("%v", sv.Interface())
|
||||||
|
if strings.ContainsAny(val, " \t\n\r") {
|
||||||
|
val = strconv.Quote(val)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if strings.ContainsAny(val, " \t\n\r") {
|
|
||||||
buf.WriteByte('"')
|
|
||||||
buf.WriteString(val)
|
buf.WriteString(val)
|
||||||
buf.WriteByte('"')
|
|
||||||
} else {
|
|
||||||
buf.WriteString(val)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
buf.WriteRune(']')
|
buf.WriteRune(']')
|
||||||
@ -416,7 +458,9 @@ func (l *intLogger) logJSON(t time.Time, name string, level Level, msg string, a
|
|||||||
func (l intLogger) jsonMapEntry(t time.Time, name string, level Level, msg string) map[string]interface{} {
|
func (l intLogger) jsonMapEntry(t time.Time, name string, level Level, msg string) map[string]interface{} {
|
||||||
vals := map[string]interface{}{
|
vals := map[string]interface{}{
|
||||||
"@message": msg,
|
"@message": msg,
|
||||||
"@timestamp": t.Format("2006-01-02T15:04:05.000000Z07:00"),
|
}
|
||||||
|
if !l.disableTime {
|
||||||
|
vals["@timestamp"] = t.Format(l.timeFormat)
|
||||||
}
|
}
|
||||||
|
|
||||||
var levelStr string
|
var levelStr string
|
||||||
@ -441,8 +485,8 @@ func (l intLogger) jsonMapEntry(t time.Time, name string, level Level, msg strin
|
|||||||
vals["@module"] = name
|
vals["@module"] = name
|
||||||
}
|
}
|
||||||
|
|
||||||
if l.caller {
|
if l.callerOffset > 0 {
|
||||||
if _, file, line, ok := runtime.Caller(4); ok {
|
if _, file, line, ok := runtime.Caller(l.callerOffset + 1); ok {
|
||||||
vals["@caller"] = fmt.Sprintf("%s:%d", file, line)
|
vals["@caller"] = fmt.Sprintf("%s:%d", file, line)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -517,7 +561,7 @@ func (l *intLogger) With(args ...interface{}) Logger {
|
|||||||
args = args[:len(args)-1]
|
args = args[:len(args)-1]
|
||||||
}
|
}
|
||||||
|
|
||||||
sl := *l
|
sl := l.copy()
|
||||||
|
|
||||||
result := make(map[string]interface{}, len(l.implied)+len(args))
|
result := make(map[string]interface{}, len(l.implied)+len(args))
|
||||||
keys := make([]string, 0, len(l.implied)+len(args))
|
keys := make([]string, 0, len(l.implied)+len(args))
|
||||||
@ -551,13 +595,13 @@ func (l *intLogger) With(args ...interface{}) Logger {
|
|||||||
sl.implied = append(sl.implied, MissingKey, extra)
|
sl.implied = append(sl.implied, MissingKey, extra)
|
||||||
}
|
}
|
||||||
|
|
||||||
return &sl
|
return sl
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new sub-Logger that a name decending from the current name.
|
// Create a new sub-Logger that a name decending from the current name.
|
||||||
// This is used to create a subsystem specific Logger.
|
// This is used to create a subsystem specific Logger.
|
||||||
func (l *intLogger) Named(name string) Logger {
|
func (l *intLogger) Named(name string) Logger {
|
||||||
sl := *l
|
sl := l.copy()
|
||||||
|
|
||||||
if sl.name != "" {
|
if sl.name != "" {
|
||||||
sl.name = sl.name + "." + name
|
sl.name = sl.name + "." + name
|
||||||
@ -565,18 +609,18 @@ func (l *intLogger) Named(name string) Logger {
|
|||||||
sl.name = name
|
sl.name = name
|
||||||
}
|
}
|
||||||
|
|
||||||
return &sl
|
return sl
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new sub-Logger with an explicit name. This ignores the current
|
// Create a new sub-Logger with an explicit name. This ignores the current
|
||||||
// name. This is used to create a standalone logger that doesn't fall
|
// name. This is used to create a standalone logger that doesn't fall
|
||||||
// within the normal hierarchy.
|
// within the normal hierarchy.
|
||||||
func (l *intLogger) ResetNamed(name string) Logger {
|
func (l *intLogger) ResetNamed(name string) Logger {
|
||||||
sl := *l
|
sl := l.copy()
|
||||||
|
|
||||||
sl.name = name
|
sl.name = name
|
||||||
|
|
||||||
return &sl
|
return sl
|
||||||
}
|
}
|
||||||
|
|
||||||
func (l *intLogger) ResetOutput(opts *LoggerOptions) error {
|
func (l *intLogger) ResetOutput(opts *LoggerOptions) error {
|
||||||
@ -632,8 +676,15 @@ func (l *intLogger) StandardLogger(opts *StandardLoggerOptions) *log.Logger {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (l *intLogger) StandardWriter(opts *StandardLoggerOptions) io.Writer {
|
func (l *intLogger) StandardWriter(opts *StandardLoggerOptions) io.Writer {
|
||||||
|
newLog := *l
|
||||||
|
if l.callerOffset > 0 {
|
||||||
|
// the stack is
|
||||||
|
// logger.printf() -> l.Output() ->l.out.writer(hclog:stdlogAdaptor.write) -> hclog:stdlogAdaptor.dispatch()
|
||||||
|
// So plus 4.
|
||||||
|
newLog.callerOffset = l.callerOffset + 4
|
||||||
|
}
|
||||||
return &stdlogAdapter{
|
return &stdlogAdapter{
|
||||||
log: l,
|
log: &newLog,
|
||||||
inferLevels: opts.InferLevels,
|
inferLevels: opts.InferLevels,
|
||||||
forceLevel: opts.ForceLevel,
|
forceLevel: opts.ForceLevel,
|
||||||
}
|
}
|
||||||
@ -663,3 +714,16 @@ func (i *intLogger) ImpliedArgs() []interface{} {
|
|||||||
func (i *intLogger) Name() string {
|
func (i *intLogger) Name() string {
|
||||||
return i.name
|
return i.name
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// copy returns a shallow copy of the intLogger, replacing the level pointer
|
||||||
|
// when necessary
|
||||||
|
func (l *intLogger) copy() *intLogger {
|
||||||
|
sl := *l
|
||||||
|
|
||||||
|
if l.independentLevels {
|
||||||
|
sl.level = new(int32)
|
||||||
|
*sl.level = *l.level
|
||||||
|
}
|
||||||
|
|
||||||
|
return &sl
|
||||||
|
}
|
||||||
|
24
vendor/github.com/hashicorp/go-hclog/logger.go
generated
vendored
24
vendor/github.com/hashicorp/go-hclog/logger.go
generated
vendored
@ -38,6 +38,9 @@ const (
|
|||||||
|
|
||||||
// Error information about unrecoverable events.
|
// Error information about unrecoverable events.
|
||||||
Error Level = 5
|
Error Level = 5
|
||||||
|
|
||||||
|
// Off disables all logging output.
|
||||||
|
Off Level = 6
|
||||||
)
|
)
|
||||||
|
|
||||||
// Format is a simple convience type for when formatting is required. When
|
// Format is a simple convience type for when formatting is required. When
|
||||||
@ -96,6 +99,8 @@ func LevelFromString(levelStr string) Level {
|
|||||||
return Warn
|
return Warn
|
||||||
case "error":
|
case "error":
|
||||||
return Error
|
return Error
|
||||||
|
case "off":
|
||||||
|
return Off
|
||||||
default:
|
default:
|
||||||
return NoLevel
|
return NoLevel
|
||||||
}
|
}
|
||||||
@ -115,6 +120,8 @@ func (l Level) String() string {
|
|||||||
return "error"
|
return "error"
|
||||||
case NoLevel:
|
case NoLevel:
|
||||||
return "none"
|
return "none"
|
||||||
|
case Off:
|
||||||
|
return "off"
|
||||||
default:
|
default:
|
||||||
return "unknown"
|
return "unknown"
|
||||||
}
|
}
|
||||||
@ -179,7 +186,8 @@ type Logger interface {
|
|||||||
// the current name as well.
|
// the current name as well.
|
||||||
ResetNamed(name string) Logger
|
ResetNamed(name string) Logger
|
||||||
|
|
||||||
// Updates the level. This should affect all sub-loggers as well. If an
|
// Updates the level. This should affect all related loggers as well,
|
||||||
|
// unless they were created with IndependentLevels. If an
|
||||||
// implementation cannot update the level on the fly, it should no-op.
|
// implementation cannot update the level on the fly, it should no-op.
|
||||||
SetLevel(level Level)
|
SetLevel(level Level)
|
||||||
|
|
||||||
@ -227,6 +235,10 @@ type LoggerOptions struct {
|
|||||||
// Include file and line information in each log line
|
// Include file and line information in each log line
|
||||||
IncludeLocation bool
|
IncludeLocation bool
|
||||||
|
|
||||||
|
// AdditionalLocationOffset is the number of additional stack levels to skip
|
||||||
|
// when finding the file and line information for the log line
|
||||||
|
AdditionalLocationOffset int
|
||||||
|
|
||||||
// The time format to use instead of the default
|
// The time format to use instead of the default
|
||||||
TimeFormat string
|
TimeFormat string
|
||||||
|
|
||||||
@ -243,6 +255,12 @@ type LoggerOptions struct {
|
|||||||
// This is useful when interacting with a system that you wish to suppress the log
|
// This is useful when interacting with a system that you wish to suppress the log
|
||||||
// message for (because it's too noisy, etc)
|
// message for (because it's too noisy, etc)
|
||||||
Exclude func(level Level, msg string, args ...interface{}) bool
|
Exclude func(level Level, msg string, args ...interface{}) bool
|
||||||
|
|
||||||
|
// IndependentLevels causes subloggers to be created with an independent
|
||||||
|
// copy of this logger's level. This means that using SetLevel on this
|
||||||
|
// logger will not effect any subloggers, and SetLevel on any subloggers
|
||||||
|
// will not effect the parent or sibling loggers.
|
||||||
|
IndependentLevels bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// InterceptLogger describes the interface for using a logger
|
// InterceptLogger describes the interface for using a logger
|
||||||
@ -271,10 +289,10 @@ type InterceptLogger interface {
|
|||||||
// the current name as well.
|
// the current name as well.
|
||||||
ResetNamedIntercept(name string) InterceptLogger
|
ResetNamedIntercept(name string) InterceptLogger
|
||||||
|
|
||||||
// Return a value that conforms to the stdlib log.Logger interface
|
// Deprecated: use StandardLogger
|
||||||
StandardLoggerIntercept(opts *StandardLoggerOptions) *log.Logger
|
StandardLoggerIntercept(opts *StandardLoggerOptions) *log.Logger
|
||||||
|
|
||||||
// Return a value that conforms to io.Writer, which can be passed into log.SetOutput()
|
// Deprecated: use StandardWriter
|
||||||
StandardWriterIntercept(opts *StandardLoggerOptions) io.Writer
|
StandardWriterIntercept(opts *StandardLoggerOptions) io.Writer
|
||||||
}
|
}
|
||||||
|
|
||||||
|
6
vendor/github.com/hashicorp/vault/api/README.md
generated
vendored
Normal file
6
vendor/github.com/hashicorp/vault/api/README.md
generated
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
Vault API
|
||||||
|
=================
|
||||||
|
|
||||||
|
This provides the `github.com/hashicorp/vault/api` package which contains code useful for interacting with a Vault server.
|
||||||
|
|
||||||
|
[![GoDoc](https://godoc.org/github.com/hashicorp/vault/api?status.png)](https://godoc.org/github.com/hashicorp/vault/api)
|
349
vendor/github.com/hashicorp/vault/api/client.go
generated
vendored
349
vendor/github.com/hashicorp/vault/api/client.go
generated
vendored
@ -25,26 +25,30 @@ import (
|
|||||||
"golang.org/x/time/rate"
|
"golang.org/x/time/rate"
|
||||||
)
|
)
|
||||||
|
|
||||||
const EnvVaultAddress = "VAULT_ADDR"
|
const (
|
||||||
const EnvVaultAgentAddr = "VAULT_AGENT_ADDR"
|
EnvVaultAddress = "VAULT_ADDR"
|
||||||
const EnvVaultCACert = "VAULT_CACERT"
|
EnvVaultAgentAddr = "VAULT_AGENT_ADDR"
|
||||||
const EnvVaultCAPath = "VAULT_CAPATH"
|
EnvVaultCACert = "VAULT_CACERT"
|
||||||
const EnvVaultClientCert = "VAULT_CLIENT_CERT"
|
EnvVaultCAPath = "VAULT_CAPATH"
|
||||||
const EnvVaultClientKey = "VAULT_CLIENT_KEY"
|
EnvVaultClientCert = "VAULT_CLIENT_CERT"
|
||||||
const EnvVaultClientTimeout = "VAULT_CLIENT_TIMEOUT"
|
EnvVaultClientKey = "VAULT_CLIENT_KEY"
|
||||||
const EnvVaultSRVLookup = "VAULT_SRV_LOOKUP"
|
EnvVaultClientTimeout = "VAULT_CLIENT_TIMEOUT"
|
||||||
const EnvVaultSkipVerify = "VAULT_SKIP_VERIFY"
|
EnvVaultSRVLookup = "VAULT_SRV_LOOKUP"
|
||||||
const EnvVaultNamespace = "VAULT_NAMESPACE"
|
EnvVaultSkipVerify = "VAULT_SKIP_VERIFY"
|
||||||
const EnvVaultTLSServerName = "VAULT_TLS_SERVER_NAME"
|
EnvVaultNamespace = "VAULT_NAMESPACE"
|
||||||
const EnvVaultWrapTTL = "VAULT_WRAP_TTL"
|
EnvVaultTLSServerName = "VAULT_TLS_SERVER_NAME"
|
||||||
const EnvVaultMaxRetries = "VAULT_MAX_RETRIES"
|
EnvVaultWrapTTL = "VAULT_WRAP_TTL"
|
||||||
const EnvVaultToken = "VAULT_TOKEN"
|
EnvVaultMaxRetries = "VAULT_MAX_RETRIES"
|
||||||
const EnvVaultMFA = "VAULT_MFA"
|
EnvVaultToken = "VAULT_TOKEN"
|
||||||
const EnvRateLimit = "VAULT_RATE_LIMIT"
|
EnvVaultMFA = "VAULT_MFA"
|
||||||
|
EnvRateLimit = "VAULT_RATE_LIMIT"
|
||||||
|
)
|
||||||
|
|
||||||
// Deprecated values
|
// Deprecated values
|
||||||
const EnvVaultAgentAddress = "VAULT_AGENT_ADDR"
|
const (
|
||||||
const EnvVaultInsecure = "VAULT_SKIP_VERIFY"
|
EnvVaultAgentAddress = "VAULT_AGENT_ADDR"
|
||||||
|
EnvVaultInsecure = "VAULT_SKIP_VERIFY"
|
||||||
|
)
|
||||||
|
|
||||||
// WrappingLookupFunc is a function that, given an HTTP verb and a path,
|
// WrappingLookupFunc is a function that, given an HTTP verb and a path,
|
||||||
// returns an optional string duration to be used for response wrapping (e.g.
|
// returns an optional string duration to be used for response wrapping (e.g.
|
||||||
@ -75,6 +79,14 @@ type Config struct {
|
|||||||
// (or http.DefaultClient).
|
// (or http.DefaultClient).
|
||||||
HttpClient *http.Client
|
HttpClient *http.Client
|
||||||
|
|
||||||
|
// MinRetryWait controls the minimum time to wait before retrying when a 5xx
|
||||||
|
// error occurs. Defaults to 1000 milliseconds.
|
||||||
|
MinRetryWait time.Duration
|
||||||
|
|
||||||
|
// MaxRetryWait controls the maximum time to wait before retrying when a 5xx
|
||||||
|
// error occurs. Defaults to 1500 milliseconds.
|
||||||
|
MaxRetryWait time.Duration
|
||||||
|
|
||||||
// MaxRetries controls the maximum number of times to retry when a 5xx
|
// MaxRetries controls the maximum number of times to retry when a 5xx
|
||||||
// error occurs. Set to 0 to disable retrying. Defaults to 2 (for a total
|
// error occurs. Set to 0 to disable retrying. Defaults to 2 (for a total
|
||||||
// of three tries).
|
// of three tries).
|
||||||
@ -93,6 +105,9 @@ type Config struct {
|
|||||||
// The CheckRetry function to use; a default is used if not provided
|
// The CheckRetry function to use; a default is used if not provided
|
||||||
CheckRetry retryablehttp.CheckRetry
|
CheckRetry retryablehttp.CheckRetry
|
||||||
|
|
||||||
|
// Logger is the leveled logger to provide to the retryable HTTP client.
|
||||||
|
Logger retryablehttp.LeveledLogger
|
||||||
|
|
||||||
// Limiter is the rate limiter used by the client.
|
// Limiter is the rate limiter used by the client.
|
||||||
// If this pointer is nil, then there will be no limit set.
|
// If this pointer is nil, then there will be no limit set.
|
||||||
// In contrast, if this pointer is set, even to an empty struct,
|
// In contrast, if this pointer is set, even to an empty struct,
|
||||||
@ -149,6 +164,10 @@ func DefaultConfig() *Config {
|
|||||||
Address: "https://127.0.0.1:8200",
|
Address: "https://127.0.0.1:8200",
|
||||||
HttpClient: cleanhttp.DefaultPooledClient(),
|
HttpClient: cleanhttp.DefaultPooledClient(),
|
||||||
Timeout: time.Second * 60,
|
Timeout: time.Second * 60,
|
||||||
|
MinRetryWait: time.Millisecond * 1000,
|
||||||
|
MaxRetryWait: time.Millisecond * 1500,
|
||||||
|
MaxRetries: 2,
|
||||||
|
Backoff: retryablehttp.LinearJitterBackoff,
|
||||||
}
|
}
|
||||||
|
|
||||||
transport := config.HttpClient.Transport.(*http.Transport)
|
transport := config.HttpClient.Transport.(*http.Transport)
|
||||||
@ -178,9 +197,6 @@ func DefaultConfig() *Config {
|
|||||||
return http.ErrUseLastResponse
|
return http.ErrUseLastResponse
|
||||||
}
|
}
|
||||||
|
|
||||||
config.Backoff = retryablehttp.LinearJitterBackoff
|
|
||||||
config.MaxRetries = 2
|
|
||||||
|
|
||||||
return config
|
return config
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -360,7 +376,6 @@ func (c *Config) ReadEnvironment() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func parseRateLimit(val string) (rate float64, burst int, err error) {
|
func parseRateLimit(val string) (rate float64, burst int, err error) {
|
||||||
|
|
||||||
_, err = fmt.Sscanf(val, "%f:%d", &rate, &burst)
|
_, err = fmt.Sscanf(val, "%f:%d", &rate, &burst)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
rate, err = strconv.ParseFloat(val, 64)
|
rate, err = strconv.ParseFloat(val, 64)
|
||||||
@ -371,7 +386,6 @@ func parseRateLimit(val string) (rate float64, burst int, err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
return rate, burst, err
|
return rate, burst, err
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Client is the client to the Vault API. Create a client with NewClient.
|
// Client is the client to the Vault API. Create a client with NewClient.
|
||||||
@ -384,6 +398,8 @@ type Client struct {
|
|||||||
wrappingLookupFunc WrappingLookupFunc
|
wrappingLookupFunc WrappingLookupFunc
|
||||||
mfaCreds []string
|
mfaCreds []string
|
||||||
policyOverride bool
|
policyOverride bool
|
||||||
|
requestCallbacks []RequestCallback
|
||||||
|
responseCallbacks []ResponseCallback
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewClient returns a new client for the given configuration.
|
// NewClient returns a new client for the given configuration.
|
||||||
@ -410,6 +426,14 @@ func NewClient(c *Config) (*Client, error) {
|
|||||||
c.modifyLock.Lock()
|
c.modifyLock.Lock()
|
||||||
defer c.modifyLock.Unlock()
|
defer c.modifyLock.Unlock()
|
||||||
|
|
||||||
|
if c.MinRetryWait == 0 {
|
||||||
|
c.MinRetryWait = def.MinRetryWait
|
||||||
|
}
|
||||||
|
|
||||||
|
if c.MaxRetryWait == 0 {
|
||||||
|
c.MaxRetryWait = def.MaxRetryWait
|
||||||
|
}
|
||||||
|
|
||||||
if c.HttpClient == nil {
|
if c.HttpClient == nil {
|
||||||
c.HttpClient = def.HttpClient
|
c.HttpClient = def.HttpClient
|
||||||
}
|
}
|
||||||
@ -463,6 +487,31 @@ func NewClient(c *Config) (*Client, error) {
|
|||||||
return client, nil
|
return client, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) CloneConfig() *Config {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
newConfig := DefaultConfig()
|
||||||
|
newConfig.Address = c.config.Address
|
||||||
|
newConfig.AgentAddress = c.config.AgentAddress
|
||||||
|
newConfig.MinRetryWait = c.config.MinRetryWait
|
||||||
|
newConfig.MaxRetryWait = c.config.MaxRetryWait
|
||||||
|
newConfig.MaxRetries = c.config.MaxRetries
|
||||||
|
newConfig.Timeout = c.config.Timeout
|
||||||
|
newConfig.Backoff = c.config.Backoff
|
||||||
|
newConfig.CheckRetry = c.config.CheckRetry
|
||||||
|
newConfig.Logger = c.config.Logger
|
||||||
|
newConfig.Limiter = c.config.Limiter
|
||||||
|
newConfig.OutputCurlString = c.config.OutputCurlString
|
||||||
|
newConfig.SRVLookup = c.config.SRVLookup
|
||||||
|
|
||||||
|
// we specifically want a _copy_ of the client here, not a pointer to the original one
|
||||||
|
newClient := *c.config.HttpClient
|
||||||
|
newConfig.HttpClient = &newClient
|
||||||
|
|
||||||
|
return newConfig
|
||||||
|
}
|
||||||
|
|
||||||
// Sets the address of Vault in the client. The format of address should be
|
// Sets the address of Vault in the client. The format of address should be
|
||||||
// "<Scheme>://<Host>:<Port>". Setting this on a client will override the
|
// "<Scheme>://<Host>:<Port>". Setting this on a client will override the
|
||||||
// value of VAULT_ADDR environment variable.
|
// value of VAULT_ADDR environment variable.
|
||||||
@ -475,6 +524,9 @@ func (c *Client) SetAddress(addr string) error {
|
|||||||
return errwrap.Wrapf("failed to set address: {{err}}", err)
|
return errwrap.Wrapf("failed to set address: {{err}}", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c.config.modifyLock.Lock()
|
||||||
|
c.config.Address = addr
|
||||||
|
c.config.modifyLock.Unlock()
|
||||||
c.addr = parsedAddr
|
c.addr = parsedAddr
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -492,57 +544,149 @@ func (c *Client) Address() string {
|
|||||||
// rateLimit and burst are specified according to https://godoc.org/golang.org/x/time/rate#NewLimiter
|
// rateLimit and burst are specified according to https://godoc.org/golang.org/x/time/rate#NewLimiter
|
||||||
func (c *Client) SetLimiter(rateLimit float64, burst int) {
|
func (c *Client) SetLimiter(rateLimit float64, burst int) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.Lock()
|
c.config.modifyLock.Lock()
|
||||||
defer c.config.modifyLock.Unlock()
|
defer c.config.modifyLock.Unlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
c.config.Limiter = rate.NewLimiter(rate.Limit(rateLimit), burst)
|
c.config.Limiter = rate.NewLimiter(rate.Limit(rateLimit), burst)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) Limiter() *rate.Limiter {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.Limiter
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetMinRetryWait sets the minimum time to wait before retrying in the case of certain errors.
|
||||||
|
func (c *Client) SetMinRetryWait(retryWait time.Duration) {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.Lock()
|
||||||
|
defer c.config.modifyLock.Unlock()
|
||||||
|
|
||||||
|
c.config.MinRetryWait = retryWait
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) MinRetryWait() time.Duration {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.MinRetryWait
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetMaxRetryWait sets the maximum time to wait before retrying in the case of certain errors.
|
||||||
|
func (c *Client) SetMaxRetryWait(retryWait time.Duration) {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.Lock()
|
||||||
|
defer c.config.modifyLock.Unlock()
|
||||||
|
|
||||||
|
c.config.MaxRetryWait = retryWait
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) MaxRetryWait() time.Duration {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.MaxRetryWait
|
||||||
|
}
|
||||||
|
|
||||||
// SetMaxRetries sets the number of retries that will be used in the case of certain errors
|
// SetMaxRetries sets the number of retries that will be used in the case of certain errors
|
||||||
func (c *Client) SetMaxRetries(retries int) {
|
func (c *Client) SetMaxRetries(retries int) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.Lock()
|
c.config.modifyLock.Lock()
|
||||||
defer c.config.modifyLock.Unlock()
|
defer c.config.modifyLock.Unlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
c.config.MaxRetries = retries
|
c.config.MaxRetries = retries
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) MaxRetries() int {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.MaxRetries
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) SetSRVLookup(srv bool) {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.Lock()
|
||||||
|
defer c.config.modifyLock.Unlock()
|
||||||
|
|
||||||
|
c.config.SRVLookup = srv
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) SRVLookup() bool {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.SRVLookup
|
||||||
|
}
|
||||||
|
|
||||||
// SetCheckRetry sets the CheckRetry function to be used for future requests.
|
// SetCheckRetry sets the CheckRetry function to be used for future requests.
|
||||||
func (c *Client) SetCheckRetry(checkRetry retryablehttp.CheckRetry) {
|
func (c *Client) SetCheckRetry(checkRetry retryablehttp.CheckRetry) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.Lock()
|
c.config.modifyLock.Lock()
|
||||||
defer c.config.modifyLock.Unlock()
|
defer c.config.modifyLock.Unlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
c.config.CheckRetry = checkRetry
|
c.config.CheckRetry = checkRetry
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) CheckRetry() retryablehttp.CheckRetry {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.CheckRetry
|
||||||
|
}
|
||||||
|
|
||||||
// SetClientTimeout sets the client request timeout
|
// SetClientTimeout sets the client request timeout
|
||||||
func (c *Client) SetClientTimeout(timeout time.Duration) {
|
func (c *Client) SetClientTimeout(timeout time.Duration) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.Lock()
|
c.config.modifyLock.Lock()
|
||||||
defer c.config.modifyLock.Unlock()
|
defer c.config.modifyLock.Unlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
c.config.Timeout = timeout
|
c.config.Timeout = timeout
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Client) OutputCurlString() bool {
|
func (c *Client) ClientTimeout() time.Duration {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.RLock()
|
||||||
|
defer c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
return c.config.Timeout
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *Client) OutputCurlString() bool {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.RLock()
|
c.config.modifyLock.RLock()
|
||||||
defer c.config.modifyLock.RUnlock()
|
defer c.config.modifyLock.RUnlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
return c.config.OutputCurlString
|
return c.config.OutputCurlString
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Client) SetOutputCurlString(curl bool) {
|
func (c *Client) SetOutputCurlString(curl bool) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.Lock()
|
c.config.modifyLock.Lock()
|
||||||
defer c.config.modifyLock.Unlock()
|
defer c.config.modifyLock.Unlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
c.config.OutputCurlString = curl
|
c.config.OutputCurlString = curl
|
||||||
}
|
}
|
||||||
@ -552,7 +696,6 @@ func (c *Client) SetOutputCurlString(curl bool) {
|
|||||||
func (c *Client) CurrentWrappingLookupFunc() WrappingLookupFunc {
|
func (c *Client) CurrentWrappingLookupFunc() WrappingLookupFunc {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
defer c.modifyLock.RUnlock()
|
defer c.modifyLock.RUnlock()
|
||||||
|
|
||||||
return c.wrappingLookupFunc
|
return c.wrappingLookupFunc
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -561,7 +704,6 @@ func (c *Client) CurrentWrappingLookupFunc() WrappingLookupFunc {
|
|||||||
func (c *Client) SetWrappingLookupFunc(lookupFunc WrappingLookupFunc) {
|
func (c *Client) SetWrappingLookupFunc(lookupFunc WrappingLookupFunc) {
|
||||||
c.modifyLock.Lock()
|
c.modifyLock.Lock()
|
||||||
defer c.modifyLock.Unlock()
|
defer c.modifyLock.Unlock()
|
||||||
|
|
||||||
c.wrappingLookupFunc = lookupFunc
|
c.wrappingLookupFunc = lookupFunc
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -570,7 +712,6 @@ func (c *Client) SetWrappingLookupFunc(lookupFunc WrappingLookupFunc) {
|
|||||||
func (c *Client) SetMFACreds(creds []string) {
|
func (c *Client) SetMFACreds(creds []string) {
|
||||||
c.modifyLock.Lock()
|
c.modifyLock.Lock()
|
||||||
defer c.modifyLock.Unlock()
|
defer c.modifyLock.Unlock()
|
||||||
|
|
||||||
c.mfaCreds = creds
|
c.mfaCreds = creds
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -595,7 +736,6 @@ func (c *Client) setNamespace(namespace string) {
|
|||||||
func (c *Client) Token() string {
|
func (c *Client) Token() string {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
defer c.modifyLock.RUnlock()
|
defer c.modifyLock.RUnlock()
|
||||||
|
|
||||||
return c.token
|
return c.token
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -604,7 +744,6 @@ func (c *Client) Token() string {
|
|||||||
func (c *Client) SetToken(v string) {
|
func (c *Client) SetToken(v string) {
|
||||||
c.modifyLock.Lock()
|
c.modifyLock.Lock()
|
||||||
defer c.modifyLock.Unlock()
|
defer c.modifyLock.Unlock()
|
||||||
|
|
||||||
c.token = v
|
c.token = v
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -612,7 +751,6 @@ func (c *Client) SetToken(v string) {
|
|||||||
func (c *Client) ClearToken() {
|
func (c *Client) ClearToken() {
|
||||||
c.modifyLock.Lock()
|
c.modifyLock.Lock()
|
||||||
defer c.modifyLock.Unlock()
|
defer c.modifyLock.Unlock()
|
||||||
|
|
||||||
c.token = ""
|
c.token = ""
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -655,13 +793,22 @@ func (c *Client) SetHeaders(headers http.Header) {
|
|||||||
// SetBackoff sets the backoff function to be used for future requests.
|
// SetBackoff sets the backoff function to be used for future requests.
|
||||||
func (c *Client) SetBackoff(backoff retryablehttp.Backoff) {
|
func (c *Client) SetBackoff(backoff retryablehttp.Backoff) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
c.config.modifyLock.Lock()
|
c.config.modifyLock.Lock()
|
||||||
defer c.config.modifyLock.Unlock()
|
defer c.config.modifyLock.Unlock()
|
||||||
c.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
c.config.Backoff = backoff
|
c.config.Backoff = backoff
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Client) SetLogger(logger retryablehttp.LeveledLogger) {
|
||||||
|
c.modifyLock.RLock()
|
||||||
|
defer c.modifyLock.RUnlock()
|
||||||
|
c.config.modifyLock.Lock()
|
||||||
|
defer c.config.modifyLock.Unlock()
|
||||||
|
|
||||||
|
c.config.Logger = logger
|
||||||
|
}
|
||||||
|
|
||||||
// Clone creates a new client with the same configuration. Note that the same
|
// Clone creates a new client with the same configuration. Note that the same
|
||||||
// underlying http.Client is used; modifying the client from more than one
|
// underlying http.Client is used; modifying the client from more than one
|
||||||
// goroutine at once may not be safe, so modify the client as needed and then
|
// goroutine at once may not be safe, so modify the client as needed and then
|
||||||
@ -672,22 +819,33 @@ func (c *Client) SetBackoff(backoff retryablehttp.Backoff) {
|
|||||||
// behavior, must currently then be set as desired on the new client.
|
// behavior, must currently then be set as desired on the new client.
|
||||||
func (c *Client) Clone() (*Client, error) {
|
func (c *Client) Clone() (*Client, error) {
|
||||||
c.modifyLock.RLock()
|
c.modifyLock.RLock()
|
||||||
c.config.modifyLock.RLock()
|
defer c.modifyLock.RUnlock()
|
||||||
|
|
||||||
config := c.config
|
config := c.config
|
||||||
c.modifyLock.RUnlock()
|
config.modifyLock.RLock()
|
||||||
|
defer config.modifyLock.RUnlock()
|
||||||
|
|
||||||
newConfig := &Config{
|
newConfig := &Config{
|
||||||
Address: config.Address,
|
Address: config.Address,
|
||||||
HttpClient: config.HttpClient,
|
HttpClient: config.HttpClient,
|
||||||
|
MinRetryWait: config.MinRetryWait,
|
||||||
|
MaxRetryWait: config.MaxRetryWait,
|
||||||
MaxRetries: config.MaxRetries,
|
MaxRetries: config.MaxRetries,
|
||||||
Timeout: config.Timeout,
|
Timeout: config.Timeout,
|
||||||
Backoff: config.Backoff,
|
Backoff: config.Backoff,
|
||||||
CheckRetry: config.CheckRetry,
|
CheckRetry: config.CheckRetry,
|
||||||
|
Logger: config.Logger,
|
||||||
Limiter: config.Limiter,
|
Limiter: config.Limiter,
|
||||||
|
OutputCurlString: config.OutputCurlString,
|
||||||
|
AgentAddress: config.AgentAddress,
|
||||||
|
SRVLookup: config.SRVLookup,
|
||||||
|
}
|
||||||
|
client, err := NewClient(newConfig)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
}
|
}
|
||||||
config.modifyLock.RUnlock()
|
|
||||||
|
|
||||||
return NewClient(newConfig)
|
return client, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// SetPolicyOverride sets whether requests should be sent with the policy
|
// SetPolicyOverride sets whether requests should be sent with the policy
|
||||||
@ -696,7 +854,6 @@ func (c *Client) Clone() (*Client, error) {
|
|||||||
func (c *Client) SetPolicyOverride(override bool) {
|
func (c *Client) SetPolicyOverride(override bool) {
|
||||||
c.modifyLock.Lock()
|
c.modifyLock.Lock()
|
||||||
defer c.modifyLock.Unlock()
|
defer c.modifyLock.Unlock()
|
||||||
|
|
||||||
c.policyOverride = override
|
c.policyOverride = override
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -712,7 +869,7 @@ func (c *Client) NewRequest(method, requestPath string) *Request {
|
|||||||
policyOverride := c.policyOverride
|
policyOverride := c.policyOverride
|
||||||
c.modifyLock.RUnlock()
|
c.modifyLock.RUnlock()
|
||||||
|
|
||||||
var host = addr.Host
|
host := addr.Host
|
||||||
// if SRV records exist (see https://tools.ietf.org/html/draft-andrews-http-srv-02), lookup the SRV
|
// if SRV records exist (see https://tools.ietf.org/html/draft-andrews-http-srv-02), lookup the SRV
|
||||||
// record and take the highest match; this is not designed for high-availability, just discovery
|
// record and take the highest match; this is not designed for high-availability, just discovery
|
||||||
// Internet Draft specifies that the SRV record is ignored if a port is given
|
// Internet Draft specifies that the SRV record is ignored if a port is given
|
||||||
@ -776,16 +933,23 @@ func (c *Client) RawRequestWithContext(ctx context.Context, r *Request) (*Respon
|
|||||||
|
|
||||||
c.config.modifyLock.RLock()
|
c.config.modifyLock.RLock()
|
||||||
limiter := c.config.Limiter
|
limiter := c.config.Limiter
|
||||||
|
minRetryWait := c.config.MinRetryWait
|
||||||
|
maxRetryWait := c.config.MaxRetryWait
|
||||||
maxRetries := c.config.MaxRetries
|
maxRetries := c.config.MaxRetries
|
||||||
checkRetry := c.config.CheckRetry
|
checkRetry := c.config.CheckRetry
|
||||||
backoff := c.config.Backoff
|
backoff := c.config.Backoff
|
||||||
httpClient := c.config.HttpClient
|
httpClient := c.config.HttpClient
|
||||||
timeout := c.config.Timeout
|
timeout := c.config.Timeout
|
||||||
outputCurlString := c.config.OutputCurlString
|
outputCurlString := c.config.OutputCurlString
|
||||||
|
logger := c.config.Logger
|
||||||
c.config.modifyLock.RUnlock()
|
c.config.modifyLock.RUnlock()
|
||||||
|
|
||||||
c.modifyLock.RUnlock()
|
c.modifyLock.RUnlock()
|
||||||
|
|
||||||
|
for _, cb := range c.requestCallbacks {
|
||||||
|
cb(r)
|
||||||
|
}
|
||||||
|
|
||||||
if limiter != nil {
|
if limiter != nil {
|
||||||
limiter.Wait(ctx)
|
limiter.Wait(ctx)
|
||||||
}
|
}
|
||||||
@ -809,7 +973,10 @@ START:
|
|||||||
}
|
}
|
||||||
|
|
||||||
if outputCurlString {
|
if outputCurlString {
|
||||||
LastOutputStringError = &OutputStringError{Request: req}
|
LastOutputStringError = &OutputStringError{
|
||||||
|
Request: req,
|
||||||
|
TLSSkipVerify: c.config.HttpClient.Transport.(*http.Transport).TLSClientConfig.InsecureSkipVerify,
|
||||||
|
}
|
||||||
return nil, LastOutputStringError
|
return nil, LastOutputStringError
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -827,16 +994,17 @@ START:
|
|||||||
}
|
}
|
||||||
|
|
||||||
if checkRetry == nil {
|
if checkRetry == nil {
|
||||||
checkRetry = retryablehttp.DefaultRetryPolicy
|
checkRetry = DefaultRetryPolicy
|
||||||
}
|
}
|
||||||
|
|
||||||
client := &retryablehttp.Client{
|
client := &retryablehttp.Client{
|
||||||
HTTPClient: httpClient,
|
HTTPClient: httpClient,
|
||||||
RetryWaitMin: 1000 * time.Millisecond,
|
RetryWaitMin: minRetryWait,
|
||||||
RetryWaitMax: 1500 * time.Millisecond,
|
RetryWaitMax: maxRetryWait,
|
||||||
RetryMax: maxRetries,
|
RetryMax: maxRetries,
|
||||||
Backoff: backoff,
|
Backoff: backoff,
|
||||||
CheckRetry: checkRetry,
|
CheckRetry: checkRetry,
|
||||||
|
Logger: logger,
|
||||||
ErrorHandler: retryablehttp.PassthroughErrorHandler,
|
ErrorHandler: retryablehttp.PassthroughErrorHandler,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -888,9 +1056,96 @@ START:
|
|||||||
goto START
|
goto START
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if result != nil {
|
||||||
|
for _, cb := range c.responseCallbacks {
|
||||||
|
cb(result)
|
||||||
|
}
|
||||||
|
}
|
||||||
if err := result.Error(); err != nil {
|
if err := result.Error(); err != nil {
|
||||||
return result, err
|
return result, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return result, nil
|
return result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type (
|
||||||
|
RequestCallback func(*Request)
|
||||||
|
ResponseCallback func(*Response)
|
||||||
|
)
|
||||||
|
|
||||||
|
// WithRequestCallbacks makes a shallow clone of Client, modifies it to use
|
||||||
|
// the given callbacks, and returns it. Each of the callbacks will be invoked
|
||||||
|
// on every outgoing request. A client may be used to issue requests
|
||||||
|
// concurrently; any locking needed by callbacks invoked concurrently is the
|
||||||
|
// callback's responsibility.
|
||||||
|
func (c *Client) WithRequestCallbacks(callbacks ...RequestCallback) *Client {
|
||||||
|
c2 := *c
|
||||||
|
c2.modifyLock = sync.RWMutex{}
|
||||||
|
c2.requestCallbacks = callbacks
|
||||||
|
return &c2
|
||||||
|
}
|
||||||
|
|
||||||
|
// WithResponseCallbacks makes a shallow clone of Client, modifies it to use
|
||||||
|
// the given callbacks, and returns it. Each of the callbacks will be invoked
|
||||||
|
// on every received response. A client may be used to issue requests
|
||||||
|
// concurrently; any locking needed by callbacks invoked concurrently is the
|
||||||
|
// callback's responsibility.
|
||||||
|
func (c *Client) WithResponseCallbacks(callbacks ...ResponseCallback) *Client {
|
||||||
|
c2 := *c
|
||||||
|
c2.modifyLock = sync.RWMutex{}
|
||||||
|
c2.responseCallbacks = callbacks
|
||||||
|
return &c2
|
||||||
|
}
|
||||||
|
|
||||||
|
// RecordState returns a response callback that will record the state returned
|
||||||
|
// by Vault in a response header.
|
||||||
|
func RecordState(state *string) ResponseCallback {
|
||||||
|
return func(resp *Response) {
|
||||||
|
*state = resp.Header.Get("X-Vault-Index")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// RequireState returns a request callback that will add a request header to
|
||||||
|
// specify the state we require of Vault. This state was obtained from a
|
||||||
|
// response header seen previous, probably captured with RecordState.
|
||||||
|
func RequireState(states ...string) RequestCallback {
|
||||||
|
return func(req *Request) {
|
||||||
|
for _, s := range states {
|
||||||
|
req.Headers.Add("X-Vault-Index", s)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ForwardInconsistent returns a request callback that will add a request
|
||||||
|
// header which says: if the state required isn't present on the node receiving
|
||||||
|
// this request, forward it to the active node. This should be used in
|
||||||
|
// conjunction with RequireState.
|
||||||
|
func ForwardInconsistent() RequestCallback {
|
||||||
|
return func(req *Request) {
|
||||||
|
req.Headers.Set("X-Vault-Inconsistent", "forward-active-node")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ForwardAlways returns a request callback which adds a header telling any
|
||||||
|
// performance standbys handling the request to forward it to the active node.
|
||||||
|
// This feature must be enabled in Vault's configuration.
|
||||||
|
func ForwardAlways() RequestCallback {
|
||||||
|
return func(req *Request) {
|
||||||
|
req.Headers.Set("X-Vault-Forward", "active-node")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// DefaultRetryPolicy is the default retry policy used by new Client objects.
|
||||||
|
// It is the same as retryablehttp.DefaultRetryPolicy except that it also retries
|
||||||
|
// 412 requests, which are returned by Vault when a X-Vault-Index header isn't
|
||||||
|
// satisfied.
|
||||||
|
func DefaultRetryPolicy(ctx context.Context, resp *http.Response, err error) (bool, error) {
|
||||||
|
retry, err := retryablehttp.DefaultRetryPolicy(ctx, resp, err)
|
||||||
|
if err != nil || retry {
|
||||||
|
return retry, err
|
||||||
|
}
|
||||||
|
if resp != nil && resp.StatusCode == 412 {
|
||||||
|
return true, nil
|
||||||
|
}
|
||||||
|
return false, nil
|
||||||
|
}
|
||||||
|
4
vendor/github.com/hashicorp/vault/api/go.mod
generated
vendored
4
vendor/github.com/hashicorp/vault/api/go.mod
generated
vendored
@ -5,14 +5,16 @@ go 1.13
|
|||||||
replace github.com/hashicorp/vault/sdk => ../sdk
|
replace github.com/hashicorp/vault/sdk => ../sdk
|
||||||
|
|
||||||
require (
|
require (
|
||||||
|
github.com/cenkalti/backoff/v3 v3.0.0
|
||||||
github.com/go-test/deep v1.0.2
|
github.com/go-test/deep v1.0.2
|
||||||
github.com/hashicorp/errwrap v1.0.0
|
github.com/hashicorp/errwrap v1.0.0
|
||||||
github.com/hashicorp/go-cleanhttp v0.5.1
|
github.com/hashicorp/go-cleanhttp v0.5.1
|
||||||
|
github.com/hashicorp/go-hclog v0.16.1
|
||||||
github.com/hashicorp/go-multierror v1.1.0
|
github.com/hashicorp/go-multierror v1.1.0
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.6
|
github.com/hashicorp/go-retryablehttp v0.6.6
|
||||||
github.com/hashicorp/go-rootcerts v1.0.2
|
github.com/hashicorp/go-rootcerts v1.0.2
|
||||||
github.com/hashicorp/hcl v1.0.0
|
github.com/hashicorp/hcl v1.0.0
|
||||||
github.com/hashicorp/vault/sdk v0.1.14-0.20200519221838-e0cfd64bc267
|
github.com/hashicorp/vault/sdk v0.2.1
|
||||||
github.com/mitchellh/mapstructure v1.3.2
|
github.com/mitchellh/mapstructure v1.3.2
|
||||||
golang.org/x/net v0.0.0-20200602114024-627f9648deb9
|
golang.org/x/net v0.0.0-20200602114024-627f9648deb9
|
||||||
golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1
|
golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1
|
||||||
|
34
vendor/github.com/hashicorp/vault/api/go.sum
generated
vendored
34
vendor/github.com/hashicorp/vault/api/go.sum
generated
vendored
@ -10,15 +10,15 @@ github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuy
|
|||||||
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
||||||
github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
|
||||||
github.com/armon/go-metrics v0.3.3/go.mod h1:4O98XIr/9W0sxpJ8UaYkvjk10Iff7SnFrb4QAOwNTFc=
|
github.com/armon/go-metrics v0.3.3/go.mod h1:4O98XIr/9W0sxpJ8UaYkvjk10Iff7SnFrb4QAOwNTFc=
|
||||||
github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310 h1:BUAU3CGlLvorLI26FmByPp2eC2qla6E1Tw+scpcg/to=
|
|
||||||
github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
|
github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
|
||||||
github.com/armon/go-radix v1.0.0/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
|
github.com/armon/go-radix v1.0.0/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
|
||||||
github.com/aws/aws-sdk-go v1.30.27/go.mod h1:5zCpMtNQVjRREroY7sYe8lOMRSxkhG6MZveU8YkpAk0=
|
github.com/aws/aws-sdk-go v1.30.27/go.mod h1:5zCpMtNQVjRREroY7sYe8lOMRSxkhG6MZveU8YkpAk0=
|
||||||
github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
|
github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
|
||||||
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
|
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
|
||||||
github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
|
github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw=
|
||||||
github.com/bgentry/speakeasy v0.1.0 h1:ByYyxL9InA1OWqxJqqp2A5pYHUrCiAL6K3J+LKSsQkY=
|
|
||||||
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
|
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
|
||||||
|
github.com/cenkalti/backoff/v3 v3.0.0 h1:ske+9nBpD9qZsTBoF41nW5L+AIuFBKMeze18XQ3eG1c=
|
||||||
|
github.com/cenkalti/backoff/v3 v3.0.0/go.mod h1:cIeZDE3IrqwwJl6VUwCN6trj1oXrTS4rc0ij+ULvLYs=
|
||||||
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
|
||||||
github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
|
github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
|
||||||
github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6Dob7S7YxXgwXpfOuvO54S+tGdZdw9fuRZt25Ag=
|
github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6Dob7S7YxXgwXpfOuvO54S+tGdZdw9fuRZt25Ag=
|
||||||
@ -63,7 +63,6 @@ github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9
|
|||||||
github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk=
|
github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk=
|
||||||
github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
github.com/go-sql-driver/mysql v1.5.0/go.mod h1:DCzpHaOWr8IXmIStZouvnhqoel9Qv2LBy8hT2VhHyBg=
|
||||||
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
|
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
|
||||||
github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31 h1:28FVBuwkwowZMjbA7M0wXsI6t3PYulRTMio3SO+eKCM=
|
|
||||||
github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA=
|
github.com/go-test/deep v1.0.2-0.20181118220953-042da051cf31/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA=
|
||||||
github.com/go-test/deep v1.0.2 h1:onZX1rnHT3Wv6cqNgYyFOOlgVKJrksuCMCRvJStbMYw=
|
github.com/go-test/deep v1.0.2 h1:onZX1rnHT3Wv6cqNgYyFOOlgVKJrksuCMCRvJStbMYw=
|
||||||
github.com/go-test/deep v1.0.2/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA=
|
github.com/go-test/deep v1.0.2/go.mod h1:wGDj63lr65AM2AQyKZd/NYHGb0R+1RLqB8NKt3aSFNA=
|
||||||
@ -89,8 +88,9 @@ github.com/golang/snappy v0.0.1/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEW
|
|||||||
github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
|
github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M=
|
||||||
github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
||||||
github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU=
|
||||||
github.com/google/go-cmp v0.4.0 h1:xsAVV57WRhGj6kEIi8ReJzQlHHqcBYCElAvkovg3B/4=
|
|
||||||
github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
|
github.com/google/go-cmp v0.5.0 h1:/QaMHBdZ26BB3SSst0Iwl10Epc+xhTquomWX0oZEB6w=
|
||||||
|
github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
|
||||||
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
|
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
|
||||||
github.com/gorilla/mux v1.7.4/go.mod h1:DVbg23sWSpFRCP0SfiEN6jmj59UnW/n46BH5rLB71So=
|
github.com/gorilla/mux v1.7.4/go.mod h1:DVbg23sWSpFRCP0SfiEN6jmj59UnW/n46BH5rLB71So=
|
||||||
github.com/hashicorp/errwrap v1.0.0 h1:hLrqtEDnRye3+sgx6z4qVLNuviH3MR5aQ0ykNJa/UYA=
|
github.com/hashicorp/errwrap v1.0.0 h1:hLrqtEDnRye3+sgx6z4qVLNuviH3MR5aQ0ykNJa/UYA=
|
||||||
@ -99,24 +99,21 @@ github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtng
|
|||||||
github.com/hashicorp/go-cleanhttp v0.5.1 h1:dH3aiDG9Jvb5r5+bYHsikaOUIpcM0xvgMXVoDkXMzJM=
|
github.com/hashicorp/go-cleanhttp v0.5.1 h1:dH3aiDG9Jvb5r5+bYHsikaOUIpcM0xvgMXVoDkXMzJM=
|
||||||
github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
|
github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
|
||||||
github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd/go.mod h1:9bjs9uLqI8l75knNv3lV1kA55veR+WUPSiKIWcQHudI=
|
github.com/hashicorp/go-hclog v0.0.0-20180709165350-ff2cf002a8dd/go.mod h1:9bjs9uLqI8l75knNv3lV1kA55veR+WUPSiKIWcQHudI=
|
||||||
github.com/hashicorp/go-hclog v0.9.2 h1:CG6TE5H9/JXsFWJCfoIVpKFIkFe6ysEuHirp4DxCsHI=
|
|
||||||
github.com/hashicorp/go-hclog v0.9.2/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ=
|
github.com/hashicorp/go-hclog v0.9.2/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ=
|
||||||
github.com/hashicorp/go-hclog v0.14.1 h1:nQcJDQwIAGnmoUWp8ubocEX40cCml/17YkF6csQLReU=
|
|
||||||
github.com/hashicorp/go-hclog v0.14.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
github.com/hashicorp/go-hclog v0.14.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
||||||
|
github.com/hashicorp/go-hclog v0.16.1 h1:IVQwpTGNRRIHafnTs2dQLIk4ENtneRIEEJWOVDqz99o=
|
||||||
|
github.com/hashicorp/go-hclog v0.16.1/go.mod h1:whpDNt7SSdeAju8AWKIWsul05p54N/39EeqMAyrmvFQ=
|
||||||
github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
||||||
github.com/hashicorp/go-immutable-radix v1.1.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
github.com/hashicorp/go-immutable-radix v1.1.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
|
||||||
github.com/hashicorp/go-kms-wrapping/entropy v0.1.0/go.mod h1:d1g9WGtAunDNpek8jUIEJnBlbgKS1N2Q61QkHiZyR1g=
|
github.com/hashicorp/go-kms-wrapping/entropy v0.1.0/go.mod h1:d1g9WGtAunDNpek8jUIEJnBlbgKS1N2Q61QkHiZyR1g=
|
||||||
github.com/hashicorp/go-multierror v1.0.0 h1:iVjPR7a6H0tWELX5NxNe7bYopibicUzc7uPribsnS6o=
|
|
||||||
github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk=
|
github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk=
|
||||||
github.com/hashicorp/go-multierror v1.1.0 h1:B9UzwGQJehnUY1yNrnwREHc3fGbC2xefo8g4TbElacI=
|
github.com/hashicorp/go-multierror v1.1.0 h1:B9UzwGQJehnUY1yNrnwREHc3fGbC2xefo8g4TbElacI=
|
||||||
github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA=
|
github.com/hashicorp/go-multierror v1.1.0/go.mod h1:spPvp8C1qA32ftKqdAHm4hHTbPw+vmowP0z+KUhOZdA=
|
||||||
github.com/hashicorp/go-plugin v1.0.1/go.mod h1:++UyYGoz3o5w9ZzAdZxtQKrWWP+iqPBn3cQptSMzBuY=
|
github.com/hashicorp/go-plugin v1.0.1/go.mod h1:++UyYGoz3o5w9ZzAdZxtQKrWWP+iqPBn3cQptSMzBuY=
|
||||||
github.com/hashicorp/go-retryablehttp v0.5.3/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
|
github.com/hashicorp/go-retryablehttp v0.5.3/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.2 h1:bHM2aVXwBtBJWxHtkSrWuI4umABCUczs52eiUS9nSiw=
|
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.2/go.mod h1:gEx6HMUGxYYhJScX7W1Il64m6cc2C1mDaW3NQ9sY1FY=
|
github.com/hashicorp/go-retryablehttp v0.6.2/go.mod h1:gEx6HMUGxYYhJScX7W1Il64m6cc2C1mDaW3NQ9sY1FY=
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.6 h1:HJunrbHTDDbBb/ay4kxa1n+dLmttUlnP3V9oNE4hmsM=
|
github.com/hashicorp/go-retryablehttp v0.6.6 h1:HJunrbHTDDbBb/ay4kxa1n+dLmttUlnP3V9oNE4hmsM=
|
||||||
github.com/hashicorp/go-retryablehttp v0.6.6/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
github.com/hashicorp/go-retryablehttp v0.6.6/go.mod h1:vAew36LZh98gCBJNLH42IQ1ER/9wtLZZ8meHqQvEYWY=
|
||||||
github.com/hashicorp/go-rootcerts v1.0.1 h1:DMo4fmknnz0E0evoNYnV48RjWndOsmd6OW+09R3cEP8=
|
|
||||||
github.com/hashicorp/go-rootcerts v1.0.1/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
|
github.com/hashicorp/go-rootcerts v1.0.1/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
|
||||||
github.com/hashicorp/go-rootcerts v1.0.2 h1:jzhAVGtqPKbwpyCPELlgNWhE1znq+qwJtW5Oi2viEzc=
|
github.com/hashicorp/go-rootcerts v1.0.2 h1:jzhAVGtqPKbwpyCPELlgNWhE1znq+qwJtW5Oi2viEzc=
|
||||||
github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
|
github.com/hashicorp/go-rootcerts v1.0.2/go.mod h1:pqUvnprVnM5bf7AOirdbb01K4ccR319Vf4pU3K5EGc8=
|
||||||
@ -151,18 +148,15 @@ github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
|
|||||||
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
|
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
|
||||||
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
|
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
|
||||||
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
|
||||||
github.com/mattn/go-colorable v0.1.4 h1:snbPLB8fVfU9iwbbo30TPtbLRzwWu6aJS6Xh4eaaviA=
|
|
||||||
github.com/mattn/go-colorable v0.1.4/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE=
|
github.com/mattn/go-colorable v0.1.4/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE=
|
||||||
github.com/mattn/go-colorable v0.1.6 h1:6Su7aK7lXmJ/U79bYtBjLNaha4Fs1Rg9plHpcH+vvnE=
|
github.com/mattn/go-colorable v0.1.6 h1:6Su7aK7lXmJ/U79bYtBjLNaha4Fs1Rg9plHpcH+vvnE=
|
||||||
github.com/mattn/go-colorable v0.1.6/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc=
|
github.com/mattn/go-colorable v0.1.6/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc=
|
||||||
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
|
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
|
||||||
github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s=
|
github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s=
|
||||||
github.com/mattn/go-isatty v0.0.10 h1:qxFzApOv4WsAL965uUPIsXzAKCZxN2p9UqdhFS4ZW10=
|
|
||||||
github.com/mattn/go-isatty v0.0.10/go.mod h1:qgIWMr58cqv1PHHyhnkY9lrL7etaEgOFcMEpPG5Rm84=
|
github.com/mattn/go-isatty v0.0.10/go.mod h1:qgIWMr58cqv1PHHyhnkY9lrL7etaEgOFcMEpPG5Rm84=
|
||||||
github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY=
|
github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY=
|
||||||
github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
|
github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
|
||||||
github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
|
github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
|
||||||
github.com/mitchellh/cli v1.0.0 h1:iGBIsUe3+HZ/AD/Vd7DErOt5sU9fa8Uj7A2s1aggv1Y=
|
|
||||||
github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc=
|
github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc=
|
||||||
github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw=
|
github.com/mitchellh/copystructure v1.0.0/go.mod h1:SNtv71yrdKgLRyLFxmLdkAbkKEFWgYaq1OVrnRcwhnw=
|
||||||
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
|
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
|
||||||
@ -200,7 +194,6 @@ github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINE
|
|||||||
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
|
||||||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
|
||||||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||||
github.com/posener/complete v1.1.1 h1:ccV59UEOTzVDnDUEFdT95ZzHVZ+5+158q8+SJb2QV5w=
|
|
||||||
github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI=
|
github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI=
|
||||||
github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
|
github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
|
||||||
github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo=
|
github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo=
|
||||||
@ -227,9 +220,7 @@ github.com/spf13/pflag v1.0.1-0.20171106142849-4c012f6dcd95/go.mod h1:DYY7MBk1bd
|
|||||||
github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
|
github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
|
||||||
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
|
||||||
github.com/stretchr/testify v1.2.2 h1:bSDNvY7ZPG5RlJ8otE/7V6gMiyenm9RtJ7IUVIAoJ1w=
|
|
||||||
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
|
||||||
github.com/stretchr/testify v1.3.0 h1:TivCn/peBQ7UY8ooIcPgZFpTNSz0Q2U6UrFlUfqbe0Q=
|
|
||||||
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
|
||||||
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
|
||||||
github.com/stretchr/testify v1.5.1 h1:nOGnQDM7FYENwehXlg/kFVnos3rEvtKTjRvOWSzb6H4=
|
github.com/stretchr/testify v1.5.1 h1:nOGnQDM7FYENwehXlg/kFVnos3rEvtKTjRvOWSzb6H4=
|
||||||
@ -237,9 +228,9 @@ github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5
|
|||||||
github.com/tv42/httpunix v0.0.0-20150427012821-b75d8614f926/go.mod h1:9ESjWnEqriFuLhtthL60Sar/7RFoluCcXsuvEwTV5KM=
|
github.com/tv42/httpunix v0.0.0-20150427012821-b75d8614f926/go.mod h1:9ESjWnEqriFuLhtthL60Sar/7RFoluCcXsuvEwTV5KM=
|
||||||
github.com/urfave/cli v0.0.0-20171014202726-7bc6a0acffa5/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA=
|
github.com/urfave/cli v0.0.0-20171014202726-7bc6a0acffa5/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA=
|
||||||
go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8=
|
go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8=
|
||||||
|
go.uber.org/atomic v1.6.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ=
|
||||||
golang.org/x/crypto v0.0.0-20171113213409-9f005a07e0d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
|
golang.org/x/crypto v0.0.0-20171113213409-9f005a07e0d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
|
||||||
golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
|
golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
|
||||||
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2 h1:VklqNMn3ovrHsnt90PveolxSbWFaJdECFbxSq0Mqo2M=
|
|
||||||
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
||||||
golang.org/x/crypto v0.0.0-20200604202706-70a84ac30bf9 h1:vEg9joUBmeBcK9iSJftGNf3coIG4HqZElCPehJsfAYM=
|
golang.org/x/crypto v0.0.0-20200604202706-70a84ac30bf9 h1:vEg9joUBmeBcK9iSJftGNf3coIG4HqZElCPehJsfAYM=
|
||||||
golang.org/x/crypto v0.0.0-20200604202706-70a84ac30bf9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
golang.org/x/crypto v0.0.0-20200604202706-70a84ac30bf9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
|
||||||
@ -247,6 +238,7 @@ golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL
|
|||||||
golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
|
golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
|
||||||
golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
|
golang.org/x/lint v0.0.0-20190227174305-5b3e6a55c961/go.mod h1:wehouNa3lNwaWXcvxsM5YxQ5yQlVC4a0KAMCusXpPoU=
|
||||||
golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
|
golang.org/x/lint v0.0.0-20190313153728-d0100b6bd8b3/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
|
||||||
|
golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc=
|
||||||
golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
||||||
golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
||||||
golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
|
||||||
@ -256,7 +248,7 @@ golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn
|
|||||||
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
||||||
golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
||||||
golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7 h1:fHDIZ2oxGnUZRN6WgWFCbYBjH9uqVPRCUVUDhs0wnbA=
|
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
golang.org/x/net v0.0.0-20200202094626-16171245cfb2/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
golang.org/x/net v0.0.0-20200202094626-16171245cfb2/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
@ -282,7 +274,6 @@ golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7w
|
|||||||
golang.org/x/sys v0.0.0-20190502145724-3ef323f4f1fd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20190502145724-3ef323f4f1fd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20190514135907-3a4b5fb9f71f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20190514135907-3a4b5fb9f71f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20191008105621-543471e840be h1:QAcqgptGM8IQBC9K/RC4o+O9YmqEm0diQn9QmZw/0mU=
|
|
||||||
golang.org/x/sys v0.0.0-20191008105621-543471e840be/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20191008105621-543471e840be/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
@ -290,11 +281,9 @@ golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7w
|
|||||||
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/sys v0.0.0-20200602225109-6fdc65e7d980 h1:OjiUf46hAmXblsZdnoSXsEUSKU8r1UEzcL5RVZ4gO9Y=
|
golang.org/x/sys v0.0.0-20200602225109-6fdc65e7d980 h1:OjiUf46hAmXblsZdnoSXsEUSKU8r1UEzcL5RVZ4gO9Y=
|
||||||
golang.org/x/sys v0.0.0-20200602225109-6fdc65e7d980/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20200602225109-6fdc65e7d980/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
golang.org/x/text v0.3.0 h1:g61tztE5qeGQ89tm6NTjjM9VPIm088od1l6aSorWRWg=
|
|
||||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/text v0.3.2 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs=
|
golang.org/x/text v0.3.2 h1:tW2bmiBqwgJj/UpqtC8EpXEZVYOwU0yG4iWbprSVAcs=
|
||||||
golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
|
golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk=
|
||||||
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4 h1:SvFZT6jyqRaOeXpc5h/JSfZenJ2O330aBsf7JfSUXmQ=
|
|
||||||
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1 h1:NusfzzA6yGQ+ua51ck7E3omNUX/JuqbFSaRGqU8CcLI=
|
golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1 h1:NusfzzA6yGQ+ua51ck7E3omNUX/JuqbFSaRGqU8CcLI=
|
||||||
golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
|
||||||
@ -306,6 +295,8 @@ golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3
|
|||||||
golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
|
golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
|
||||||
golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
|
golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
|
||||||
golang.org/x/tools v0.0.0-20190624222133-a101b041ded4/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
|
golang.org/x/tools v0.0.0-20190624222133-a101b041ded4/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
|
||||||
|
golang.org/x/tools v0.0.0-20191029041327-9cc4af7d6b2c/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
|
||||||
|
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4=
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4=
|
||||||
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
|
google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
|
||||||
@ -331,7 +322,7 @@ google.golang.org/protobuf v1.21.0/go.mod h1:47Nbq4nVaFHyn7ilMalzfO3qCViNmqZ2kzi
|
|||||||
google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
||||||
google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
||||||
google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU=
|
||||||
google.golang.org/protobuf v1.24.0/go.mod h1:r/3tXBNzIEhYS9I1OUVjXDlt8tc493IdKGjtUeSXeh4=
|
google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c=
|
||||||
gopkg.in/airbrake/gobrake.v2 v2.0.9/go.mod h1:/h5ZAUhDkGaJfjzjKLSjv6zCL6O0LLBxU4K+aSYdM/U=
|
gopkg.in/airbrake/gobrake.v2 v2.0.9/go.mod h1:/h5ZAUhDkGaJfjzjKLSjv6zCL6O0LLBxU4K+aSYdM/U=
|
||||||
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
|
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
|
||||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
@ -340,7 +331,6 @@ gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15 h1:YR8cESwS4TdDjEe65xsg0ogR
|
|||||||
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||||
gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
|
gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
|
||||||
gopkg.in/gemnasium/logrus-airbrake-hook.v2 v2.1.2/go.mod h1:Xk6kEKp8OKb+X14hQBKWaSkCsqBpgog8nAV2xsGOxlo=
|
gopkg.in/gemnasium/logrus-airbrake-hook.v2 v2.1.2/go.mod h1:Xk6kEKp8OKb+X14hQBKWaSkCsqBpgog8nAV2xsGOxlo=
|
||||||
gopkg.in/square/go-jose.v2 v2.3.1 h1:SK5KegNXmKmqE342YYN2qPHEnUYeoMiXXl1poUlI+o4=
|
|
||||||
gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
|
gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
|
||||||
gopkg.in/square/go-jose.v2 v2.5.1 h1:7odma5RETjNHWJnR32wx8t+Io4djHE1PqxCFx3iiZ2w=
|
gopkg.in/square/go-jose.v2 v2.5.1 h1:7odma5RETjNHWJnR32wx8t+Io4djHE1PqxCFx3iiZ2w=
|
||||||
gopkg.in/square/go-jose.v2 v2.5.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
|
gopkg.in/square/go-jose.v2 v2.5.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
|
||||||
|
106
vendor/github.com/hashicorp/vault/api/lifetime_watcher.go
generated
vendored
106
vendor/github.com/hashicorp/vault/api/lifetime_watcher.go
generated
vendored
@ -5,6 +5,8 @@ import (
|
|||||||
"math/rand"
|
"math/rand"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/cenkalti/backoff/v3"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -229,28 +231,25 @@ func (r *LifetimeWatcher) Renew() {
|
|||||||
r.Start()
|
r.Start()
|
||||||
}
|
}
|
||||||
|
|
||||||
// renewAuth is a helper for renewing authentication.
|
type renewFunc func(string, int) (*Secret, error)
|
||||||
func (r *LifetimeWatcher) doRenew() error {
|
|
||||||
var nonRenewable bool
|
|
||||||
var tokenMode bool
|
|
||||||
var initLeaseDuration int
|
|
||||||
var credString string
|
|
||||||
var renewFunc func(string, int) (*Secret, error)
|
|
||||||
|
|
||||||
|
// doRenew is a helper for renewing authentication.
|
||||||
|
func (r *LifetimeWatcher) doRenew() error {
|
||||||
|
defaultInitialRetryInterval := 10 * time.Second
|
||||||
switch {
|
switch {
|
||||||
case r.secret.Auth != nil:
|
case r.secret.Auth != nil:
|
||||||
tokenMode = true
|
return r.doRenewWithOptions(true, !r.secret.Auth.Renewable,
|
||||||
nonRenewable = !r.secret.Auth.Renewable
|
r.secret.Auth.LeaseDuration, r.secret.Auth.ClientToken,
|
||||||
initLeaseDuration = r.secret.Auth.LeaseDuration
|
r.client.Auth().Token().RenewTokenAsSelf, defaultInitialRetryInterval)
|
||||||
credString = r.secret.Auth.ClientToken
|
|
||||||
renewFunc = r.client.Auth().Token().RenewTokenAsSelf
|
|
||||||
default:
|
default:
|
||||||
nonRenewable = !r.secret.Renewable
|
return r.doRenewWithOptions(false, !r.secret.Renewable,
|
||||||
initLeaseDuration = r.secret.LeaseDuration
|
r.secret.LeaseDuration, r.secret.LeaseID,
|
||||||
credString = r.secret.LeaseID
|
r.client.Sys().Renew, defaultInitialRetryInterval)
|
||||||
renewFunc = r.client.Sys().Renew
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (r *LifetimeWatcher) doRenewWithOptions(tokenMode bool, nonRenewable bool, initLeaseDuration int, credString string,
|
||||||
|
renew renewFunc, initialRetryInterval time.Duration) error {
|
||||||
if credString == "" ||
|
if credString == "" ||
|
||||||
(nonRenewable && r.renewBehavior == RenewBehaviorErrorOnErrors) {
|
(nonRenewable && r.renewBehavior == RenewBehaviorErrorOnErrors) {
|
||||||
return r.errLifetimeWatcherNotRenewable
|
return r.errLifetimeWatcherNotRenewable
|
||||||
@ -259,6 +258,7 @@ func (r *LifetimeWatcher) doRenew() error {
|
|||||||
initialTime := time.Now()
|
initialTime := time.Now()
|
||||||
priorDuration := time.Duration(initLeaseDuration) * time.Second
|
priorDuration := time.Duration(initLeaseDuration) * time.Second
|
||||||
r.calculateGrace(priorDuration)
|
r.calculateGrace(priorDuration)
|
||||||
|
var errorBackoff backoff.BackOff
|
||||||
|
|
||||||
for {
|
for {
|
||||||
// Check if we are stopped.
|
// Check if we are stopped.
|
||||||
@ -268,18 +268,20 @@ func (r *LifetimeWatcher) doRenew() error {
|
|||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
|
|
||||||
var leaseDuration time.Duration
|
var remainingLeaseDuration time.Duration
|
||||||
fallbackLeaseDuration := initialTime.Add(priorDuration).Sub(time.Now())
|
fallbackLeaseDuration := initialTime.Add(priorDuration).Sub(time.Now())
|
||||||
|
var renewal *Secret
|
||||||
|
var err error
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
case nonRenewable || r.renewBehavior == RenewBehaviorRenewDisabled:
|
case nonRenewable || r.renewBehavior == RenewBehaviorRenewDisabled:
|
||||||
// Can't or won't renew, just keep the same expiration so we exit
|
// Can't or won't renew, just keep the same expiration so we exit
|
||||||
// when it's reauthentication time
|
// when it's reauthentication time
|
||||||
leaseDuration = fallbackLeaseDuration
|
remainingLeaseDuration = fallbackLeaseDuration
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// Renew the token
|
// Renew the token
|
||||||
renewal, err := renewFunc(credString, r.increment)
|
renewal, err = renew(credString, r.increment)
|
||||||
if err != nil || renewal == nil || (tokenMode && renewal.Auth == nil) {
|
if err != nil || renewal == nil || (tokenMode && renewal.Auth == nil) {
|
||||||
if r.renewBehavior == RenewBehaviorErrorOnErrors {
|
if r.renewBehavior == RenewBehaviorErrorOnErrors {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -290,9 +292,22 @@ func (r *LifetimeWatcher) doRenew() error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
leaseDuration = fallbackLeaseDuration
|
// Calculate remaining duration until initial token lease expires
|
||||||
|
remainingLeaseDuration = initialTime.Add(time.Duration(initLeaseDuration) * time.Second).Sub(time.Now())
|
||||||
|
if errorBackoff == nil {
|
||||||
|
errorBackoff = &backoff.ExponentialBackOff{
|
||||||
|
MaxElapsedTime: remainingLeaseDuration,
|
||||||
|
RandomizationFactor: backoff.DefaultRandomizationFactor,
|
||||||
|
InitialInterval: initialRetryInterval,
|
||||||
|
MaxInterval: 5 * time.Minute,
|
||||||
|
Multiplier: 2,
|
||||||
|
Clock: backoff.SystemClock,
|
||||||
|
}
|
||||||
|
errorBackoff.Reset()
|
||||||
|
}
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
errorBackoff = nil
|
||||||
|
|
||||||
// Push a message that a renewal took place.
|
// Push a message that a renewal took place.
|
||||||
select {
|
select {
|
||||||
@ -306,26 +321,38 @@ func (r *LifetimeWatcher) doRenew() error {
|
|||||||
return r.errLifetimeWatcherNotRenewable
|
return r.errLifetimeWatcherNotRenewable
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Reset initial time
|
||||||
|
initialTime = time.Now()
|
||||||
|
|
||||||
// Grab the lease duration
|
// Grab the lease duration
|
||||||
newDuration := renewal.LeaseDuration
|
initLeaseDuration = renewal.LeaseDuration
|
||||||
if tokenMode {
|
if tokenMode {
|
||||||
newDuration = renewal.Auth.LeaseDuration
|
initLeaseDuration = renewal.Auth.LeaseDuration
|
||||||
}
|
}
|
||||||
|
|
||||||
leaseDuration = time.Duration(newDuration) * time.Second
|
remainingLeaseDuration = time.Duration(initLeaseDuration) * time.Second
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var sleepDuration time.Duration
|
||||||
|
|
||||||
|
if errorBackoff != nil {
|
||||||
|
sleepDuration = errorBackoff.NextBackOff()
|
||||||
|
if sleepDuration == backoff.Stop {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
// We keep evaluating a new grace period so long as the lease is
|
// We keep evaluating a new grace period so long as the lease is
|
||||||
// extending. Once it stops extending, we've hit the max and need to
|
// extending. Once it stops extending, we've hit the max and need to
|
||||||
// rely on the grace duration.
|
// rely on the grace duration.
|
||||||
if leaseDuration > priorDuration {
|
if remainingLeaseDuration > priorDuration {
|
||||||
r.calculateGrace(leaseDuration)
|
r.calculateGrace(remainingLeaseDuration)
|
||||||
}
|
}
|
||||||
priorDuration = leaseDuration
|
priorDuration = remainingLeaseDuration
|
||||||
|
|
||||||
// The sleep duration is set to 2/3 of the current lease duration plus
|
// The sleep duration is set to 2/3 of the current lease duration plus
|
||||||
// 1/3 of the current grace period, which adds jitter.
|
// 1/3 of the current grace period, which adds jitter.
|
||||||
sleepDuration := time.Duration(float64(leaseDuration.Nanoseconds())*2/3 + float64(r.grace.Nanoseconds())/3)
|
sleepDuration = time.Duration(float64(remainingLeaseDuration.Nanoseconds())*2/3 + float64(r.grace.Nanoseconds())/3)
|
||||||
|
}
|
||||||
|
|
||||||
// If we are within grace, return now; or, if the amount of time we
|
// If we are within grace, return now; or, if the amount of time we
|
||||||
// would sleep would land us in the grace period. This helps with short
|
// would sleep would land us in the grace period. This helps with short
|
||||||
@ -333,7 +360,7 @@ func (r *LifetimeWatcher) doRenew() error {
|
|||||||
// seconds, a grace period of 3 seconds, and end up sleeping for more
|
// seconds, a grace period of 3 seconds, and end up sleeping for more
|
||||||
// than three of those seconds and having a very small budget of time
|
// than three of those seconds and having a very small budget of time
|
||||||
// to renew.
|
// to renew.
|
||||||
if leaseDuration <= r.grace || leaseDuration-sleepDuration <= r.grace {
|
if remainingLeaseDuration <= r.grace || remainingLeaseDuration-sleepDuration <= r.grace {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -346,23 +373,6 @@ func (r *LifetimeWatcher) doRenew() error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// sleepDuration calculates the time to sleep given the base lease duration. The
|
|
||||||
// base is the resulting lease duration. It will be reduced to 1/3 and
|
|
||||||
// multiplied by a random float between 0.0 and 1.0. This extra randomness
|
|
||||||
// prevents multiple clients from all trying to renew simultaneously.
|
|
||||||
func (r *LifetimeWatcher) sleepDuration(base time.Duration) time.Duration {
|
|
||||||
sleep := float64(base)
|
|
||||||
|
|
||||||
// Renew at 1/3 the remaining lease. This will give us an opportunity to retry
|
|
||||||
// at least one more time should the first renewal fail.
|
|
||||||
sleep = sleep / 3.0
|
|
||||||
|
|
||||||
// Use a randomness so many clients do not hit Vault simultaneously.
|
|
||||||
sleep = sleep * (r.random.Float64() + 1) / 2.0
|
|
||||||
|
|
||||||
return time.Duration(sleep)
|
|
||||||
}
|
|
||||||
|
|
||||||
// calculateGrace calculates the grace period based on a reasonable set of
|
// calculateGrace calculates the grace period based on a reasonable set of
|
||||||
// assumptions given the total lease time; it also adds some jitter to not have
|
// assumptions given the total lease time; it also adds some jitter to not have
|
||||||
// clients be in sync.
|
// clients be in sync.
|
||||||
@ -380,5 +390,7 @@ func (r *LifetimeWatcher) calculateGrace(leaseDuration time.Duration) {
|
|||||||
r.grace = time.Duration(jitterMax) + time.Duration(uint64(r.random.Int63())%uint64(jitterMax))
|
r.grace = time.Duration(jitterMax) + time.Duration(uint64(r.random.Int63())%uint64(jitterMax))
|
||||||
}
|
}
|
||||||
|
|
||||||
type Renewer = LifetimeWatcher
|
type (
|
||||||
type RenewerInput = LifetimeWatcherInput
|
Renewer = LifetimeWatcher
|
||||||
|
RenewerInput = LifetimeWatcherInput
|
||||||
|
)
|
||||||
|
8
vendor/github.com/hashicorp/vault/api/output_string.go
generated
vendored
8
vendor/github.com/hashicorp/vault/api/output_string.go
generated
vendored
@ -11,12 +11,11 @@ const (
|
|||||||
ErrOutputStringRequest = "output a string, please"
|
ErrOutputStringRequest = "output a string, please"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var LastOutputStringError *OutputStringError
|
||||||
LastOutputStringError *OutputStringError
|
|
||||||
)
|
|
||||||
|
|
||||||
type OutputStringError struct {
|
type OutputStringError struct {
|
||||||
*retryablehttp.Request
|
*retryablehttp.Request
|
||||||
|
TLSSkipVerify bool
|
||||||
parsingError error
|
parsingError error
|
||||||
parsedCurlString string
|
parsedCurlString string
|
||||||
}
|
}
|
||||||
@ -41,6 +40,9 @@ func (d *OutputStringError) parseRequest() {
|
|||||||
|
|
||||||
// Build cURL string
|
// Build cURL string
|
||||||
d.parsedCurlString = "curl "
|
d.parsedCurlString = "curl "
|
||||||
|
if d.TLSSkipVerify {
|
||||||
|
d.parsedCurlString += "--insecure "
|
||||||
|
}
|
||||||
if d.Request.Method != "GET" {
|
if d.Request.Method != "GET" {
|
||||||
d.parsedCurlString = fmt.Sprintf("%s-X %s ", d.parsedCurlString, d.Request.Method)
|
d.parsedCurlString = fmt.Sprintf("%s-X %s ", d.parsedCurlString, d.Request.Method)
|
||||||
}
|
}
|
||||||
|
2
vendor/github.com/hashicorp/vault/api/plugin_helpers.go
generated
vendored
2
vendor/github.com/hashicorp/vault/api/plugin_helpers.go
generated
vendored
@ -82,7 +82,7 @@ func VaultPluginTLSProvider(apiTLSConfig *TLSConfig) func() (*tls.Config, error)
|
|||||||
return nil, errwrap.Wrapf("error parsing wrapping token: {{err}}", err)
|
return nil, errwrap.Wrapf("error parsing wrapping token: {{err}}", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
var allClaims = make(map[string]interface{})
|
allClaims := make(map[string]interface{})
|
||||||
if err = parsedJWT.UnsafeClaimsWithoutVerification(&allClaims); err != nil {
|
if err = parsedJWT.UnsafeClaimsWithoutVerification(&allClaims); err != nil {
|
||||||
return nil, errwrap.Wrapf("error parsing claims from wrapping token: {{err}}", err)
|
return nil, errwrap.Wrapf("error parsing claims from wrapping token: {{err}}", err)
|
||||||
}
|
}
|
||||||
|
2
vendor/github.com/hashicorp/vault/api/sys_audit.go
generated
vendored
2
vendor/github.com/hashicorp/vault/api/sys_audit.go
generated
vendored
@ -52,7 +52,6 @@ func (c *Sys) ListAudit() (map[string]*Audit, error) {
|
|||||||
ctx, cancelFunc := context.WithCancel(context.Background())
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
defer cancelFunc()
|
defer cancelFunc()
|
||||||
resp, err := c.c.RawRequestWithContext(ctx, r)
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -94,7 +93,6 @@ func (c *Sys) EnableAuditWithOptions(path string, options *EnableAuditOptions) e
|
|||||||
ctx, cancelFunc := context.WithCancel(context.Background())
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
defer cancelFunc()
|
defer cancelFunc()
|
||||||
resp, err := c.c.RawRequestWithContext(ctx, r)
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
10
vendor/github.com/hashicorp/vault/api/sys_auth.go
generated
vendored
10
vendor/github.com/hashicorp/vault/api/sys_auth.go
generated
vendored
@ -74,7 +74,9 @@ func (c *Sys) DisableAuth(path string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Rather than duplicate, we can use modern Go's type aliasing
|
// Rather than duplicate, we can use modern Go's type aliasing
|
||||||
type EnableAuthOptions = MountInput
|
type (
|
||||||
type AuthConfigInput = MountConfigInput
|
EnableAuthOptions = MountInput
|
||||||
type AuthMount = MountOutput
|
AuthConfigInput = MountConfigInput
|
||||||
type AuthConfigOutput = MountConfigOutput
|
AuthMount = MountOutput
|
||||||
|
AuthConfigOutput = MountConfigOutput
|
||||||
|
)
|
||||||
|
52
vendor/github.com/hashicorp/vault/api/sys_config_cors.go
generated
vendored
52
vendor/github.com/hashicorp/vault/api/sys_config_cors.go
generated
vendored
@ -35,71 +35,41 @@ func (c *Sys) CORSStatus() (*CORSResponse, error) {
|
|||||||
return &result, err
|
return &result, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Sys) ConfigureCORS(req *CORSRequest) (*CORSResponse, error) {
|
func (c *Sys) ConfigureCORS(req *CORSRequest) error {
|
||||||
r := c.c.NewRequest("PUT", "/v1/sys/config/cors")
|
r := c.c.NewRequest("PUT", "/v1/sys/config/cors")
|
||||||
if err := r.SetJSONBody(req); err != nil {
|
if err := r.SetJSONBody(req); err != nil {
|
||||||
return nil, err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx, cancelFunc := context.WithCancel(context.Background())
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
defer cancelFunc()
|
defer cancelFunc()
|
||||||
resp, err := c.c.RawRequestWithContext(ctx, r)
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
if err != nil {
|
if err == nil {
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
|
|
||||||
secret, err := ParseSecret(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
if secret == nil || secret.Data == nil {
|
return err
|
||||||
return nil, errors.New("data from server response is empty")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var result CORSResponse
|
func (c *Sys) DisableCORS() error {
|
||||||
err = mapstructure.Decode(secret.Data, &result)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return &result, err
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *Sys) DisableCORS() (*CORSResponse, error) {
|
|
||||||
r := c.c.NewRequest("DELETE", "/v1/sys/config/cors")
|
r := c.c.NewRequest("DELETE", "/v1/sys/config/cors")
|
||||||
|
|
||||||
ctx, cancelFunc := context.WithCancel(context.Background())
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
defer cancelFunc()
|
defer cancelFunc()
|
||||||
resp, err := c.c.RawRequestWithContext(ctx, r)
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
if err != nil {
|
if err == nil {
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
defer resp.Body.Close()
|
||||||
|
|
||||||
secret, err := ParseSecret(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
if secret == nil || secret.Data == nil {
|
return err
|
||||||
return nil, errors.New("data from server response is empty")
|
|
||||||
}
|
|
||||||
|
|
||||||
var result CORSResponse
|
|
||||||
err = mapstructure.Decode(secret.Data, &result)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return &result, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type CORSRequest struct {
|
type CORSRequest struct {
|
||||||
AllowedOrigins string `json:"allowed_origins" mapstructure:"allowed_origins"`
|
AllowedOrigins []string `json:"allowed_origins" mapstructure:"allowed_origins"`
|
||||||
|
AllowedHeaders []string `json:"allowed_headers" mapstructure:"allowed_headers"`
|
||||||
Enabled bool `json:"enabled" mapstructure:"enabled"`
|
Enabled bool `json:"enabled" mapstructure:"enabled"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type CORSResponse struct {
|
type CORSResponse struct {
|
||||||
AllowedOrigins string `json:"allowed_origins" mapstructure:"allowed_origins"`
|
AllowedOrigins []string `json:"allowed_origins" mapstructure:"allowed_origins"`
|
||||||
|
AllowedHeaders []string `json:"allowed_headers" mapstructure:"allowed_headers"`
|
||||||
Enabled bool `json:"enabled" mapstructure:"enabled"`
|
Enabled bool `json:"enabled" mapstructure:"enabled"`
|
||||||
}
|
}
|
||||||
|
6
vendor/github.com/hashicorp/vault/api/sys_leader.go
generated
vendored
6
vendor/github.com/hashicorp/vault/api/sys_leader.go
generated
vendored
@ -1,6 +1,9 @@
|
|||||||
package api
|
package api
|
||||||
|
|
||||||
import "context"
|
import (
|
||||||
|
"context"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
func (c *Sys) Leader() (*LeaderResponse, error) {
|
func (c *Sys) Leader() (*LeaderResponse, error) {
|
||||||
r := c.c.NewRequest("GET", "/v1/sys/leader")
|
r := c.c.NewRequest("GET", "/v1/sys/leader")
|
||||||
@ -21,6 +24,7 @@ func (c *Sys) Leader() (*LeaderResponse, error) {
|
|||||||
type LeaderResponse struct {
|
type LeaderResponse struct {
|
||||||
HAEnabled bool `json:"ha_enabled"`
|
HAEnabled bool `json:"ha_enabled"`
|
||||||
IsSelf bool `json:"is_self"`
|
IsSelf bool `json:"is_self"`
|
||||||
|
ActiveTime time.Time `json:"active_time"`
|
||||||
LeaderAddress string `json:"leader_address"`
|
LeaderAddress string `json:"leader_address"`
|
||||||
LeaderClusterAddress string `json:"leader_cluster_address"`
|
LeaderClusterAddress string `json:"leader_cluster_address"`
|
||||||
PerfStandby bool `json:"performance_standby"`
|
PerfStandby bool `json:"performance_standby"`
|
||||||
|
21
vendor/github.com/hashicorp/vault/api/sys_leases.go
generated
vendored
21
vendor/github.com/hashicorp/vault/api/sys_leases.go
generated
vendored
@ -27,6 +27,27 @@ func (c *Sys) Renew(id string, increment int) (*Secret, error) {
|
|||||||
return ParseSecret(resp.Body)
|
return ParseSecret(resp.Body)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *Sys) Lookup(id string) (*Secret, error) {
|
||||||
|
r := c.c.NewRequest("PUT", "/v1/sys/leases/lookup")
|
||||||
|
|
||||||
|
body := map[string]interface{}{
|
||||||
|
"lease_id": id,
|
||||||
|
}
|
||||||
|
if err := r.SetJSONBody(body); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
|
defer cancelFunc()
|
||||||
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
|
||||||
|
return ParseSecret(resp.Body)
|
||||||
|
}
|
||||||
|
|
||||||
func (c *Sys) Revoke(id string) error {
|
func (c *Sys) Revoke(id string) error {
|
||||||
r := c.c.NewRequest("PUT", "/v1/sys/leases/revoke")
|
r := c.c.NewRequest("PUT", "/v1/sys/leases/revoke")
|
||||||
body := map[string]interface{}{
|
body := map[string]interface{}{
|
||||||
|
2
vendor/github.com/hashicorp/vault/api/sys_plugins.go
generated
vendored
2
vendor/github.com/hashicorp/vault/api/sys_plugins.go
generated
vendored
@ -109,7 +109,6 @@ func (c *Sys) ListPlugins(i *ListPluginsInput) (*ListPluginsResponse, error) {
|
|||||||
for i, nameIfc := range pluginsIfc {
|
for i, nameIfc := range pluginsIfc {
|
||||||
name, ok := nameIfc.(string)
|
name, ok := nameIfc.(string)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
|
||||||
}
|
}
|
||||||
plugins[i] = name
|
plugins[i] = name
|
||||||
}
|
}
|
||||||
@ -323,7 +322,6 @@ func (c *Sys) ReloadPluginStatus(reloadStatusInput *ReloadPluginStatusInput) (*R
|
|||||||
return &r, nil
|
return &r, nil
|
||||||
}
|
}
|
||||||
return nil, nil
|
return nil, nil
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// catalogPathByType is a helper to construct the proper API path by plugin type
|
// catalogPathByType is a helper to construct the proper API path by plugin type
|
||||||
|
158
vendor/github.com/hashicorp/vault/api/sys_raft.go
generated
vendored
158
vendor/github.com/hashicorp/vault/api/sys_raft.go
generated
vendored
@ -2,9 +2,16 @@ package api
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/hashicorp/vault/sdk/helper/parseutil"
|
||||||
|
|
||||||
|
"github.com/mitchellh/mapstructure"
|
||||||
|
|
||||||
"github.com/hashicorp/vault/sdk/helper/consts"
|
"github.com/hashicorp/vault/sdk/helper/consts"
|
||||||
)
|
)
|
||||||
@ -16,6 +23,9 @@ type RaftJoinResponse struct {
|
|||||||
|
|
||||||
// RaftJoinRequest represents the parameters consumed by the raft join API
|
// RaftJoinRequest represents the parameters consumed by the raft join API
|
||||||
type RaftJoinRequest struct {
|
type RaftJoinRequest struct {
|
||||||
|
AutoJoin string `json:"auto_join"`
|
||||||
|
AutoJoinScheme string `json:"auto_join_scheme"`
|
||||||
|
AutoJoinPort uint `json:"auto_join_port"`
|
||||||
LeaderAPIAddr string `json:"leader_api_addr"`
|
LeaderAPIAddr string `json:"leader_api_addr"`
|
||||||
LeaderCACert string `json:"leader_ca_cert"`
|
LeaderCACert string `json:"leader_ca_cert"`
|
||||||
LeaderClientCert string `json:"leader_client_cert"`
|
LeaderClientCert string `json:"leader_client_cert"`
|
||||||
@ -24,6 +34,78 @@ type RaftJoinRequest struct {
|
|||||||
NonVoter bool `json:"non_voter"`
|
NonVoter bool `json:"non_voter"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// AutopilotConfig is used for querying/setting the Autopilot configuration.
|
||||||
|
type AutopilotConfig struct {
|
||||||
|
CleanupDeadServers bool `json:"cleanup_dead_servers" mapstructure:"cleanup_dead_servers"`
|
||||||
|
LastContactThreshold time.Duration `json:"last_contact_threshold" mapstructure:"-"`
|
||||||
|
DeadServerLastContactThreshold time.Duration `json:"dead_server_last_contact_threshold" mapstructure:"-"`
|
||||||
|
MaxTrailingLogs uint64 `json:"max_trailing_logs" mapstructure:"max_trailing_logs"`
|
||||||
|
MinQuorum uint `json:"min_quorum" mapstructure:"min_quorum"`
|
||||||
|
ServerStabilizationTime time.Duration `json:"server_stabilization_time" mapstructure:"-"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// MarshalJSON makes the autopilot config fields JSON compatible
|
||||||
|
func (ac *AutopilotConfig) MarshalJSON() ([]byte, error) {
|
||||||
|
return json.Marshal(map[string]interface{}{
|
||||||
|
"cleanup_dead_servers": ac.CleanupDeadServers,
|
||||||
|
"last_contact_threshold": ac.LastContactThreshold.String(),
|
||||||
|
"dead_server_last_contact_threshold": ac.DeadServerLastContactThreshold.String(),
|
||||||
|
"max_trailing_logs": ac.MaxTrailingLogs,
|
||||||
|
"min_quorum": ac.MinQuorum,
|
||||||
|
"server_stabilization_time": ac.ServerStabilizationTime.String(),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// UnmarshalJSON parses the autopilot config JSON blob
|
||||||
|
func (ac *AutopilotConfig) UnmarshalJSON(b []byte) error {
|
||||||
|
var data interface{}
|
||||||
|
err := json.Unmarshal(b, &data)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
conf := data.(map[string]interface{})
|
||||||
|
if err = mapstructure.WeakDecode(conf, ac); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if ac.LastContactThreshold, err = parseutil.ParseDurationSecond(conf["last_contact_threshold"]); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if ac.DeadServerLastContactThreshold, err = parseutil.ParseDurationSecond(conf["dead_server_last_contact_threshold"]); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if ac.ServerStabilizationTime, err = parseutil.ParseDurationSecond(conf["server_stabilization_time"]); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// AutopilotState represents the response of the raft autopilot state API
|
||||||
|
type AutopilotState struct {
|
||||||
|
Healthy bool `mapstructure:"healthy"`
|
||||||
|
FailureTolerance int `mapstructure:"failure_tolerance"`
|
||||||
|
Servers map[string]*AutopilotServer `mapstructure:"servers"`
|
||||||
|
Leader string `mapstructure:"leader"`
|
||||||
|
Voters []string `mapstructure:"voters"`
|
||||||
|
NonVoters []string `mapstructure:"non_voters"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// AutopilotServer represents the server blocks in the response of the raft
|
||||||
|
// autopilot state API.
|
||||||
|
type AutopilotServer struct {
|
||||||
|
ID string `mapstructure:"id"`
|
||||||
|
Name string `mapstructure:"name"`
|
||||||
|
Address string `mapstructure:"address"`
|
||||||
|
NodeStatus string `mapstructure:"node_status"`
|
||||||
|
LastContact string `mapstructure:"last_contact"`
|
||||||
|
LastTerm uint64 `mapstructure:"last_term"`
|
||||||
|
LastIndex uint64 `mapstructure:"last_index"`
|
||||||
|
Healthy bool `mapstructure:"healthy"`
|
||||||
|
StableSince string `mapstructure:"stable_since"`
|
||||||
|
Status string `mapstructure:"status"`
|
||||||
|
Meta map[string]string `mapstructure:"meta"`
|
||||||
|
}
|
||||||
|
|
||||||
// RaftJoin adds the node from which this call is invoked from to the raft
|
// RaftJoin adds the node from which this call is invoked from to the raft
|
||||||
// cluster represented by the leader address in the parameter.
|
// cluster represented by the leader address in the parameter.
|
||||||
func (c *Sys) RaftJoin(opts *RaftJoinRequest) (*RaftJoinResponse, error) {
|
func (c *Sys) RaftJoin(opts *RaftJoinRequest) (*RaftJoinResponse, error) {
|
||||||
@ -157,3 +239,79 @@ func (c *Sys) RaftSnapshotRestore(snapReader io.Reader, force bool) error {
|
|||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// RaftAutopilotState returns the state of the raft cluster as seen by autopilot.
|
||||||
|
func (c *Sys) RaftAutopilotState() (*AutopilotState, error) {
|
||||||
|
r := c.c.NewRequest("GET", "/v1/sys/storage/raft/autopilot/state")
|
||||||
|
|
||||||
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
|
defer cancelFunc()
|
||||||
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
|
if resp != nil {
|
||||||
|
defer resp.Body.Close()
|
||||||
|
if resp.StatusCode == 404 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
secret, err := ParseSecret(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if secret == nil || secret.Data == nil {
|
||||||
|
return nil, errors.New("data from server response is empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
var result AutopilotState
|
||||||
|
err = mapstructure.Decode(secret.Data, &result)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &result, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// RaftAutopilotConfiguration fetches the autopilot config.
|
||||||
|
func (c *Sys) RaftAutopilotConfiguration() (*AutopilotConfig, error) {
|
||||||
|
r := c.c.NewRequest("GET", "/v1/sys/storage/raft/autopilot/configuration")
|
||||||
|
|
||||||
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
||||||
|
defer cancelFunc()
|
||||||
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
||||||
|
if resp != nil {
|
||||||
|
defer resp.Body.Close()
|
||||||
|
if resp.StatusCode == 404 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
secret, err := ParseSecret(resp.Body)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if secret == nil {
|
||||||
|
return nil, errors.New("data from server response is empty")
|
||||||
|
}
|
||||||
|
|
||||||
|
var result AutopilotConfig
|
||||||
|
if err = mapstructure.Decode(secret.Data, &result); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if result.LastContactThreshold, err = parseutil.ParseDurationSecond(secret.Data["last_contact_threshold"]); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if result.DeadServerLastContactThreshold, err = parseutil.ParseDurationSecond(secret.Data["dead_server_last_contact_threshold"]); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if result.ServerStabilizationTime, err = parseutil.ParseDurationSecond(secret.Data["server_stabilization_time"]); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return &result, err
|
||||||
|
}
|
||||||
|
14
vendor/github.com/hashicorp/vault/api/sys_rotate.go
generated
vendored
14
vendor/github.com/hashicorp/vault/api/sys_rotate.go
generated
vendored
@ -68,10 +68,24 @@ func (c *Sys) KeyStatus() (*KeyStatus, error) {
|
|||||||
}
|
}
|
||||||
result.InstallTime = installTime
|
result.InstallTime = installTime
|
||||||
|
|
||||||
|
encryptionsRaw, ok := secret.Data["encryptions"]
|
||||||
|
if ok {
|
||||||
|
encryptions, ok := encryptionsRaw.(json.Number)
|
||||||
|
if !ok {
|
||||||
|
return nil, errors.New("could not convert encryptions to a number")
|
||||||
|
}
|
||||||
|
encryptions64, err := encryptions.Int64()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
result.Encryptions = int(encryptions64)
|
||||||
|
}
|
||||||
|
|
||||||
return &result, err
|
return &result, err
|
||||||
}
|
}
|
||||||
|
|
||||||
type KeyStatus struct {
|
type KeyStatus struct {
|
||||||
Term int `json:"term"`
|
Term int `json:"term"`
|
||||||
InstallTime time.Time `json:"install_time"`
|
InstallTime time.Time `json:"install_time"`
|
||||||
|
Encryptions int `json:"encryptions"`
|
||||||
}
|
}
|
||||||
|
11
vendor/modules.txt
vendored
11
vendor/modules.txt
vendored
@ -47,6 +47,8 @@ github.com/aws/aws-sdk-go/service/sts/stsiface
|
|||||||
github.com/beorn7/perks/quantile
|
github.com/beorn7/perks/quantile
|
||||||
# github.com/blang/semver v3.5.1+incompatible
|
# github.com/blang/semver v3.5.1+incompatible
|
||||||
github.com/blang/semver
|
github.com/blang/semver
|
||||||
|
# github.com/cenkalti/backoff/v3 v3.0.0
|
||||||
|
github.com/cenkalti/backoff/v3
|
||||||
# github.com/ceph/go-ceph v0.11.0
|
# github.com/ceph/go-ceph v0.11.0
|
||||||
## explicit
|
## explicit
|
||||||
github.com/ceph/go-ceph/cephfs/admin
|
github.com/ceph/go-ceph/cephfs/admin
|
||||||
@ -135,7 +137,7 @@ github.com/grpc-ecosystem/grpc-gateway/utilities
|
|||||||
github.com/hashicorp/errwrap
|
github.com/hashicorp/errwrap
|
||||||
# github.com/hashicorp/go-cleanhttp v0.5.1
|
# github.com/hashicorp/go-cleanhttp v0.5.1
|
||||||
github.com/hashicorp/go-cleanhttp
|
github.com/hashicorp/go-cleanhttp
|
||||||
# github.com/hashicorp/go-hclog v0.14.1
|
# github.com/hashicorp/go-hclog v0.16.1
|
||||||
github.com/hashicorp/go-hclog
|
github.com/hashicorp/go-hclog
|
||||||
# github.com/hashicorp/go-multierror v1.1.0
|
# github.com/hashicorp/go-multierror v1.1.0
|
||||||
github.com/hashicorp/go-multierror
|
github.com/hashicorp/go-multierror
|
||||||
@ -160,10 +162,10 @@ github.com/hashicorp/hcl/json/token
|
|||||||
# github.com/hashicorp/vault v1.4.2
|
# github.com/hashicorp/vault v1.4.2
|
||||||
github.com/hashicorp/vault/command/agent/auth
|
github.com/hashicorp/vault/command/agent/auth
|
||||||
github.com/hashicorp/vault/command/agent/auth/kubernetes
|
github.com/hashicorp/vault/command/agent/auth/kubernetes
|
||||||
# github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a => github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a
|
# github.com/hashicorp/vault/api v1.1.1
|
||||||
## explicit
|
## explicit
|
||||||
github.com/hashicorp/vault/api
|
github.com/hashicorp/vault/api
|
||||||
# github.com/hashicorp/vault/sdk v0.1.14-0.20200519221838-e0cfd64bc267 => github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b
|
# github.com/hashicorp/vault/sdk v0.2.1 => github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b
|
||||||
github.com/hashicorp/vault/sdk/helper/compressutil
|
github.com/hashicorp/vault/sdk/helper/compressutil
|
||||||
github.com/hashicorp/vault/sdk/helper/consts
|
github.com/hashicorp/vault/sdk/helper/consts
|
||||||
github.com/hashicorp/vault/sdk/helper/hclutil
|
github.com/hashicorp/vault/sdk/helper/hclutil
|
||||||
@ -190,7 +192,7 @@ github.com/kubernetes-csi/external-snapshotter/client/v4/apis/volumesnapshot/v1
|
|||||||
github.com/kubernetes-csi/external-snapshotter/client/v4/apis/volumesnapshot/v1beta1
|
github.com/kubernetes-csi/external-snapshotter/client/v4/apis/volumesnapshot/v1beta1
|
||||||
github.com/kubernetes-csi/external-snapshotter/client/v4/clientset/versioned/scheme
|
github.com/kubernetes-csi/external-snapshotter/client/v4/clientset/versioned/scheme
|
||||||
github.com/kubernetes-csi/external-snapshotter/client/v4/clientset/versioned/typed/volumesnapshot/v1
|
github.com/kubernetes-csi/external-snapshotter/client/v4/clientset/versioned/typed/volumesnapshot/v1
|
||||||
# github.com/libopenstorage/secrets v0.0.0-20210709082113-dde442ea20ec
|
# github.com/libopenstorage/secrets v0.0.0-20210908194121-a1d19aa9713a
|
||||||
## explicit
|
## explicit
|
||||||
github.com/libopenstorage/secrets
|
github.com/libopenstorage/secrets
|
||||||
github.com/libopenstorage/secrets/vault
|
github.com/libopenstorage/secrets/vault
|
||||||
@ -1056,7 +1058,6 @@ sigs.k8s.io/structured-merge-diff/v4/value
|
|||||||
sigs.k8s.io/yaml
|
sigs.k8s.io/yaml
|
||||||
# code.cloudfoundry.org/gofileutils => github.com/cloudfoundry/gofileutils v0.0.0-20170111115228-4d0c80011a0f
|
# code.cloudfoundry.org/gofileutils => github.com/cloudfoundry/gofileutils v0.0.0-20170111115228-4d0c80011a0f
|
||||||
# github.com/golang/protobuf => github.com/golang/protobuf v1.4.3
|
# github.com/golang/protobuf => github.com/golang/protobuf v1.4.3
|
||||||
# github.com/hashicorp/vault/api => github.com/hashicorp/vault/api v1.0.5-0.20200902155336-f9d5ce5a171a
|
|
||||||
# github.com/hashicorp/vault/sdk => github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b
|
# github.com/hashicorp/vault/sdk => github.com/hashicorp/vault/sdk v0.1.14-0.20201116234512-b4d4137dfe8b
|
||||||
# github.com/portworx/sched-ops => github.com/portworx/sched-ops v0.20.4-openstorage-rc3
|
# github.com/portworx/sched-ops => github.com/portworx/sched-ops v0.20.4-openstorage-rc3
|
||||||
# gomodules.xyz/jsonpatch/v2 => github.com/gomodules/jsonpatch/v2 v2.2.0
|
# gomodules.xyz/jsonpatch/v2 => github.com/gomodules/jsonpatch/v2 v2.2.0
|
||||||
|
Loading…
Reference in New Issue
Block a user