From 707c5c6a0226343723a8188d9c88b141cad424d9 Mon Sep 17 00:00:00 2001 From: Panchajanya Mysarla Date: Mon, 11 Sep 2023 14:19:22 -0500 Subject: [PATCH 1/4] Update go version to 1.21 --- go.mod | 4 +- go.sum | 58 +++++++++++- go.work | 2 +- go.work.sum | 195 +++++++++++++++++++++++++++++++++++++- test/e2e/framework/go.mod | 2 +- 5 files changed, 254 insertions(+), 7 deletions(-) diff --git a/go.mod b/go.mod index e4799e902..f4b57f89e 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/vmware-tanzu/tanzu-cli -go 1.19 +go 1.21 replace cloud.google.com/go => cloud.google.com/go v0.102.1 @@ -41,7 +41,7 @@ require ( github.com/vmware-tanzu/carvel-ytt v0.40.0 github.com/vmware-tanzu/tanzu-cli/test/e2e/framework v0.0.0-00010101000000-000000000000 github.com/vmware-tanzu/tanzu-framework/capabilities/client v0.0.0-20230523145612-1c6fbba34686 - github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.0 + github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.1 go.pinniped.dev v0.20.0 golang.org/x/mod v0.10.0 golang.org/x/oauth2 v0.8.0 diff --git a/go.sum b/go.sum index 82cd1e4e0..efa71a5ef 100644 --- a/go.sum +++ b/go.sum @@ -13,11 +13,15 @@ cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2Aawl cloud.google.com/go/datastore v1.0.0/go.mod h1:LXYbyblFSglQ5pkeyhO+Qmw7ukd3C+pD7TKLgZqpHYE= cloud.google.com/go/iam v0.3.0/go.mod h1:XzJPvDayI+9zsASAFO68Hk07u3z+f+JrT2xXNdp4bnY= cloud.google.com/go/iam v0.13.0 h1:+CmB+K0J/33d0zSQ9SlFWUeCCEn5XJA0ZMZ3pHE9u8k= +cloud.google.com/go/iam v0.13.0/go.mod h1:ljOg+rcNfzZ5d6f1nAUJ8ZIxOaZUVoS14bKCtaLZ/D0= cloud.google.com/go/kms v1.10.2 h1:8UePKEypK3SQ6g+4mn/s/VgE5L7XOh+FwGGRUqvY3Hw= +cloud.google.com/go/kms v1.10.2/go.mod h1:9mX3Q6pdroWzL20pbK6RaOdBbXBEhMNgK4Pfz2bweb4= cloud.google.com/go/storage v1.14.0/go.mod h1:GrKmX003DSIwi9o29oFT7YDnHYwZoctc3fOKtUw0Xmo= cloud.google.com/go/storage v1.22.1/go.mod h1:S8N1cAStu7BOeFfE8KAQzmyyLkK8p/vmRq6kuBTW58Y= filippo.io/edwards25519 v1.0.0 h1:0wAIcmJUqRdI8IJ/3eGi5/HwXZWPujYXXlkrQogz0Ek= +filippo.io/edwards25519 v1.0.0/go.mod h1:N1IkdkCkiLB6tki+MYJoSx2JTY9NUlxZE7eHn5EwJns= github.com/AdamKorcz/go-fuzz-headers-1 v0.0.0-20230329111138-12e09aba5ebd h1:1tbEqR4NyQLgiod7vLXSswHteGetAVZrMGCqrJxLKRs= +github.com/AdamKorcz/go-fuzz-headers-1 v0.0.0-20230329111138-12e09aba5ebd/go.mod h1:0vOOKsOMKPThRu9lQMAxcQ8D60f8U+wHXl07SyUw0+U= github.com/AlecAivazis/survey/v2 v2.3.6 h1:NvTuVHISgTHEHeBFqt6BHOe4Ny/NwGZr7w+F8S9ziyw= github.com/AlecAivazis/survey/v2 v2.3.6/go.mod h1:4AuI9b7RjAR+G7v9+C4YSlX/YL3K3cWNXgWXOhllqvI= github.com/Azure/azure-sdk-for-go v68.0.0+incompatible h1:fcYLmCpyNYRnvJbPerq7U0hS+6+I79yEDJBqVNcqUzU= @@ -41,7 +45,9 @@ github.com/Azure/go-autorest/autorest/mocks v0.4.1/go.mod h1:LTp+uSrOhSkaKrUy935 github.com/Azure/go-autorest/autorest/mocks v0.4.2 h1:PGN4EDXnuQbojHbU0UWoNvmu9AGVwYHG9/fkDYhtAfw= github.com/Azure/go-autorest/autorest/mocks v0.4.2/go.mod h1:Vy7OitM9Kei0i1Oj+LvyAWMXJHeKH1MVlzFugfVrmyU= github.com/Azure/go-autorest/autorest/to v0.4.0 h1:oXVqrxakqqV1UZdSazDOPOLvOIz+XA683u8EctwboHk= +github.com/Azure/go-autorest/autorest/to v0.4.0/go.mod h1:fE8iZBn7LQR7zH/9XU2NcPR4o9jEImooCeWJcYV/zLE= github.com/Azure/go-autorest/autorest/validation v0.3.1 h1:AgyqjAd94fwNAoTjl/WQXg4VvFeRFpO+UhNyRXqF1ac= +github.com/Azure/go-autorest/autorest/validation v0.3.1/go.mod h1:yhLgjC0Wda5DYXl6JAsWyUe4KVNffhoDhG0zVzUMo3E= github.com/Azure/go-autorest/logger v0.2.1 h1:IG7i4p/mDa2Ce4TRyAO8IHnVhAVF3RFU+ZtXWSmf4Tg= github.com/Azure/go-autorest/logger v0.2.1/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZmbF5NWuPV8+WeEW8= github.com/Azure/go-autorest/tracing v0.6.0 h1:TYi4+3m5t6K48TGI9AUdb+IzbnSxvnvUMfuitfgcfuo= @@ -69,6 +75,7 @@ github.com/asaskevich/govalidator v0.0.0-20200907205600-7a23bdc65eef/go.mod h1:W github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2 h1:DklsrG3dyBCFEj5IhUbnKptjxatkF07cF2ak3yi77so= github.com/asaskevich/govalidator v0.0.0-20230301143203-a9d515a09cc2/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw= github.com/aws/aws-sdk-go v1.44.259 h1:7yDn1dcv4DZFMKpu+2exIH5O6ipNj9qXrKfdMUaIJwY= +github.com/aws/aws-sdk-go v1.44.259/go.mod h1:aVsgQcEevwlmQ7qHE9I3h+dtQgpqhFB+i8Phjh7fkwI= github.com/aws/aws-sdk-go-v2 v1.7.1/go.mod h1:L5LuPC1ZgDr2xQS7AmIec/Jlc7O/Y1u2KxJyNVab250= github.com/aws/aws-sdk-go-v2 v1.14.0/go.mod h1:ZA3Y8V0LrlWj63MQAnRHgKf/5QB//LSZCPNWlWrNGLU= github.com/aws/aws-sdk-go-v2 v1.18.0 h1:882kkTpSFhdgYRKVZ/VCgf7sd0ru57p2JCxz4/oN5RY= @@ -101,6 +108,7 @@ github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.2.1/go.mod h1:zce github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.9.27 h1:0iKliEXAcCa2qVtRs7Ot5hItA2MsufrphbRFlz1Owxo= github.com/aws/aws-sdk-go-v2/service/internal/presigned-url v1.9.27/go.mod h1:EOwBD4J4S5qYszS5/3DpkejfuK+Z5/1uzICfPaZLtqw= github.com/aws/aws-sdk-go-v2/service/kms v1.21.1 h1:Q03Jqh1enA8keCiGZpLetpk58Ll9iGejE5bOErxyGAU= +github.com/aws/aws-sdk-go-v2/service/kms v1.21.1/go.mod h1:EEfb4gfSphdVpRo5sGf2W3KvJbelYUno5VaXR5MJ3z4= github.com/aws/aws-sdk-go-v2/service/sso v1.3.1/go.mod h1:J3A3RGUvuCZjvSuZEcOpHDnzZP/sKbhDWV2T1EOzFIM= github.com/aws/aws-sdk-go-v2/service/sso v1.12.10 h1:UBQjaMTCKwyUYwiVnUt6toEJwGXsLBI6al083tpjJzY= github.com/aws/aws-sdk-go-v2/service/sso v1.12.10/go.mod h1:ouy2P4z6sJN70fR3ka3wD3Ro3KezSxU6eKGQI2+2fjI= @@ -116,6 +124,7 @@ github.com/aws/smithy-go v1.13.5/go.mod h1:Tg+OJXh4MB2R/uN61Ko2f6hTZwB/ZYGOtib8J github.com/awslabs/amazon-ecr-credential-helper/ecr-login v0.0.0-20220517224237-e6f29200ae04 h1:p2I85zYI9z5/c/3Q0LiO3RtNXcmXHTtJfml/hV16zNg= github.com/awslabs/amazon-ecr-credential-helper/ecr-login v0.0.0-20220517224237-e6f29200ae04/go.mod h1:Z+bXnIbhKJYSvxNwsNnwde7pDKxuqlEZCbUBoTwAqf0= github.com/benbjohnson/clock v1.1.0 h1:Q92kusRqC1XV2MjkWETPvjJVqKetz1OzxZB7mHJLju8= +github.com/benbjohnson/clock v1.1.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= github.com/blang/semver v3.5.1+incompatible h1:cQNTCjp13qL8KC3Nbxr/y2Bqb63oX6wdnnjpJbkM4JQ= @@ -125,6 +134,7 @@ github.com/briandowns/spinner v1.19.0/go.mod h1:mQak9GHqbspjC/5iUx3qMlIho8xBS/pp github.com/buger/jsonparser v1.1.1/go.mod h1:6RYKKt7H4d4+iWqouImQ9R2FZql3VbhNgx27UK13J/0= github.com/bwesterb/go-ristretto v1.2.0/go.mod h1:fUIoIZaG73pV5biE2Blr2xEzDoMj7NFEuV9ekS419A0= github.com/cenkalti/backoff/v3 v3.2.2 h1:cfUAAO3yvKMYKPrvhDuHSwQnhZNk/RMHKdZqKTxfm6M= +github.com/cenkalti/backoff/v3 v3.2.2/go.mod h1:cIeZDE3IrqwwJl6VUwCN6trj1oXrTS4rc0ij+ULvLYs= github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc= github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= @@ -151,6 +161,7 @@ github.com/cncf/xds/go v0.0.0-20210922020428-25de7278fc84/go.mod h1:eXthEFrGJvWH github.com/cncf/xds/go v0.0.0-20211001041855-01bcc9b48dfe/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/codahale/rfc6979 v0.0.0-20141003034818-6a90f24967eb h1:EDmT6Q9Zs+SbUoc7Ik9EfrFqcylYqgPZ9ANSbTAntnE= +github.com/codahale/rfc6979 v0.0.0-20141003034818-6a90f24967eb/go.mod h1:ZjrT6AXHbDs86ZSdt/osfBi5qfexBrKUdONk989Wnk4= github.com/containerd/stargz-snapshotter/estargz v0.14.3 h1:OqlDCK3ZVUO6C3B/5FSkDwbkEETK84kQgEeFwDC+62k= github.com/containerd/stargz-snapshotter/estargz v0.14.3/go.mod h1:KY//uOCIkSuNAHhJogcZtrNHdKrA99/FCCRjE3HD36o= github.com/cppforlife/cobrautil v0.0.0-20221021151949-d60711905d65 h1:+3J1K6yQFRPKDEl5Py68c1q0FjaCkeMcB1nb7uzmpSw= @@ -165,9 +176,11 @@ github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7Do github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= github.com/creack/pty v1.1.17/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4= github.com/creack/pty v1.1.18 h1:n56/Zwd5o6whRC5PMGretI4IdRLlmBXYNjScPaBgsbY= +github.com/creack/pty v1.1.18/go.mod h1:MOBLtS5ELjhRRrroQr9kyvTxUAFNvYEK993ew/Vr4O4= github.com/cyberphone/json-canonicalization v0.0.0-20220623050100-57a0ce2678a7 h1:vU+EP9ZuFUCYE0NYLwTSob+3LNEJATzNfP/DC7SWGWI= github.com/cyberphone/json-canonicalization v0.0.0-20220623050100-57a0ce2678a7/go.mod h1:uzvlm1mxhHkdfqitSA92i7Se+S9ksOn3a3qmv/kyOCw= github.com/cyphar/filepath-securejoin v0.2.3 h1:YX6ebbZCZP7VkM3scTTokDgBL2TY741X51MTk3ycuNI= +github.com/cyphar/filepath-securejoin v0.2.3/go.mod h1:aPGpWjXOXUn2NCNjFvBE6aRxGGx79pTxQpKOJNYHHl4= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -208,14 +221,18 @@ github.com/evanphx/json-patch v5.6.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLi github.com/evanphx/json-patch/v5 v5.6.0 h1:b91NhWfaz02IuVxO9faSllyAtNXHMPkC5J8sJCLunww= github.com/evanphx/json-patch/v5 v5.6.0/go.mod h1:G79N1coSVB93tBe7j6PhzjmR3/2VvlbKOFpnXhI9Bw4= github.com/facebookgo/clock v0.0.0-20150410010913-600d898af40a h1:yDWHCSQ40h88yih2JAcL6Ls/kVkSE8GFACTGVnMPruw= +github.com/facebookgo/clock v0.0.0-20150410010913-600d898af40a/go.mod h1:7Ga40egUymuWXxAe151lTNnCv97MddSOVsjpPPkityA= github.com/facebookgo/limitgroup v0.0.0-20150612190941-6abd8d71ec01 h1:IeaD1VDVBPlx3viJT9Md8if8IxxJnO+x0JCGb054heg= +github.com/facebookgo/limitgroup v0.0.0-20150612190941-6abd8d71ec01/go.mod h1:ypD5nozFk9vcGw1ATYefw6jHe/jZP++Z15/+VTMcWhc= github.com/facebookgo/muster v0.0.0-20150708232844-fd3d7953fd52 h1:a4DFiKFJiDRGFD1qIcqGLX/WlUMD9dyLSLDt+9QZgt8= +github.com/facebookgo/muster v0.0.0-20150708232844-fd3d7953fd52/go.mod h1:yIquW87NGRw1FU5p5lEkpnt/QxoH5uPAOUlOVkAUuMg= github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= github.com/fatih/color v1.10.0/go.mod h1:ELkj/draVOlAH/xkhN6mQ50Qd0MPOk5AAr3maGEBuJM= github.com/fatih/color v1.15.0 h1:kOqh6YHBtK8aywxGerMG2Eq3H6Qgoqeo13Bk2Mv/nBs= github.com/fatih/color v1.15.0/go.mod h1:0h5ZqXfHYED7Bhv2ZJamyIOUej9KtShiJESRwBDUSsw= github.com/flowstack/go-jsonschema v0.1.1/go.mod h1:yL7fNggx1o8rm9RlgXv7hTBWxdBM0rVwpMwimd3F3N0= github.com/frankban/quicktest v1.14.3 h1:FJKSZTDHjyhriyC81FLQ0LY93eSai0ZyR/ZIkd3ZUKE= +github.com/frankban/quicktest v1.14.3/go.mod h1:mgiwOwqx65TmIk1wJ6Q7wvnVMocbUorkibMOrVTHZps= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= github.com/fsnotify/fsnotify v1.5.4/go.mod h1:OVB6XrOHzAwXMpEM7uPOzcehqUV2UqJxmVXmkdnm1bU= @@ -227,6 +244,7 @@ github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeME github.com/go-chi/chi v4.1.2+incompatible h1:fGFk2Gmi/YKXk0OmGfBh0WgmN3XB8lVnEyNz34tQRec= github.com/go-chi/chi v4.1.2+incompatible/go.mod h1:eB3wogJHnLi3x/kFX2A+IbTBlXxmMeXJVKy9tTv1XzQ= github.com/go-jose/go-jose/v3 v3.0.0 h1:s6rrhirfEP/CGIoc6p+PZAeogN2SxKav6Wp7+dyMWVo= +github.com/go-jose/go-jose/v3 v3.0.0/go.mod h1:RNkWWRld676jZEYoV3+XK8L2ZnNSvIsxFMht0mSX+u8= github.com/go-logr/logr v1.2.0/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= github.com/go-logr/logr v1.2.4 h1:g01GSCwiDw2xSZfjJ2/T9M+S6pFdcNtFYsp+Y43HYDQ= @@ -234,6 +252,7 @@ github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbV github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= github.com/go-logr/zapr v1.2.3 h1:a9vnzlIBPQBBkeaR9IuMUfmVOrQlkoC4YfPoFkX3T7A= +github.com/go-logr/zapr v1.2.3/go.mod h1:eIauM6P8qSvTw5o2ez6UEAfGjQKrxQTl5EoK+Qa2oG4= github.com/go-openapi/analysis v0.21.2/go.mod h1:HZwRk4RRisyG8vx2Oe6aqeSQcoxRp47Xkp3+K6q+LdY= github.com/go-openapi/analysis v0.21.4 h1:ZDFLvSNxpDaomuCueM0BlSXxpANBlFYiBvr+GXrvIHc= github.com/go-openapi/analysis v0.21.4/go.mod h1:4zQ35W4neeZTqh3ol0rv/O8JBbka9QyAgQRPp9y3pfo= @@ -272,6 +291,7 @@ github.com/go-openapi/swag v0.22.3/go.mod h1:UzaqsxGiab7freDnrUUra0MwWfN/q7tE4j+ github.com/go-openapi/validate v0.22.1 h1:G+c2ub6q47kfX1sOBLwIQwzBVt8qmOAARyo/9Fqs9NU= github.com/go-openapi/validate v0.22.1/go.mod h1:rjnrwK57VJ7A8xqfpAOEKRH8yQSGUriMu5/zuPSQ1hg= github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= +github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= @@ -283,6 +303,7 @@ github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg78 github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 h1:tfuBGBXKqDEevZMzYi5KSi8KkcZtzBcTgAUUtapy0OI= github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572/go.mod h1:9Pwr4B2jHnOSGXyyzV8ROjYa2ojvAY6HCGYYfMoC3Ls= github.com/go-test/deep v1.1.0 h1:WOcxcdHcvdgThNXjw0t76K42FXTU7HpNQWHpA2HHNlg= +github.com/go-test/deep v1.1.0/go.mod h1:5C2ZWiW0ErCdrYzpqxLbTX7MG14M9iiw8DgHncVwcsE= github.com/gobuffalo/attrs v0.0.0-20190224210810-a9411de4debd/go.mod h1:4duuawTqi2wkkpB4ePgWMaai6/Kc6WEz83bhFwpHzj0= github.com/gobuffalo/depgen v0.0.0-20190329151759-d478694a28d3/go.mod h1:3STtPUQYuzV0gBVOY3vy6CfMm/ljR4pABfrTeHNLHUY= github.com/gobuffalo/depgen v0.1.0/go.mod h1:+ifsuy7fhi15RWncXQQKjWS9JPkdah5sZvtHc2RXGlg= @@ -376,7 +397,9 @@ github.com/google/pprof v0.0.0-20210407192527-94a9f03dee38/go.mod h1:kpwsk12EmLe github.com/google/pprof v0.0.0-20221118152302-e6195bd50e26 h1:Xim43kblpZXfIBQsbuBVKCudVG457BR2GZFIz3uw3hQ= github.com/google/pprof v0.0.0-20221118152302-e6195bd50e26/go.mod h1:dDKJzRmX4S37WGHujM7tX//fmj1uioxKzKxz3lo4HJo= github.com/google/s2a-go v0.1.3 h1:FAgZmpLl/SXurPEZyCMPBIiiYeTbqfjlbdnCNTAkbGE= +github.com/google/s2a-go v0.1.3/go.mod h1:Ej+mSEMGRnqRzjc7VtF+jdBwYG5fuJfiZ8ELkjEwM0A= github.com/google/tink/go v1.7.0 h1:6Eox8zONGebBFcCBqkVmt60LaWZa6xg1cl/DwAh/J1w= +github.com/google/tink/go v1.7.0/go.mod h1:GAUOd+QE3pgj9q8VKIGTCP33c/B7eb4NhxLcgTJZStM= github.com/google/trillian v1.5.2 h1:roGP6G8aaAch7vP08+oitPkvmZzxjTfIkguozqJ04Ok= github.com/google/trillian v1.5.2/go.mod h1:H8vOoa2dxd3xCdMzOOwt9kIz/3MSoJhcqLJGG8iRwbg= github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= @@ -385,6 +408,7 @@ github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I= github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/googleapis/enterprise-certificate-proxy v0.0.0-20220520183353-fd19c99a87aa/go.mod h1:17drOmN3MwGY7t0e+Ei9b45FFGA3fBs3x36SsCg1hq8= github.com/googleapis/enterprise-certificate-proxy v0.2.3 h1:yk9/cqRKtT9wXZSsRH9aurXEpJX+U6FLtpYTdC3R06k= +github.com/googleapis/enterprise-certificate-proxy v0.2.3/go.mod h1:AwSRAtLfXpU5Nm3pW+v7rGDHp09LsPtGY9MduiEsR9k= github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= github.com/googleapis/gax-go/v2 v2.1.0/go.mod h1:Q3nei7sK6ybPYH7twZdmQpAd1MKb7pfu6SK+H1/DsU0= github.com/googleapis/gax-go/v2 v2.1.1/go.mod h1:hddJymUZASv3XPyGkUpKj8pPO47Rmb0eJc8R6ouapiM= @@ -392,23 +416,31 @@ github.com/googleapis/gax-go/v2 v2.2.0/go.mod h1:as02EH8zWkzwUoLbBaFeQ+arQaj/Oth github.com/googleapis/gax-go/v2 v2.3.0/go.mod h1:b8LNqSzNabLiUpXKkY7HAR5jr6bIT99EXz9pXxye9YM= github.com/googleapis/gax-go/v2 v2.4.0/go.mod h1:XOTVJ59hdnfJLIP/dh8n5CGryZR2LxK9wbMD5+iXC6c= github.com/googleapis/gax-go/v2 v2.8.0 h1:UBtEZqx1bjXtOQ5BVTkuYghXrr3N4V123VKJK67vJZc= +github.com/googleapis/gax-go/v2 v2.8.0/go.mod h1:4orTrqY6hXxxaUL4LHIPl6lGo8vAE38/qKbhSAKP6QI= github.com/googleapis/go-type-adapters v1.0.0/go.mod h1:zHW75FOG2aur7gAO2B+MLby+cLsWGBF62rFAi7WjWO4= github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g= github.com/gorilla/mux v1.8.0 h1:i40aqfkR1h2SlN9hojwV5ZA91wcXFOvkdNIeFDP5koI= github.com/gorilla/mux v1.8.0/go.mod h1:DVbg23sWSpFRCP0SfiEN6jmj59UnW/n46BH5rLB71So= github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw= github.com/hashicorp/errwrap v1.1.0 h1:OxrOeh75EUXMY8TBjag2fzXGZ40LB6IKw45YeGUDY2I= +github.com/hashicorp/errwrap v1.1.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= github.com/hashicorp/go-cleanhttp v0.5.2 h1:035FKYIWjmULyFRBKPs8TBQoi0x6d9G4xc9neXJWAZQ= github.com/hashicorp/go-cleanhttp v0.5.2/go.mod h1:kO/YDlP8L1346E6Sodw+PrpBSV4/SoxCXGY6BqNFT48= github.com/hashicorp/go-hclog v0.9.2/go.mod h1:5CU+agLiy3J7N7QjHK5d05KxGsuXiQLrjA0H7acj2lQ= github.com/hashicorp/go-hclog v1.3.1 h1:vDwF1DFNZhntP4DAjuTpOw3uEgMUpXh1pB5fW9DqHpo= +github.com/hashicorp/go-hclog v1.3.1/go.mod h1:W4Qnvbt70Wk/zYJryRzDRU/4r0kIg0PVHBcfoyhpF5M= github.com/hashicorp/go-multierror v1.1.1 h1:H5DkEtf6CXdFp0N0Em5UCwQpXMWke8IA0+lD48awMYo= +github.com/hashicorp/go-multierror v1.1.1/go.mod h1:iw975J/qwKPdAO1clOe2L8331t/9/fmwbPZ6JB6eMoM= github.com/hashicorp/go-retryablehttp v0.7.2 h1:AcYqCvkpalPnPF2pn0KamgwamS42TqUDDYFRKq/RAd0= github.com/hashicorp/go-retryablehttp v0.7.2/go.mod h1:Jy/gPYAdjqffZ/yFGCFV2doI5wjtH1ewM9u8iYVjtX8= 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-secure-stdlib/parseutil v0.1.7 h1:UpiO20jno/eV1eVZcxqWnUohyKRe1g8FPV/xH1s/2qs= +github.com/hashicorp/go-secure-stdlib/parseutil v0.1.7/go.mod h1:QmrqtbKuxxSWTN3ETMPuB+VtEiBJ/A9XhoYGv8E1uD8= github.com/hashicorp/go-secure-stdlib/strutil v0.1.2 h1:kes8mmyCpxJsI7FTwtzRqEy9CdjCtrXrXGuOpxEA7Ts= +github.com/hashicorp/go-secure-stdlib/strutil v0.1.2/go.mod h1:Gou2R9+il93BqX25LAKCLuM+y9U2T4hlwvT1yprcna4= github.com/hashicorp/go-sockaddr v1.0.2 h1:ztczhD1jLxIRjVejw8gFomI1BQZOe2WoVOu0SyteCQc= +github.com/hashicorp/go-sockaddr v1.0.2/go.mod h1:rB4wwRAUzs07qva3c5SdrY/NEtAUjGlgmH/UkBUC97A= github.com/hashicorp/go-version v1.6.0 h1:feTTfFNnjP967rlCxM/I9g701jU+RN74YKx2mOkIeek= github.com/hashicorp/go-version v1.6.0/go.mod h1:fltr4n8CU8Ke44wwGCBoEymUuxUHl09ZGVZPK5anwXA= github.com/hashicorp/golang-lru v0.5.0/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ4Ao+sR/qLZy8= @@ -416,10 +448,13 @@ github.com/hashicorp/golang-lru v0.5.1/go.mod h1:/m3WP610KZHVQ1SGc6re/UDhFvYD7pJ github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= github.com/hashicorp/vault/api v1.9.1 h1:LtY/I16+5jVGU8rufyyAkwopgq/HpUnxFBg+QLOAV38= +github.com/hashicorp/vault/api v1.9.1/go.mod h1:78kktNcQYbBGSrOjQfHjXN32OhhxXnbYl3zxpd2uPUs= github.com/hinshun/vt10x v0.0.0-20220119200601-820417d04eec h1:qv2VnGeEQHchGaZ/u7lxST/RaJw+cv273q79D81Xbog= github.com/hinshun/vt10x v0.0.0-20220119200601-820417d04eec/go.mod h1:Q48J4R4DvxnHolD5P8pOtXigYlRuPLGl6moFx3ulM68= github.com/honeycombio/beeline-go v1.10.0 h1:cUDe555oqvw8oD76BQJ8alk7FP0JZ/M/zXpNvOEDLDc= +github.com/honeycombio/beeline-go v1.10.0/go.mod h1:Zz5WMeQCJzFt2Mvf8t6HC1X8RLskLVR/e8rvcmXB1G8= github.com/honeycombio/libhoney-go v1.16.0 h1:kPpqoz6vbOzgp7jC6SR7SkNj7rua7rgxvznI6M3KdHc= +github.com/honeycombio/libhoney-go v1.16.0/go.mod h1:izP4fbREuZ3vqC4HlCAmPrcPT9gxyxejRjGtCYpmBn0= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= github.com/imdario/mergo v0.3.13 h1:lFzP57bqS/wsqKssCGmtLAb8A0wKjLGrve2q3PPVcBk= @@ -432,12 +467,14 @@ github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLf github.com/jedisct1/go-minisign v0.0.0-20211028175153-1c139d1cc84b h1:ZGiXF8sz7PDk6RgkP+A/SFfUD0ZR/AgG6SpRNEDKZy8= github.com/jedisct1/go-minisign v0.0.0-20211028175153-1c139d1cc84b/go.mod h1:hQmNrgofl+IY/8L+n20H6E6PWBBTokdsv+q49j0QhsU= github.com/jellydator/ttlcache/v3 v3.0.1 h1:cHgCSMS7TdQcoprXnWUptJZzyFsqs18Lt8VVhRuZYVU= +github.com/jellydator/ttlcache/v3 v3.0.1/go.mod h1:WwTaEmcXQ3MTjOm4bsZoDFiCu/hMvNWLO1w67RXz6h4= github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= github.com/jmespath/go-jmespath v0.4.0 h1:BEgLn5cpjn8UN1mAw4NjwDrS35OdebyEtFe+9YPoQUg= github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo= github.com/jmespath/go-jmespath/internal/testify v1.5.1 h1:shLQSRRSCCPj3f2gpwzGwWFoC7ycTf1rcQZHOlsJ6N8= github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U= github.com/jmhodges/clock v0.0.0-20160418191101-880ee4c33548 h1:dYTbLf4m0a5u0KLmPfB6mgxbcV7588bOCx79hxa5Sr4= +github.com/jmhodges/clock v0.0.0-20160418191101-880ee4c33548/go.mod h1:hGT6jSUVzF6no3QaDSMLGLEHtHSBSefs+MgcDWnmhmo= github.com/joho/godotenv v1.3.0/go.mod h1:7hK45KPybAkOC6peb+G5yklZfMxEjkZhHbwpqxOKXbg= github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y= @@ -446,6 +483,7 @@ github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHm github.com/juju/fslock v0.0.0-20160525022230-4d5c94c67b4b h1:FQ7+9fxhyp82ks9vAuyPzG0/vVbWwMwLJ+P6yJI5FN8= github.com/juju/fslock v0.0.0-20160525022230-4d5c94c67b4b/go.mod h1:HMcgvsgd0Fjj4XXDkbjdmlbI505rUPBs6WBMYg2pXks= github.com/k14s/difflib v0.0.0-20201117154628-0c031775bf57 h1:CwBRArr+BWBopnUJhDjJw86rPL/jGbEjfHWKzTasSqE= +github.com/k14s/difflib v0.0.0-20201117154628-0c031775bf57/go.mod h1:B0xN2MiNBGWOWi9CcfAo9LBI8IU4J1utlbOIJCsmKr4= github.com/k14s/kbld v0.32.0 h1:zf3qCir0usz7rX6JRF97QxaZ25+13EniE7z+ll0xaZ8= github.com/k14s/kbld v0.32.0/go.mod h1:N7Ij72ZhJ2B7kTUxavGTBT1YymIfmAeO6JKyNbtja1g= github.com/k14s/semver/v4 v4.0.1-0.20210701191048-266d47ac6115 h1:wKSifC/VbCaQMqXYn6/gSFqle82OX4bE3KYALDU9FlU= @@ -468,6 +506,7 @@ github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORN github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= +github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= github.com/kr/pty v1.1.8 h1:AkaSdXYQOWeaO3neb8EM634ahkXXe3jYbVh/F9lq+GI= github.com/kr/pty v1.1.8/go.mod h1:O1sed60cT9XZ5uDucP5qwvh+TE3NnUj51EiZO/lmSfw= @@ -507,6 +546,7 @@ github.com/mattn/go-runewidth v0.0.12/go.mod h1:RAqKPSqVFrSLVXbA8x7dzmKdmGzieGRC github.com/mattn/go-runewidth v0.0.14 h1:+xnbZSEeDbOIg5/mE6JF0w6n9duR1l3/WmbinWVwUuU= github.com/mattn/go-runewidth v0.0.14/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w= github.com/mattn/go-sqlite3 v1.14.16 h1:yOQRA0RpS5PFz/oikGwBEqvAWhWg5ufRz4ETLjwpU1Y= +github.com/mattn/go-sqlite3 v1.14.16/go.mod h1:2eHXhiwb8IkHr+BDWZGa96P6+rkvnG63S2DGjv9HUNg= github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo= github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= github.com/mgutz/ansi v0.0.0-20170206155736-9520e82c474b h1:j7+1HpAFS1zy5+Q4qx1fWh90gTKwiN4QCGoY9TWyyO4= @@ -601,6 +641,7 @@ github.com/rogpeppe/go-internal v1.10.0/go.mod h1:UQnix2H7Ngw/k4C5ijL5+65zddjncj github.com/russross/blackfriday/v2 v2.1.0 h1:JIOH55/0cWyOuilr9/qlrm0BSXldqnqwMsf35Ld67mk= github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/ryanuber/go-glob v1.0.0 h1:iQh3xXAumdQ+4Ufa5b25cRpC5TYKlno6hsv6Cb3pkBk= +github.com/ryanuber/go-glob v1.0.0/go.mod h1:807d1WSdnB0XRJzKNil9Om6lcp/3a0v4qIHxIXzX/Yc= github.com/sassoftware/relic v7.2.1+incompatible h1:Pwyh1F3I0r4clFJXkSI8bOyJINGqpgjJU3DYAZeI05A= github.com/sassoftware/relic v7.2.1+incompatible/go.mod h1:CWfAxv73/iLZ17rbyhIEq3K9hs5w6FpNMdUT//qR+zk= github.com/sclevine/agouti v3.0.0+incompatible/go.mod h1:b4WX9W9L1sfQKXeJf1mUTLZKJ48R1S7H23Ji7oFO5Bw= @@ -664,6 +705,7 @@ github.com/theupdateframework/go-tuf v0.5.2 h1:habfDzTmpbzBLIFGWa2ZpVhYvFBoK0C1o github.com/theupdateframework/go-tuf v0.5.2/go.mod h1:SyMV5kg5n4uEclsyxXJZI2UxPFJNDc4Y+r7wv+MlvTA= github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk= github.com/tidwall/pretty v1.2.0 h1:RWIZEg2iJ8/g6fDDYzMpobmaoGh5OLl4AXtGUGPcqCs= +github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= github.com/titanous/rocacheck v0.0.0-20171023193734-afe73141d399 h1:e/5i7d4oYZ+C1wj2THlRK+oAhjeS/TRQwMfkIuet3w0= github.com/titanous/rocacheck v0.0.0-20171023193734-afe73141d399/go.mod h1:LdwHTNJT99C5fTAzDz0ud328OgXz+gierycbcIx2fRs= github.com/tj/assert v0.0.3 h1:Df/BlaZ20mq6kuai7f5z2TvPFiwC3xaWJSDQNiIS3Rk= @@ -678,7 +720,9 @@ github.com/verybluebot/tarinator-go v0.0.0-20190613183509-5ab4e1193986/go.mod h1 github.com/vito/go-interact v1.0.1 h1:O8xi8c93bRUv2Tb/v6HdiuGc+WnWt+AQzF74MOOdlBs= github.com/vito/go-interact v1.0.1/go.mod h1:HrdHSJXD2yn1MhlTwSIMeFgQ5WftiIorszVGd3S/DAA= github.com/vmihailenco/msgpack/v5 v5.3.5 h1:5gO0H1iULLWGhs2H5tbAHIZTV8/cYafcFOr9znI5mJU= +github.com/vmihailenco/msgpack/v5 v5.3.5/go.mod h1:7xyJ9e+0+9SaZT0Wt1RGleJXzli6Q/V5KbhBonMG9jc= github.com/vmihailenco/tagparser/v2 v2.0.0 h1:y09buUbR+b5aycVFQs/g70pqKVZNBmxwAhO7/IwNM9g= +github.com/vmihailenco/tagparser/v2 v2.0.0/go.mod h1:Wri+At7QHww0WTrCBeu4J6bNtoV6mEfg5OIWRZA9qds= github.com/vmware-tanzu/carvel-imgpkg v0.36.1 h1:OYO0yIqQ1V2o5E4fXH6QRfEovYm2ln3us31mHFT8OIw= github.com/vmware-tanzu/carvel-imgpkg v0.36.1/go.mod h1:eBOaUEF4tVajROCfcNFnB3zThG6xONhKuahbLFiqGU4= github.com/vmware-tanzu/carvel-vendir v0.26.0 h1:Q98tPnH9WUAWE2vJSAP0lsHGsfwGjfW2y+JUOEiJ/Yk= @@ -691,8 +735,8 @@ github.com/vmware-tanzu/tanzu-framework/apis/run v0.0.0-20230419030809-7081502eb github.com/vmware-tanzu/tanzu-framework/apis/run v0.0.0-20230419030809-7081502ebf68/go.mod h1:e1Uef+Ux5BIHpYwqbeP2ZZmOzehBcez2vUEWXHe+xHE= github.com/vmware-tanzu/tanzu-framework/capabilities/client v0.0.0-20230523145612-1c6fbba34686 h1:VcuXqUXFxm5WDqWkzAlU/6cJXua0ozELnqD59fy7J6E= github.com/vmware-tanzu/tanzu-framework/capabilities/client v0.0.0-20230523145612-1c6fbba34686/go.mod h1:AFGOXZD4tH+KhpmtV0VjWjllXhr8y57MvOsIxTtywc4= -github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.0 h1:8u4BYfAFSsNYRHcSZrhDEDeGMNGStRDs7Ywe2BOBpmg= -github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.0/go.mod h1:wMK/qpJjU7hytDAGt3FX5/iGdlUK8TsJLu36pCr+Zvk= +github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.1 h1:g+ayiMzQApBzgRgKCCjmyB8kAbeD6yZ5MF+f++iZ+pM= +github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.1/go.mod h1:wMK/qpJjU7hytDAGt3FX5/iGdlUK8TsJLu36pCr+Zvk= github.com/xanzy/go-gitlab v0.83.0 h1:37p0MpTPNbsTMKX/JnmJtY8Ch1sFiJzVF342+RvZEGw= github.com/xanzy/go-gitlab v0.83.0/go.mod h1:5ryv+MnpZStBH8I/77HuQBsMbBGANtVpLWC15qOjWAw= github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI= @@ -717,18 +761,22 @@ go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= go.opencensus.io v0.23.0/go.mod h1:XItmlyltB5F7CS4xOC1DcqMoFqwtC6OG2xF7mCv7P7E= go.opencensus.io v0.24.0 h1:y73uSU6J157QMP2kn2r30vwW1A2W2WFwSCGnAVxeaD0= +go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= go.opentelemetry.io/otel v1.15.0 h1:NIl24d4eiLJPM0vKn4HjLYM+UZf6gSfi9Z+NmCxkWbk= go.opentelemetry.io/otel v1.15.0/go.mod h1:qfwLEbWhLPk5gyWrne4XnF0lC8wtywbuJbgfAE3zbek= go.opentelemetry.io/otel/sdk v1.14.0 h1:PDCppFRDq8A1jL9v6KMI6dYesaq+DFcDZvjsoGvxGzY= +go.opentelemetry.io/otel/sdk v1.14.0/go.mod h1:bwIC5TjrNG6QDCHNWvW4HLHtUQ4I+VQDsnjhvyZCALM= go.opentelemetry.io/otel/trace v1.15.0 h1:5Fwje4O2ooOxkfyqI/kJwxWotggDLix4BSAvpE1wlpo= go.opentelemetry.io/otel/trace v1.15.0/go.mod h1:CUsmE2Ht1CRkvE8OsMESvraoZrrcgD1J2W8GV1ev0Y4= go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqeYNgFYFoEGnI= go.pinniped.dev v0.20.0 h1:tw602N+BDgjf3y1ahCIvpr86fiqY3jAKADxscULFbvQ= go.pinniped.dev v0.20.0/go.mod h1:hbE7IYaXqtYyFpfB3M1C7WX2Gdlo5mH8f8zcQe1A+wE= go.step.sm/crypto v0.30.0 h1:EzqPTvW1g6kxEnfIf/exDW+MhHGeEhtoNMhQX7P/UwI= +go.step.sm/crypto v0.30.0/go.mod h1:6jFFgUoafyHvb6rNq3NJrBByof4SCzj1n8ThyXuMVAM= go.uber.org/atomic v1.10.0 h1:9qC72Qh0+3MqyJbAn8YU5xVq1frD8bn3JtD2oXtafVQ= go.uber.org/atomic v1.10.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0= go.uber.org/goleak v1.2.1 h1:NBol2c7O1ZokfZ0LEU9K6Whx/KnwvepVetCUhtKja4A= +go.uber.org/goleak v1.2.1/go.mod h1:qlT2yGI9QafXHhZZLxlSuNsMw3FFLxBr+tBRlmO1xH4= go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= go.uber.org/zap v1.24.0 h1:FiJd5l1UOLj0wCgbSE0rwwXHzEdAZS6hiiSnxJN/D60= @@ -956,6 +1004,7 @@ google.golang.org/api v0.75.0/go.mod h1:pU9QmyHLnzlpar1Mjt4IbapUCy8J+6HD6GeELN69 google.golang.org/api v0.78.0/go.mod h1:1Sg78yoMLOhlQTeF+ARBoytAcH1NNyyl390YMy6rKmw= google.golang.org/api v0.84.0/go.mod h1:NTsGnUFJMYROtiquksZHBWtHfeMC7iYthki7Eq3pa8o= google.golang.org/api v0.123.0 h1:yHVU//vA+qkOhm4reEC9LtzHVUCN/IqqNRl1iQ9xE20= +google.golang.org/api v0.123.0/go.mod h1:gcitW0lvnyWjSp9nKxAbdHKIZ6vF4aajGueeslZOyms= google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM= google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= google.golang.org/appengine v1.5.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4= @@ -1040,6 +1089,7 @@ google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqw google.golang.org/protobuf v1.30.0 h1:kPPoIgf3TsEvrm0PFe15JQ+570QVxYzEvvHqChK+cng= google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= gopkg.in/alexcesaro/statsd.v2 v2.0.0 h1:FXkZSCZIH17vLCO5sO2UucTHsH9pc+17F6pl3JVCwMc= +gopkg.in/alexcesaro/statsd.v2 v2.0.0/go.mod h1:i0ubccKGzBVNBpdGV5MocxyA/XlLUJzA7SLonnE4drU= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= @@ -1100,7 +1150,9 @@ modernc.org/cc/v3 v3.40.0/go.mod h1:/bTg4dnWkSXowUO6ssQKnOV0yMVxDYNIsIrzqTFDGH0= modernc.org/ccgo/v3 v3.16.13 h1:Mkgdzl46i5F/CNR/Kj80Ri59hC8TKAhZrYSaqvkwzUw= modernc.org/ccgo/v3 v3.16.13/go.mod h1:2Quk+5YgpImhPjv2Qsob1DnZ/4som1lJTodubIcoUkY= modernc.org/ccorpus v1.11.6 h1:J16RXiiqiCgua6+ZvQot4yUuUy8zxgqbqEEUuGPlISk= +modernc.org/ccorpus v1.11.6/go.mod h1:2gEUTrWqdpH2pXsmTM1ZkjeSrUWDpjMu2T6m29L/ErQ= modernc.org/httpfs v1.0.6 h1:AAgIpFZRXuYnkjftxTAZwMIiwEqAfk8aVB2/oA6nAeM= +modernc.org/httpfs v1.0.6/go.mod h1:7dosgurJGp0sPaRanU53W4xZYKh14wfzX420oZADeHM= modernc.org/libc v1.22.3 h1:D/g6O5ftAfavceqlLOFwaZuA5KYafKwmr30A6iSqoyY= modernc.org/libc v1.22.3/go.mod h1:MQrloYP209xa2zHome2a8HLiLm6k0UT8CoHpV74tOFw= modernc.org/mathutil v1.5.0 h1:rV0Ko/6SfM+8G+yKiyI830l3Wuz1zRutdslNoQ0kfiQ= @@ -1114,9 +1166,11 @@ modernc.org/sqlite v1.21.1/go.mod h1:XwQ0wZPIh1iKb5mkvCJ3szzbhk+tykC8ZWqTRTgYRwI modernc.org/strutil v1.1.3 h1:fNMm+oJklMGYfU9Ylcywl0CO5O6nTfaowNsh2wpPjzY= modernc.org/strutil v1.1.3/go.mod h1:MEHNA7PdEnEwLvspRMtWTNnp2nnyvMfkimT1NKNAGbw= modernc.org/tcl v1.15.1 h1:mOQwiEK4p7HruMZcwKTZPw/aqtGM4aY00uzWhlKKYws= +modernc.org/tcl v1.15.1/go.mod h1:aEjeGJX2gz1oWKOLDVZ2tnEWLUrIn8H+GFu+akoDhqs= modernc.org/token v1.0.1 h1:A3qvTqOwexpfZZeyI0FeGPDlSWX5pjZu9hF4lU+EKWg= modernc.org/token v1.0.1/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM= modernc.org/z v1.7.0 h1:xkDw/KepgEjeizO2sNco+hqYkU12taxQFqPEmgm1GWE= +modernc.org/z v1.7.0/go.mod h1:hVdgNMh8ggTuRG1rGU8x+xGRFfiQUIAw0ZqlPy8+HyQ= sigs.k8s.io/cluster-api v1.4.2 h1:hdIz0Ms2j7YaU1qBK5yF2R8ii0GcGb3jQ7EO6i3tAN8= sigs.k8s.io/cluster-api v1.4.2/go.mod h1:IIebZTsqyXU8CHbINV2zuMh0/wykqdr+vEXxQNeteEU= sigs.k8s.io/controller-runtime v0.14.5 h1:6xaWFqzT5KuAQ9ufgUaj1G/+C4Y1GRkhrxl+BJ9i+5s= diff --git a/go.work b/go.work index 8a2e13088..8fd2b414f 100644 --- a/go.work +++ b/go.work @@ -1,4 +1,4 @@ -go 1.19 +go 1.21 use ( . diff --git a/go.work.sum b/go.work.sum index 87d2dbf57..5b847fcb0 100644 --- a/go.work.sum +++ b/go.work.sum @@ -310,11 +310,14 @@ contrib.go.opencensus.io/resource v0.1.1 h1:4r2CANuYhKGmYWP02+5E94rLRcS/YeD+KlxS contrib.go.opencensus.io/resource v0.1.1/go.mod h1:F361eGI91LCmW1I/Saf+rX0+OFcigGlFvXwEGEnkRLA= cuelang.org/go v0.4.3 h1:W3oBBjDTm7+IZfCKZAmC8uDG0eYfJL4Pp/xbbCMKaVo= cuelang.org/go v0.5.0 h1:D6N0UgTGJCOxFKU8RU+qYvavKNsVc/+ZobmifStVJzU= +cuelang.org/go v0.5.0/go.mod h1:okjJBHFQFer+a41sAe2SaGm1glWS8oEb6CmJvn5Zdws= dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9 h1:VpgP7xuJadIUuKccphEpTJnWhS2jkQyMt6Y7pJCD7fY= dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= filippo.io/edwards25519 v1.0.0/go.mod h1:N1IkdkCkiLB6tki+MYJoSx2JTY9NUlxZE7eHn5EwJns= github.com/AdaLogics/go-fuzz-headers v0.0.0-20210715213245-6c3934b029d8/go.mod h1:CzsSbkDixRphAF5hS6wbMKq0eI6ccJRb7/A0M6JBnwg= +github.com/AdamKorcz/go-fuzz-headers-1 v0.0.0-20230329111138-12e09aba5ebd/go.mod h1:0vOOKsOMKPThRu9lQMAxcQ8D60f8U+wHXl07SyUw0+U= github.com/AliyunContainerService/ack-ram-tool/pkg/credentials/alibabacloudsdkgo/helper v0.2.0 h1:8+4G8JaejP8Xa6W46PzJEwisNgBXMvFcz78N6zG/ARw= +github.com/AliyunContainerService/ack-ram-tool/pkg/credentials/alibabacloudsdkgo/helper v0.2.0/go.mod h1:GgeIE+1be8Ivm7Sh4RgwI42aTtC9qrcj+Y9Y6CjJhJs= github.com/Azure/azure-amqp-common-go/v2 v2.1.0 h1:+QbFgmWCnPzdaRMfsI0Yb6GrRdBj5jVL8N3EXuEUcBQ= github.com/Azure/azure-amqp-common-go/v2 v2.1.0/go.mod h1:R8rea+gJRuJR6QxTir/XuEd+YuKoUiazDC/N96FiDEU= github.com/Azure/azure-pipeline-go v0.2.1 h1:OLBdZJ3yvOn2MezlWvbrBMTEUQC72zAftRZOMdj5HYo= @@ -350,6 +353,7 @@ github.com/Azure/go-autorest/autorest/to v0.4.0/go.mod h1:fE8iZBn7LQR7zH/9XU2NcP github.com/Azure/go-autorest/autorest/validation v0.3.1/go.mod h1:yhLgjC0Wda5DYXl6JAsWyUe4KVNffhoDhG0zVzUMo3E= github.com/Azure/go-autorest/logger v0.2.0/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZmbF5NWuPV8+WeEW8= github.com/Azure/go-ntlmssp v0.0.0-20220621081337-cb9428e4ac1e h1:NeAW1fUYUEWhft7pkxDf6WoUvEZJ/uOKsvtpjLnn8MU= +github.com/Azure/go-ntlmssp v0.0.0-20220621081337-cb9428e4ac1e/go.mod h1:chxPXzSsl7ZWRAuOIE23GDNzjWuZquvFlgA8xmpunjU= github.com/AzureAD/microsoft-authentication-library-for-go v1.0.0/go.mod h1:kgDmCTgBzIEPFElEF+FK0SdjAor06dRq2Go927dnQ6o= github.com/BurntSushi/toml v1.2.0/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802 h1:1BDTz0u9nC3//pOCMdNH+CiXJVYJh5UQNCOBG7jbELc= @@ -362,6 +366,7 @@ github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go github.com/MakeNowJust/heredoc v1.0.0 h1:cXCdzVdstXyiTqTvfqk9SDHpKNjxuom+DOlyEeQ4pzQ= github.com/MakeNowJust/heredoc v1.0.0/go.mod h1:mG5amYoWBHf8vpLOuehzbGGw0EHxpZZ6lCpQ4fNJ8LE= github.com/MakeNowJust/heredoc/v2 v2.0.1 h1:rlCHh70XXXv7toz95ajQWOWQnN4WNLt0TdpZYIR/J6A= +github.com/MakeNowJust/heredoc/v2 v2.0.1/go.mod h1:6/2Abh5s+hc3g9nbWLe9ObDIOhaRrqsyY9MWy+4JdRM= github.com/Masterminds/goutils v1.1.0/go.mod h1:8cTjp+g8YejhMuvIA5y2vz3BpJxksy863GQaJW2MFNU= github.com/Masterminds/goutils v1.1.1 h1:5nUrii3FMTL5diU80unEVvNevw1nH4+ZV4DSLVJLSYI= github.com/Masterminds/goutils v1.1.1/go.mod h1:8cTjp+g8YejhMuvIA5y2vz3BpJxksy863GQaJW2MFNU= @@ -407,6 +412,7 @@ github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb0 github.com/NYTimes/gziphandler v1.1.1 h1:ZUDjpQae29j0ryrS0u/B8HZfJBtBQHjqw2rQ2cqUQ3I= github.com/NYTimes/gziphandler v1.1.1/go.mod h1:n/CVRwUEOgIxrgPvAQhUUr9oeUtvrhMomdKFjzJNB0c= github.com/OneOfOne/xxhash v1.2.8 h1:31czK/TI9sNkxIKfaUfGlU47BAxQ0ztGgd9vPyqimf8= +github.com/OneOfOne/xxhash v1.2.8/go.mod h1:eZbhyaAYD41SGSSsnmcpxVoRiQ/MPUTjUdIIOT9Um7Q= github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= github.com/PuerkitoBio/purell v1.1.1 h1:WEQqlqaGbrPkxLJWfBwQmfEAE1Z7ONdDLqrN38tNFfI= github.com/PuerkitoBio/urlesc v0.0.0-20160726150825-5bd2802263f2/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= @@ -421,7 +427,9 @@ github.com/VividCortex/gohistogram v1.0.0/go.mod h1:Pf5mBqqDxYaXu3hDrrU+w6nw50o/ github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5 h1:rFw4nCn9iMW+Vajsk51NtYIcwSTkXr+JGrMd36kTDJw= github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5/go.mod h1:SkGFH1ia65gfNATL8TAiHDNxPzPdmEL5uirI2Uyuz6c= github.com/agnivade/levenshtein v1.1.1 h1:QY8M92nrzkmr798gCo3kmMyqXFzdQVpxLlGPRBij0P8= +github.com/agnivade/levenshtein v1.1.1/go.mod h1:veldBMzWxcCG2ZvUTKD2kJNRdCk5hVbJomOvKkmgYbo= github.com/ajeddeloh/go-json v0.0.0-20200220154158-5ae607161559 h1:4SPQljF/GJ8Q+QlCWMWxRBepub4DresnOm4eI2ebFGc= +github.com/ajeddeloh/go-json v0.0.0-20200220154158-5ae607161559/go.mod h1:otnto4/Icqn88WCcM4bhIJNSgsh9VLBuspyyCfvof9c= github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7 h1:uSoVVbwJiQipAclBbw+8quDsfcvFjOpI5iCf4p/cqCs= github.com/alcortesm/tgz v0.0.0-20161220082320-9c5fe88206d7/go.mod h1:6zEj6s6u/ghQa61ZWa/C2Aw3RkjiTBOix7dkqa1VLIs= github.com/alecthomas/kingpin v2.2.6+incompatible h1:5svnBTFgJjZvGKyYBtMB0+m5wvrbUHiqye8wRJMlnYI= @@ -440,16 +448,27 @@ github.com/alecthomas/units v0.0.0-20211218093645-b94a6e3cc137/go.mod h1:OMCwj8V github.com/alexflint/go-filemutex v0.0.0-20171022225611-72bdc8eae2ae/go.mod h1:CgnQgUtFrFz9mxFNtED3jI5tLDjKlOM+oUF/sTk6ps0= github.com/alexflint/go-filemutex v1.1.0/go.mod h1:7P4iRhttt/nUvUOrYIhcpMzv2G6CY9UnI16Z+UJqRyk= github.com/alibabacloud-go/alibabacloud-gateway-spi v0.0.4 h1:iC9YFYKDGEy3n/FtqJnOkZsene9olVspKmkX5A2YBEo= +github.com/alibabacloud-go/alibabacloud-gateway-spi v0.0.4/go.mod h1:sCavSAvdzOjul4cEqeVtvlSaSScfNsTQ+46HwlTL1hc= github.com/alibabacloud-go/cr-20160607 v1.0.1 h1:WEnP1iPFKJU74ryUKh/YDPHoxMZawqlPajOymyNAkts= +github.com/alibabacloud-go/cr-20160607 v1.0.1/go.mod h1:QHeKZtZ3F3FOE+/uIXCBAp8POwnUYekpLwr1dtQa5r0= github.com/alibabacloud-go/cr-20181201 v1.0.10 h1:B60f6S1imsgn2fgC6X6FrVNrONDrbCT0NwYhsJ0C9/c= +github.com/alibabacloud-go/cr-20181201 v1.0.10/go.mod h1:VN9orB/w5G20FjytoSpZROqu9ZqxwycASmGqYUJSoDc= github.com/alibabacloud-go/darabonba-openapi v0.1.18 h1:3eUVmAr7WCJp7fgIvmCd9ZUyuwtJYbtUqJIed5eXCmk= +github.com/alibabacloud-go/darabonba-openapi v0.1.18/go.mod h1:PB4HffMhJVmAgNKNq3wYbTUlFvPgxJpTzd1F5pTuUsc= github.com/alibabacloud-go/debug v0.0.0-20190504072949-9472017b5c68 h1:NqugFkGxx1TXSh/pBcU00Y6bljgDPaFdh5MUSeJ7e50= +github.com/alibabacloud-go/debug v0.0.0-20190504072949-9472017b5c68/go.mod h1:6pb/Qy8c+lqua8cFpEy7g39NRRqOWc3rOwAy8m5Y2BY= github.com/alibabacloud-go/endpoint-util v1.1.1 h1:ZkBv2/jnghxtU0p+upSU0GGzW1VL9GQdZO3mcSUTUy8= +github.com/alibabacloud-go/endpoint-util v1.1.1/go.mod h1:O5FuCALmCKs2Ff7JFJMudHs0I5EBgecXXxZRyswlEjE= github.com/alibabacloud-go/openapi-util v0.0.11 h1:iYnqOPR5hyEEnNZmebGyRMkkEJRWUEjDiiaOHZ5aNhA= +github.com/alibabacloud-go/openapi-util v0.0.11/go.mod h1:sQuElr4ywwFRlCCberQwKRFhRzIyG4QTP/P4y1CJ6Ws= github.com/alibabacloud-go/tea v1.1.18 h1:+6GJ06eu5Cr/Mkj09vWrf6QAfrPepctY2OxcWNclRC0= +github.com/alibabacloud-go/tea v1.1.18/go.mod h1:nXxjm6CIFkBhwW4FQkNrolwbfon8Svy6cujmKFUq98A= github.com/alibabacloud-go/tea-utils v1.4.4 h1:lxCDvNCdTo9FaXKKq45+4vGETQUKNOW/qKTcX9Sk53o= +github.com/alibabacloud-go/tea-utils v1.4.4/go.mod h1:KNcT0oXlZZxOXINnZBs6YvgOd5aYp9U67G+E3R8fcQw= github.com/alibabacloud-go/tea-xml v1.1.2 h1:oLxa7JUXm2EDFzMg+7oRsYc+kutgCVwm+bZlhhmvW5M= +github.com/alibabacloud-go/tea-xml v1.1.2/go.mod h1:Rq08vgCcCAjHyRi/M7xlHKUykZCEtyBy9+DPF6GgEu8= github.com/aliyun/credentials-go v1.2.3 h1:Vmodnr52Rz1mcbwn0kzMhLRKb6soizewuKXdfZiNemU= +github.com/aliyun/credentials-go v1.2.3/go.mod h1:/KowD1cfGSLrLsH28Jr8W+xwoId0ywIy5lNzDz6O1vw= github.com/andybalholm/brotli v1.0.1/go.mod h1:loMXtMfwqflxFJPmdbJO0a3KNoPuLBgiu3qAvBg8x/Y= github.com/andybalholm/brotli v1.0.4 h1:V7DdXeJtZscaqfNuAdSRuRFzuiKlHSC/Zh3zl9qY3JY= github.com/andybalholm/brotli v1.0.4/go.mod h1:fO7iG3H7G2nSZ7m0zPUDn85XEX2GTukHGRSepvi9Eig= @@ -488,6 +507,7 @@ github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5 github.com/armon/go-metrics v0.0.0-20180917152333-f0300d1749da/go.mod h1:Q73ZrmVTwzkszR9V5SSuryQ31EELlFMUz1kKyl939pY= github.com/armon/go-metrics v0.3.3/go.mod h1:4O98XIr/9W0sxpJ8UaYkvjk10Iff7SnFrb4QAOwNTFc= github.com/armon/go-metrics v0.4.0 h1:yCQqn7dwca4ITXb+CbubHmedzaQYHhNhrEXLYUeEe8Q= +github.com/armon/go-metrics v0.4.0/go.mod h1:E6amYzXo6aW1tqzoZGT755KkbgrJsSdpwZ+3JqfkOG4= github.com/armon/go-metrics v0.4.1 h1:hR91U9KYmb6bLBYLQjyM+3j+rcd/UhE+G78SFnF8gJA= 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= @@ -501,6 +521,7 @@ github.com/asaskevich/govalidator v0.0.0-20190424111038-f61b66f89f4a/go.mod h1:l github.com/asaskevich/govalidator v0.0.0-20210307081110-f21760c49a8d/go.mod h1:WaHUgvxTVq04UNunO+XhnAqY/wQc+bxr74GqbsZ/Jqw= github.com/aws/aws-lambda-go v1.13.3/go.mod h1:4UKl9IzQMoD+QF79YdCuzCwp8VbmG4VAQwij/eHl5CU= github.com/aws/aws-lambda-go v1.28.0 h1:fZiik1PZqW2IyAN4rj+Y0UBaO1IDFlsNo9Zz/XnArK4= +github.com/aws/aws-lambda-go v1.28.0/go.mod h1:jJmlefzPfGnckuHdXX7/80O3BvUUi12XOkbv4w9SGLU= github.com/aws/aws-sdk-go v1.15.11/go.mod h1:mFuSZ37Z9YOHbQEwBWztmVzqXrEkub65tZoCYDt7FT0= github.com/aws/aws-sdk-go v1.15.27/go.mod h1:mFuSZ37Z9YOHbQEwBWztmVzqXrEkub65tZoCYDt7FT0= github.com/aws/aws-sdk-go v1.19.18/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo= @@ -520,15 +541,22 @@ github.com/aws/aws-sdk-go v1.44.257/go.mod h1:aVsgQcEevwlmQ7qHE9I3h+dtQgpqhFB+i8 github.com/aws/aws-sdk-go v1.44.259/go.mod h1:aVsgQcEevwlmQ7qHE9I3h+dtQgpqhFB+i8Phjh7fkwI= github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g= github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.4.3 h1:S/ZBwevQkr7gv5YxONYpGQxlMFFYSRfz3RMcjsC9Qhk= +github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.4.3/go.mod h1:gNsR5CaXKmQSSzrmGxmwmct/r+ZBfbxorAuXYsj/M5Y= github.com/aws/aws-sdk-go-v2/internal/v4a v1.0.5 h1:tEEHn+PGAxRVqMPEhtU8oCSW/1Ge3zP5nUgPrGQNUPs= +github.com/aws/aws-sdk-go-v2/internal/v4a v1.0.5/go.mod h1:aIwFF3dUk95ocCcA3zfk3nhz0oLkpzHFWuMp8l/4nNs= github.com/aws/aws-sdk-go-v2/service/internal/accept-encoding v1.9.3 h1:4n4KCtv5SUoT5Er5XV41huuzrCqepxlW3SDI9qHQebc= +github.com/aws/aws-sdk-go-v2/service/internal/accept-encoding v1.9.3/go.mod h1:gkb2qADY+OHaGLKNTYxMaQNacfeyQpZ4csDTQMeFmcw= github.com/aws/aws-sdk-go-v2/service/internal/checksum v1.1.9 h1:gVv2vXOMqJeR4ZHHV32K7LElIJIIzyw/RU1b0lSfWTQ= +github.com/aws/aws-sdk-go-v2/service/internal/checksum v1.1.9/go.mod h1:EF5RLnD9l0xvEWwMRcktIS/dI6lF8lU5eV3B13k6sWo= github.com/aws/aws-sdk-go-v2/service/internal/s3shared v1.13.8 h1:TlN1UC39A0LUNoD51ubO5h32haznA+oVe15jO9O4Lj0= +github.com/aws/aws-sdk-go-v2/service/internal/s3shared v1.13.8/go.mod h1:JlVwmWtT/1c5W+6oUsjXjAJ0iJZ+hlghdrDy/8JxGCU= github.com/aws/aws-sdk-go-v2/service/kms v1.21.1/go.mod h1:EEfb4gfSphdVpRo5sGf2W3KvJbelYUno5VaXR5MJ3z4= github.com/aws/aws-sdk-go-v2/service/s3 v1.27.1 h1:OKQIQ0QhEBmGr2LfT952meIZz3ujrPYnxH+dO/5ldnI= +github.com/aws/aws-sdk-go-v2/service/s3 v1.27.1/go.mod h1:NffjpNsMUFXp6Ok/PahrktAncoekWrywvmIK83Q2raE= github.com/aybabtme/rgbterm v0.0.0-20170906152045-cc83f3b3ce59 h1:WWB576BN5zNSZc/M9d/10pqEx5VHNhaQ/yOVAkmj5Yo= github.com/aybabtme/rgbterm v0.0.0-20170906152045-cc83f3b3ce59/go.mod h1:q/89r3U2H7sSsE2t6Kca0lfwTK8JdoNGS/yzM/4iH5I= github.com/beeker1121/goque v1.0.3-0.20191103205551-d618510128af h1:XbgLdZvVbWsK9HAhAYOp6rksTAdOVYDBQtGSVOLlJrw= +github.com/beeker1121/goque v1.0.3-0.20191103205551-d618510128af/go.mod h1:84CWnaDz4g1tEVnFLnuBigmGK15oPohy0RfvSN8d4eg= github.com/beevik/ntp v0.3.0 h1:xzVrPrE4ziasFXgBVBZJDP0Wg/KpMwk2KHJ4Ba8GrDw= github.com/beevik/ntp v1.0.0 h1:d0Lgy1xbNNqVyGfvg2Z96ItKcfyn3lzgus/oRoj9vnk= github.com/beevik/ntp v1.0.0/go.mod h1:JN7/74B0Z4GUGO/1aUeRI2adARlfJGUeaJb0y0Wvnf4= @@ -549,6 +577,7 @@ github.com/blang/semver v3.1.0+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnweb github.com/blang/semver/v4 v4.0.0 h1:1PFHFE6yCCTv8C1TeyNNarDzntLi7wMI5i/pzqYIsAM= github.com/blang/semver/v4 v4.0.0/go.mod h1:IbckMUScFkM3pff0VJDNKRiT6TG/YpiHIM2yvyW5YoQ= github.com/bmatcuk/doublestar v1.2.1 h1:eetYiv8DDYOZcBADY+pRvRytf3Dlz1FhnpvL2FsClBc= +github.com/bmatcuk/doublestar v1.2.1/go.mod h1:wiQtGV+rzVYxB7WIlirSN++5HPtPlXEo9MEoZQC/PmE= github.com/bmizerany/assert v0.0.0-20160611221934-b7ed37b82869/go.mod h1:Ekp36dRnpXw/yCqJaO+ZrUyxD+3VXMFFr56k5XYrpB4= github.com/bshuster-repo/logrus-logstash-hook v0.4.1/go.mod h1:zsTqEiSzDgAa/8GZR7E1qaXrhYNDKBYy5/dWPTIflbk= github.com/buger/jsonparser v0.0.0-20180808090653-f4dd9f5a6b44/go.mod h1:bbYlZJ7hK1yFx9hf58LP0zeX7UjIGs20ufpu3evjr+s= @@ -558,6 +587,7 @@ github.com/bugsnag/osext v0.0.0-20130617224835-0dd3f918b21b/go.mod h1:obH5gd0Bsq github.com/bugsnag/panicwrap v0.0.0-20151223152923-e2c28503fcd0/go.mod h1:D/8v3kj0zr8ZAKg1AQ6crr+5VwKN5eIywRkfhyM/+dE= github.com/buildkite/agent/v3 v3.45.0 h1:LEHtJSE0q2ZGsBb5yvhVr53+pRHCHLrENT4WR4nEy70= github.com/buildkite/agent/v3 v3.46.1 h1:M6Q1IlMSdF55HmVMg8PzovhwzTAHF21eppN7JjR4FmI= +github.com/buildkite/agent/v3 v3.46.1/go.mod h1:cOaDfQpz1a0icTRoXJp7Aoi/bbcEsh8kn4ZxS+QTO0o= github.com/bwesterb/go-ristretto v1.2.0 h1:xxWOVbN5m8NNKiSDZXE1jtZvZnC6JSJ9cYFADiZcWtw= github.com/bwesterb/go-ristretto v1.2.3 h1:1w53tCkGhCQ5djbat3+MH0BAQ5Kfgbt56UZQ/JMzngw= github.com/bwesterb/go-ristretto v1.2.3/go.mod h1:fUIoIZaG73pV5biE2Blr2xEzDoMj7NFEuV9ekS419A0= @@ -568,9 +598,11 @@ github.com/campoy/unique v0.0.0-20180121183637-88950e537e7e/go.mod h1:9IOqJGCPMS github.com/casbin/casbin/v2 v2.1.2 h1:bTwon/ECRx9dwBy2ewRVr5OiqjeXSGiTUY74sDPQi/g= github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ= github.com/cavaliercoder/badio v0.0.0-20160213150051-ce5280129e9e h1:YYUjy5BRwO5zPtfk+aa2gw255FIIoi93zMmuy19o0bc= +github.com/cavaliercoder/badio v0.0.0-20160213150051-ce5280129e9e/go.mod h1:V284PjgVwSk4ETmz84rpu9ehpGg7swlIH8npP9k2bGw= github.com/cavaliercoder/go-cpio v0.0.0-20180626203310-925f9528c45e h1:hHg27A0RSSp2Om9lubZpiMgVbvn39bsUmW9U5h0twqc= github.com/cavaliercoder/go-cpio v0.0.0-20180626203310-925f9528c45e/go.mod h1:oDpT4efm8tSYHXV5tHSdRvBet/b/QzxZ+XyyPehvm3A= github.com/cavaliercoder/go-rpm v0.0.0-20200122174316-8cb9fd9c31a8 h1:jP7ki8Tzx9ThnFPLDhBYAhEpI2+jOURnHQNURgsMvnY= +github.com/cavaliercoder/go-rpm v0.0.0-20200122174316-8cb9fd9c31a8/go.mod h1:AZIh1CCnMrcVm6afFf96PBvE2MRpWFco91z8ObJtgDY= github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM= github.com/cenkalti/backoff/v3 v3.2.2/go.mod h1:cIeZDE3IrqwwJl6VUwCN6trj1oXrTS4rc0ij+ULvLYs= github.com/cenkalti/backoff/v4 v4.1.1 h1:G2HAfAmvm/GcKan2oOQpBXOd2tT2G57ZnZGWa1PxPBQ= @@ -614,6 +646,7 @@ github.com/cilium/ebpf v0.7.0/go.mod h1:/oI2+1shJiTGAMgl6/RgJr36Eo1jzrRcAWbcXO2u github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6Dob7S7YxXgwXpfOuvO54S+tGdZdw9fuRZt25Ag= github.com/circonus-labs/circonusllhist v0.1.3/go.mod h1:kMXHVDlOchFAehlya5ePtbp5jckzBHf4XRpQvBOLI+I= github.com/clbanning/mxj/v2 v2.5.6 h1:Jm4VaCI/+Ug5Q57IzEoZbwx4iQFA6wkXv72juUSeK+g= +github.com/clbanning/mxj/v2 v2.5.6/go.mod h1:hNiWqW14h+kc+MdF9C6/YoRfjEJoR3ou6tn/Qo+ve2s= github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec h1:EdRZT3IeKQmfCSrgo8SZ8V3MEnskuJP0wCYNpe+aiXo= github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec/go.mod h1:jMjuTZXRI4dUb/I5gc9Hdhagfvm9+RyrPryS/auMzxE= github.com/client9/misspell v0.3.4 h1:ta993UF76GwbvJcIo3Y68y/M3WxlpEHPWIGDkJYwzJI= @@ -628,6 +661,7 @@ github.com/cncf/xds/go v0.0.0-20230310173818-32f1caf87195/go.mod h1:eXthEFrGJvWH github.com/cockroachdb/apd v1.1.0/go.mod h1:8Sl8LxpKi29FqWXR16WEFZRNSz3SoPzUzeMeY4+DwBQ= github.com/cockroachdb/apd/v2 v2.0.1 h1:y1Rh3tEU89D+7Tgbw+lp52T6p/GJLpDmNvr10UWqLTE= github.com/cockroachdb/apd/v2 v2.0.2 h1:weh8u7Cneje73dDh+2tEVLUvyBc89iwepWCD8b8034E= +github.com/cockroachdb/apd/v2 v2.0.2/go.mod h1:DDxRlzC2lo3/vSlmSoS7JkqbbrARPuFOGr0B9pvN3Gw= github.com/cockroachdb/cockroach-go/v2 v2.2.19 h1:YIHyz17jZumBeXPuoZKq/0nrITsqDoDD8/KQt3/xiyc= github.com/cockroachdb/cockroach-go/v2 v2.2.19/go.mod h1:mzlIDDBALQfEjv/7DU12fb2AfQ/MUYTlychcMpWp9QI= github.com/cockroachdb/cockroach-go/v2 v2.3.3 h1:fNmtG6XhoA1DhdDCIu66YyGSsNb1szj4CaAsbDxRmy4= @@ -638,6 +672,7 @@ github.com/cockroachdb/errors v1.2.4/go.mod h1:rQD95gz6FARkaKkQXUksEje/d9a6wBJoC github.com/cockroachdb/logtags v0.0.0-20190617123548-eb05cc24525f/go.mod h1:i/u985jwjWRlyHXQbwatDASoW0RMlZ/3i9yJHE2xLkI= github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd h1:qMd81Ts1T2OTKmB4acZcyKaMtRnY5Y44NuXGX2GFJ1w= github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd/go.mod h1:sE/e/2PUdi/liOCUjSTXgM1o87ZssimdTWN964YiIeI= +github.com/codahale/rfc6979 v0.0.0-20141003034818-6a90f24967eb/go.mod h1:ZjrT6AXHbDs86ZSdt/osfBi5qfexBrKUdONk989Wnk4= github.com/common-nighthawk/go-figure v0.0.0-20210622060536-734e95fb86be h1:J5BL2kskAlV9ckgEsNQXscjIaLiOYiZ75d4e94E6dcQ= github.com/common-nighthawk/go-figure v0.0.0-20210622060536-734e95fb86be/go.mod h1:mk5IQ+Y0ZeO87b858TlA645sVcEcbiX6YqP98kt+7+w= github.com/containerd/aufs v0.0.0-20200908144142-dab0cbea06f4/go.mod h1:nukgQABAEopAHvB6j7cnP5zJ+/3aVcE7hCYqvIwAHyE= @@ -737,8 +772,10 @@ github.com/containers/ocicrypt v1.1.0/go.mod h1:b8AOe0YR67uU8OqfVNcznfFpAzu3rdgU github.com/containers/ocicrypt v1.1.1/go.mod h1:Dm55fwWm1YZAjYRaJ94z2mfZikIyIN4B0oB3dj3jFxY= github.com/containers/ocicrypt v1.1.2/go.mod h1:Dm55fwWm1YZAjYRaJ94z2mfZikIyIN4B0oB3dj3jFxY= github.com/coredns/caddy v1.1.1 h1:2eYKZT7i6yxIfGP3qLJoJ7HAsDJqYB+X68g4NYjSrE0= +github.com/coredns/caddy v1.1.1/go.mod h1:A6ntJQlAWuQfFlsd9hvigKbo2WS0VUs2l1e2F+BawD4= github.com/coredns/corefile-migration v1.0.18 h1:zs5PJm/VGZVje1ESRj6ZqyUuVsVfagExkbLU2QKV5mI= github.com/coredns/corefile-migration v1.0.20 h1:MdOkT6F3ehju/n9tgxlGct8XAajOX2vN+wG7To4BWSI= +github.com/coredns/corefile-migration v1.0.20/go.mod h1:XnhgULOEouimnzgn0t4WPuFDN2/PJQcTxdWKC5eXNGE= github.com/coreos/bbolt v1.3.2 h1:wZwiHHUieZCquLkDL0B8UhzreNWsPHooDAG3q34zk0s= github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk= github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= @@ -751,6 +788,7 @@ github.com/coreos/go-iptables v0.5.0/go.mod h1:/mVI274lEDI2ns62jHCDnCyBF9Iwsmeka github.com/coreos/go-iptables v0.6.0/go.mod h1:Qe8Bv2Xik5FyTXwgIbLAnv2sWSBmvWdFETJConOQ//Q= github.com/coreos/go-oidc v2.1.0+incompatible/go.mod h1:CgnwVTmzoESiwO9qyAFEMiHoZ1nMCKZlZ9V6mm3/LKc= github.com/coreos/go-oidc v2.2.1+incompatible h1:mh48q/BqXqgjVHpy2ZY7WnWAbenxRjsz9N1i1YxjHAk= +github.com/coreos/go-oidc v2.2.1+incompatible/go.mod h1:CgnwVTmzoESiwO9qyAFEMiHoZ1nMCKZlZ9V6mm3/LKc= github.com/coreos/go-oidc/v3 v3.5.0 h1:VxKtbccHZxs8juq7RdJntSqtXFtde9YpNpGn0yqgEHw= github.com/coreos/go-oidc/v3 v3.5.0/go.mod h1:ecXRtV4romGPeO6ieExAsUK9cb/3fp9hXNz1tlv8PIM= github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= @@ -762,6 +800,7 @@ github.com/coreos/go-systemd v0.0.0-20190321100706-95778dfbb74e/go.mod h1:F5haX7 github.com/coreos/go-systemd v0.0.0-20190620071333-e64a0ec8b42a/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= github.com/coreos/go-systemd v0.0.0-20190719114852-fd7a80b32e1f/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf h1:iW4rZ826su+pqaw19uhpSCzhj44qo35pNgKFGqzDKkU= +github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= github.com/coreos/go-systemd/v22 v22.0.0/go.mod h1:xO0FLkIi5MaZafQlIrOotqXZ90ih+1atmu1JpKERPPk= github.com/coreos/go-systemd/v22 v22.1.0/go.mod h1:xO0FLkIi5MaZafQlIrOotqXZ90ih+1atmu1JpKERPPk= github.com/coreos/go-systemd/v22 v22.3.2 h1:D9/bQk5vlXQFZ6Kwuu6zaiXJ9oTPe68++AzAJc1DzSI= @@ -783,6 +822,7 @@ github.com/d2g/dhcp4client v1.0.0/go.mod h1:j0hNfjhrt2SxUOw55nL0ATM/z4Yt3t2Kd1mW github.com/d2g/dhcp4server v0.0.0-20181031114812-7d4a0a7f59a5/go.mod h1:Eo87+Kg/IX2hfWJfwxMzLyuSZyxSoAug2nGa1G2QAi8= github.com/d2g/hardwareaddr v0.0.0-20190221164911-e7d9fbe030e4/go.mod h1:bMl4RjIciD2oAxI7DmWRx6gbeqrkoLqv3MV0vzNad+I= github.com/danieljoos/wincred v1.1.2 h1:QLdCxFs1/Yl4zduvBdcHB8goaYk9RARS2SgLLRuAyr0= +github.com/danieljoos/wincred v1.1.2/go.mod h1:GijpziifJoIBfYh+S7BbkdUTU4LfM+QnGqR5Vl2tAx0= github.com/davecgh/go-spew v0.0.0-20161028175848-04cdfd42973b/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/daviddengcn/go-colortext v0.0.0-20160507010035-511bcaf42ccd h1:uVsMphB1eRx7xB1njzL3fuMdWRN8HtVzoUOItHMwv5c= github.com/daviddengcn/go-colortext v1.0.0 h1:ANqDyC0ys6qCSvuEK7l3g5RaehL/Xck9EX8ATG8oKsE= @@ -790,13 +830,16 @@ github.com/daviddengcn/go-colortext v1.0.0/go.mod h1:zDqEI5NVUop5QPpVJUxE9UO10hR github.com/dennwc/varint v1.0.0/go.mod h1:hnItb35rvZvJrbTALZtY/iQfDs48JKRG1RPpgziApxA= github.com/denverdino/aliyungo v0.0.0-20190125010748-a747050bb1ba/go.mod h1:dV8lFg6daOBZbT6/BDGIz6Y3WFGn8juu6G+CQ6LHtl0= github.com/depcheck-test/depcheck-test v0.0.0-20220607135614-199033aaa936 h1:foGzavPWwtoyBvjWyKJYDYsyzy+23iBV7NKTwdk+LRY= +github.com/depcheck-test/depcheck-test v0.0.0-20220607135614-199033aaa936/go.mod h1:ttKPnOepYt4LLzD+loXQ1rT6EmpyIYHro7TAJuIIlHo= github.com/devigned/tab v0.1.1 h1:3mD6Kb1mUOYeLpJvTVSDwSg5ZsfSxfvxGRTxRsJsITA= github.com/devigned/tab v0.1.1/go.mod h1:XG9mPq0dFghrYvoBF3xdRrJzSTX1b7IQrvaL9mzjeJY= github.com/dgraph-io/ristretto v0.1.0 h1:Jv3CGQHp9OjuMBSne1485aDpUkTKEcUqF+jm/LuerPI= +github.com/dgraph-io/ristretto v0.1.0/go.mod h1:fux0lOrBhrVCJd3lcTHsIJhq1T2rokOu6v9Vcb3Q9ug= github.com/dgrijalva/jwt-go v0.0.0-20170104182250-a601269ab70c/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ= github.com/dgrijalva/jwt-go v3.2.0+incompatible h1:7qlOGliEKZXTDg6OTjfoBKDXWrumCAMpl/TFQ4/5kLM= github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ= github.com/dgryski/go-rendezvous v0.0.0-20200823014737-9f7001d12a5f h1:lO4WD4F/rVNCu3HqELle0jiPLLBs70cWOduZpkS1E78= +github.com/dgryski/go-rendezvous v0.0.0-20200823014737-9f7001d12a5f/go.mod h1:cuUVRXasLTGF7a8hSLbxyZXjz+1KgoB3wDUb6vlszIc= github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954 h1:RMLoZVzv4GliuWafOuPuQDKSm1SJph7uCRnnS61JAn4= github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no= github.com/dgryski/go-sip13 v0.0.0-20200911182023-62edffca9245/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no= @@ -824,6 +867,7 @@ github.com/docker/libtrust v0.0.0-20150114040149-fa567046d9b1/go.mod h1:cyGadeNE github.com/docker/spdystream v0.0.0-20160310174837-449fdfce4d96/go.mod h1:Qh8CwZgvJUkLughtfhJv5dyTYa91l1fOUCrgjqmcifM= github.com/docopt/docopt-go v0.0.0-20180111231733-ee0de3bc6815 h1:bWDMxwH3px2JBh6AyO7hdCn/PkvCZXii8TGj7sbtEbQ= github.com/drone/envsubst/v2 v2.0.0-20210730161058-179042472c46 h1:7QPwrLT79GlD5sizHf27aoY2RTvw62mO6x7mxkScNk0= +github.com/drone/envsubst/v2 v2.0.0-20210730161058-179042472c46/go.mod h1:esf2rsHFNlZlxsqsZDojNBcnNs5REqIvRrWRHqX0vEU= github.com/dsnet/compress v0.0.2-0.20210315054119-f66993602bf5/go.mod h1:qssHWj60/X5sZFNxpG4HBPDHVqxNm4DfnCKgrbZOT+s= github.com/dsnet/golib v0.0.0-20171103203638-1ea166775780/go.mod h1:Lj+Z9rebOhdfkVLjJ8T6VcRQv3SXugXy999NBtR9aFY= github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= @@ -838,6 +882,7 @@ github.com/edsrzf/mmap-go v1.0.0 h1:CEBF7HpRnUCSJgGUb5h1Gm7e3VkmVDrR8lvWVLtrOFw= github.com/edsrzf/mmap-go v1.0.0/go.mod h1:YO35OhQPt3KJa3ryjFM5Bs14WD66h8eGKpfaBNrHW5M= github.com/edsrzf/mmap-go v1.1.0/go.mod h1:19H/e8pUPLicwkyNgOykDXkJ9F0MHE+Z52B8EIth78Q= github.com/eggsampler/acme/v3 v3.3.0 h1:5M7vwYRy65iPpCFHZ01RyWXmYT8e8MlcWn/9BUUB7Ro= +github.com/eggsampler/acme/v3 v3.3.0/go.mod h1:/qh0rKC/Dh7Jj+p4So7DbWmFNzC4dpcpK53r226Fhuo= github.com/elazarl/goproxy v0.0.0-20180725130230-947c36da3153 h1:yUdfgN0XgIJw7foRItutHYUIhlcKzcSf5vDpdhQAKTc= github.com/elazarl/goproxy v0.0.0-20180725130230-947c36da3153/go.mod h1:/Zj4wYkgs4iZTTu3o/KG3Itv/qCCa8VVMlb3i9OVuzc= github.com/emicklei/go-restful v0.0.0-20170410110728-ff4f55a20633/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= @@ -848,6 +893,7 @@ github.com/emicklei/go-restful/v3 v3.8.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry github.com/emicklei/go-restful/v3 v3.10.1/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= github.com/emicklei/proto v1.6.15 h1:XbpwxmuOPrdES97FrSfpyy67SSCV/wBIKXqgJzh6hNw= github.com/emicklei/proto v1.10.0 h1:pDGyFRVV5RvV+nkBK9iy3q67FBy9Xa7vwrOTE+g5aGw= +github.com/emicklei/proto v1.10.0/go.mod h1:rn1FgRS/FANiZdD2djyH7TMA9jdRDcYQ9IEN9yvjX0A= github.com/emirpasic/gods v1.12.0 h1:QAUIPSaCu4G+POclxeqb3F+WPpdKqFGlw36+yOzGlrg= github.com/emirpasic/gods v1.12.0/go.mod h1:YfzfFFoVP/catgzJb4IKIqXjX78Ha8FMSDh3ymbK86o= github.com/envoyproxy/go-control-plane v0.6.9/go.mod h1:SBwIajubJHhxtWwsL9s8ss4safvEdbitLhGGK48rN6g= @@ -869,7 +915,12 @@ github.com/evanphx/json-patch v4.9.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLi github.com/evanphx/json-patch v4.11.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= github.com/evanphx/json-patch v4.12.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= github.com/exponent-io/jsonpath v0.0.0-20151013193312-d6023ce2651d h1:105gxyaGwCFad8crR9dcMQWvV9Hvulu6hwUh4tWPJnM= +github.com/exponent-io/jsonpath v0.0.0-20151013193312-d6023ce2651d/go.mod h1:ZZMPRZwes7CROmyNKgQzC3XPs6L/G2EJLHddWejkmf4= +github.com/facebookgo/clock v0.0.0-20150410010913-600d898af40a/go.mod h1:7Ga40egUymuWXxAe151lTNnCv97MddSOVsjpPPkityA= +github.com/facebookgo/limitgroup v0.0.0-20150612190941-6abd8d71ec01/go.mod h1:ypD5nozFk9vcGw1ATYefw6jHe/jZP++Z15/+VTMcWhc= +github.com/facebookgo/muster v0.0.0-20150708232844-fd3d7953fd52/go.mod h1:yIquW87NGRw1FU5p5lEkpnt/QxoH5uPAOUlOVkAUuMg= github.com/fatih/camelcase v1.0.0 h1:hxNvNX/xYBp0ovncs8WyWZrOrpBNub/JfaMvbURyft8= +github.com/fatih/camelcase v1.0.0/go.mod h1:yN2Sb0lFhZJUdVvtELVWefmrXpuZESvPmqwoZc+/fpc= github.com/fatih/color v1.9.0/go.mod h1:eQcE1qtQxscV5RaZvpXrrb8Drkc3/DdQ+uUYCNjL+zU= github.com/fatih/color v1.13.0/go.mod h1:kLAiJbzzSOZDVNGyDpeOxJ47H46qBXwg5ILebYFFOfk= github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= @@ -877,9 +928,12 @@ github.com/felixge/httpsnoop v1.0.2/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSw github.com/felixge/httpsnoop v1.0.3 h1:s/nj+GCswXYzN5v2DpNMuMQYe+0DDwt5WVCU6CWBdXk= github.com/felixge/httpsnoop v1.0.3/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= github.com/flatcar/container-linux-config-transpiler v0.9.4 h1:yXQ0NB8PeNrKJPrZvbv5/DV63PNhTqt8vaf8YxmX/RA= +github.com/flatcar/container-linux-config-transpiler v0.9.4/go.mod h1:LxanhPvXkWgHG9PrkT4rX/p7YhUPdDGGsUdkNpV3L5U= github.com/flatcar/ignition v0.36.2 h1:xGHgScUe0P4Fkprjqv7L2CE58emiQgP833OCCn9z2v4= +github.com/flatcar/ignition v0.36.2/go.mod h1:uk1tpzLFRXus4RrvzgMI+IqmmB8a/RGFSBlI+tMTbbA= github.com/flowstack/go-jsonschema v0.1.1 h1:dCrjGJRXIlbDsLAgTJZTjhwUJnnxVWl1OgNyYh5nyDc= github.com/flynn/go-docopt v0.0.0-20140912013429-f6dd2ebbb31e h1:Ss/B3/5wWRh8+emnK0++g5zQzwDTi30W10pKxKc4JXI= +github.com/flynn/go-docopt v0.0.0-20140912013429-f6dd2ebbb31e/go.mod h1:HyVoz1Mz5Co8TFO8EupIdlcpwShBmY98dkT2xeHkvEI= github.com/flynn/go-shlex v0.0.0-20150515145356-3f9db97f8568 h1:BHsljHzVlRcyQhjrss6TZTdY2VfCqZPbv5k3iBFa2ZQ= github.com/flynn/go-shlex v0.0.0-20150515145356-3f9db97f8568/go.mod h1:xEzjJPgXI435gkrCt3MPfRiAkVrwSbHsst4LCFVfpJc= github.com/form3tech-oss/jwt-go v3.2.2+incompatible/go.mod h1:pbq4aXjuKjdthFRnoDwaVPLA+WlJuPGy+QneDUgJi2k= @@ -905,7 +959,9 @@ github.com/fullstorydev/grpcurl v1.8.2/go.mod h1:YvWNT3xRp2KIRuvCphFodG0fKkMXwax github.com/fullstorydev/grpcurl v1.8.7 h1:xJWosq3BQovQ4QrdPO72OrPiWuGgEsxY8ldYsJbPrqI= github.com/fullstorydev/grpcurl v1.8.7/go.mod h1:pVtM4qe3CMoLaIzYS8uvTuDj2jVYmXqMUkZeijnXp/E= github.com/fvbommel/sortorder v1.0.1 h1:dSnXLt4mJYH25uDDGa3biZNQsozaUWDSWeKJ0qqFfzE= +github.com/fvbommel/sortorder v1.0.1/go.mod h1:uk88iVf1ovNn1iLfgUVU2F9o5eO30ui720w+kxuqRs0= github.com/fxamacker/cbor/v2 v2.4.0 h1:ri0ArlOR+5XunOP8CRUowT0pSJOwhW098ZCUyskZD88= +github.com/fxamacker/cbor/v2 v2.4.0/go.mod h1:TA1xS00nchWmaBnEIxPSE5oHLuJBAVvqrtAnWBwBCVo= github.com/garyburd/redigo v0.0.0-20150301180006-535138d7bcd7/go.mod h1:NR3MbYisc3/PwhQ00EMzDiPmrwpPxAn5GI05/YaO1SY= github.com/getkin/kin-openapi v0.76.0 h1:j77zg3Ec+k+r+GA3d8hBoXpAc6KX9TbBPrwQGBIy2sY= github.com/getkin/kin-openapi v0.76.0/go.mod h1:660oXbgy5JFMKreazJaQTw7o+X00qeSyhcnluiMv+Xg= @@ -917,13 +973,16 @@ github.com/gin-gonic/gin v1.5.0/go.mod h1:Nd6IXA8m5kNZdNEHMBd93KT+mdY3+bewLgRvmC github.com/gliderlabs/ssh v0.2.2 h1:6zsha5zo/TWhRhwqCD3+EarCAgZ2yN28ipRnGPnwkI0= github.com/gliderlabs/ssh v0.2.2/go.mod h1:U7qILu1NlMHj9FlMhZLlkCdDnU1DBEAqr0aevW3Awn0= github.com/go-asn1-ber/asn1-ber v1.5.4 h1:vXT6d/FNDiELJnLb6hGNa309LMsrCoYFvpwHDF0+Y1A= +github.com/go-asn1-ber/asn1-ber v1.5.4/go.mod h1:hEBeB/ic+5LoWskz+yKT7vGhhPYkProFKoKdwZRWMe0= github.com/go-errors/errors v1.0.1 h1:LUHzmkK3GUKUrL/1gfBUxAHzcev3apQlezX/+O7ma6w= +github.com/go-errors/errors v1.0.1/go.mod h1:f4zRHt4oKfwPJE5k8C9vpYG+aDHdBFUsgrm6/TyX73Q= github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1 h1:QbL/5oDUmRBzO9/Z7Seo6zf912W/a6Sr4Eu0G/3Jho0= github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU= github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4 h1:WtGNWLvXpe6ZudgnXrq0barxBImvnnJoMEhXAzcbM0I= github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= github.com/go-gorp/gorp/v3 v3.0.2 h1:ULqJXIekoqMx29FI5ekXXFoH1dT2Vc8UhnRzBg+Emz4= +github.com/go-gorp/gorp/v3 v3.0.2/go.mod h1:BJ3q1ejpV8cVALtcXvXaXyTOlMmJhWDxTmncaR6rwBY= github.com/go-ini/ini v1.25.4 h1:Mujh4R/dH6YL8bxuISne3xX2+qcQ9p0IxKAP6ExWoUo= github.com/go-ini/ini v1.25.4/go.mod h1:ByCAeIL28uOIIG0E3PJtZPDL8WnHpFKFOtgjp+3Ies8= github.com/go-jose/go-jose/v3 v3.0.0/go.mod h1:RNkWWRld676jZEYoV3+XK8L2ZnNSvIsxFMht0mSX+u8= @@ -937,6 +996,7 @@ github.com/go-kit/log v0.2.0/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBj github.com/go-kit/log v0.2.1 h1:MRVx0/zhvdseW+Gza6N9rVzU/IVzaeE1SFI4raAhmBU= github.com/go-kit/log v0.2.1/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBjv0= github.com/go-ldap/ldap/v3 v3.4.4 h1:qPjipEpt+qDa6SI/h1fzuGWoRUY+qqQ9sOZq67/PYUs= +github.com/go-ldap/ldap/v3 v3.4.4/go.mod h1:fe1MsuN5eJJ1FeLT/LEBVdWfNWKh459R7aXgXtJC+aI= github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE= github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk= github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A= @@ -969,6 +1029,7 @@ github.com/go-piv/piv-go v1.10.0 h1:P1Y1VjBI5DnXW0+YkKmTuh5opWnMIrKriUaIOblee9Q= github.com/go-piv/piv-go v1.11.0 h1:5vAaCdRTFSIW4PeqMbnsDlUZ7odMYWnHBDGdmtU/Zhg= github.com/go-piv/piv-go v1.11.0/go.mod h1:NZ2zmjVkfFaL/CF8cVQ/pXdXtuj110zEKGdJM6fJZZM= github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= +github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= github.com/go-playground/locales v0.12.1/go.mod h1:IUMDtCfWo/w/mtMfIE/IG2K+Ey3ygWanZIBtBW0W2TM= github.com/go-playground/locales v0.13.0/go.mod h1:taPMhCMXrRLJO55olJkUXHZBHCxTMfnGwq/HNwmWNS8= github.com/go-playground/universal-translator v0.16.0/go.mod h1:1AnU7NaIRDWWzGEKwgtJRd2xk99HeFyHw3yid4rvQIY= @@ -978,7 +1039,9 @@ github.com/go-redis/redis v6.15.8+incompatible/go.mod h1:NAIEuMOZ/fxfXJIrKDQDz8w github.com/go-redis/redis v6.15.9+incompatible h1:K0pv1D7EQUjfyoMql+r/jZqCLizCGKFlFgcHWWmHQjg= github.com/go-redis/redis v6.15.9+incompatible/go.mod h1:NAIEuMOZ/fxfXJIrKDQDz8wamY7mA7PouImQ2Jvg6kA= github.com/go-redis/redis/v8 v8.11.5 h1:AcZZR7igkdvfVmQTPnu9WE37LRrO/YrBH5zWyjDC0oI= +github.com/go-redis/redis/v8 v8.11.5/go.mod h1:gREzHqY1hg6oD9ngVRbLStwAWKhA0FEgq8Jd4h5lpwo= github.com/go-redis/redismock/v9 v9.0.3 h1:mtHQi2l51lCmXIbTRTqb1EiHYe9tL5Yk5oorlSJJqR0= +github.com/go-redis/redismock/v9 v9.0.3/go.mod h1:F6tJRfnU8R/NZ0E+Gjvoluk14MqMC5ueSZX6vVQypc0= github.com/go-resty/resty/v2 v2.1.1-0.20191201195748-d7b97669fe48/go.mod h1:dZGr0i9PLlaaTD4H/hoZIDjQ+r6xq8mgbRzHZf7f2J8= github.com/go-rod/rod v0.112.8 h1:lYFnHv/lFyjW/Ye0IhyKLeHw/zfhHbSTqawoCi2z/nI= github.com/go-rod/rod v0.112.9 h1:uA/yLbB+t0UlqJcLJtK2pZrCNPzd15dOKRUEOnmnt9k= @@ -1000,6 +1063,7 @@ github.com/gobuffalo/depgen v0.1.0 h1:31atYa/UW9V5q8vMJ+W6wd64OaaTHUrCUXER358zLM github.com/gobuffalo/envy v1.7.0 h1:GlXgaiBkmrYMHco6t4j7SacKO4XUjvh5pwXh0f4uxXU= github.com/gobuffalo/flect v0.2.5 h1:H6vvsv2an0lalEaCDRThvtBfmg44W/QHXBCYUXf/6S4= github.com/gobuffalo/flect v1.0.2 h1:eqjPGSo2WmjgY2XlpGwo2NXgL3RucAKo4k4qQMNA5sA= +github.com/gobuffalo/flect v1.0.2/go.mod h1:A5msMlrHtLqh9umBSnvabjsMrCcCpAyzglnDvkbYKHs= github.com/gobuffalo/genny v0.1.1 h1:iQ0D6SpNXIxu52WESsD+KoQ7af2e3nCfnSBoSF/hKe0= github.com/gobuffalo/gitgen v0.0.0-20190315122116-cc086187d211 h1:mSVZ4vj4khv+oThUfS+SQU3UuFIZ5Zo6UNcvK8E8Mz8= github.com/gobuffalo/gogen v0.1.1 h1:dLg+zb+uOyd/mKeQUYIbwbNmfRsr9hd/WtYWepmayhI= @@ -1076,10 +1140,12 @@ github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/ github.com/google/go-containerregistry v0.5.1/go.mod h1:Ct15B4yir3PLOP5jsy0GNeYVaIZs/MK/Jz5any1wFW0= github.com/google/go-containerregistry v0.14.0/go.mod h1:aiJ2fp/SXvkWgmYHioXnbMdlgB8eXiiYOY55gfN91Wk= github.com/google/go-github v17.0.0+incompatible h1:N0LgJ1j65A7kfXrZnUDaYCs/Sf4rEjNlfyDHW9dolSY= +github.com/google/go-github v17.0.0+incompatible/go.mod h1:zLgOLi98H3fifZn+44m+umXrS52loVEgC2AApnigrVQ= github.com/google/go-github/v28 v28.1.1 h1:kORf5ekX5qwXO2mGzXXOjMe/g6ap8ahVe0sBEulhSxo= github.com/google/go-github/v28 v28.1.1/go.mod h1:bsqJWQX05omyWVmc00nEUql9mhQyv38lDZ8kPZcQVoM= github.com/google/go-github/v45 v45.2.0 h1:5oRLszbrkvxDDqBCNj2hjDZMKmvexaZ1xw/FCD+K3FI= github.com/google/go-github/v48 v48.2.0 h1:68puzySE6WqUY9KWmpOsDEQfDZsso98rT6pZcz9HqcE= +github.com/google/go-github/v48 v48.2.0/go.mod h1:dDlehKBDo850ZPvCTK0sEqTCVWcrGl2LcDiajkYi89Y= github.com/google/go-licenses v0.0.0-20210329231322-ce1d9163b77d h1:JtmsUf+m+KdwCOgLG578T0Mvd0+l+dezPrJh5KYnXZg= github.com/google/go-licenses v0.0.0-20210329231322-ce1d9163b77d/go.mod h1:+TYOmkVoJOpwnS0wfdsJCV9CoD5nJYsHoFk/0CrTK4M= github.com/google/go-licenses v1.6.0 h1:MM+VCXf0slYkpWO0mECvdYDVCxZXIQNal5wqUIXEZ/A= @@ -1121,10 +1187,12 @@ github.com/google/renameio v0.1.0 h1:GOZbcHa3HfsPKPlmyPyN2KEohoMXOhdMbHrvbpl2QaA github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/rpmpack v0.0.0-20191226140753-aa36bfddb3a0/go.mod h1:RaTPr0KUf2K7fnZYLNDrr8rxAamWs3iNywJLtQ2AzBg= github.com/google/rpmpack v0.0.0-20210518075352-dc539ef4f2ea h1:Fv9Ni1vIq9+Gv4Sm0Xq+NnPYcnsMbdNhJ4Cu4rkbPBM= +github.com/google/rpmpack v0.0.0-20210518075352-dc539ef4f2ea/go.mod h1:+y9lKiqDhR4zkLl+V9h4q0rdyrYVsWWm6LLCQP33DIk= github.com/google/s2a-go v0.1.0/go.mod h1:OJpEgntRZo8ugHpF9hkoLJbS5dSI20XZeXJ9JVywLlM= github.com/google/s2a-go v0.1.2/go.mod h1:OJpEgntRZo8ugHpF9hkoLJbS5dSI20XZeXJ9JVywLlM= github.com/google/s2a-go v0.1.3/go.mod h1:Ej+mSEMGRnqRzjc7VtF+jdBwYG5fuJfiZ8ELkjEwM0A= github.com/google/shlex v0.0.0-20191202100458-e7afc7fbc510 h1:El6M4kTTCOh6aBiKaUGG7oYTSPP8MxqL4YI3kZKwcP4= +github.com/google/shlex v0.0.0-20191202100458-e7afc7fbc510/go.mod h1:pupxD2MaaD3pAXIBCelhxNneeOaAeabZDe5s4K6zSpQ= github.com/google/subcommands v1.0.1 h1:/eqq+otEXm5vhfBrbREPCSVQbvofip6kIz+mX5TUH7k= github.com/google/subcommands v1.0.1/go.mod h1:ZjhPrFU+Olkh9WazFPsl27BQ4UPiG37m3yTrtFlrHVk= github.com/google/tink/go v1.7.0/go.mod h1:GAUOd+QE3pgj9q8VKIGTCP33c/B7eb4NhxLcgTJZStM= @@ -1138,6 +1206,7 @@ github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+ github.com/google/uuid v1.2.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/wire v0.3.0/go.mod h1:i1DMg/Lu8Sz5yYl25iOdmc5CT5qusaa+zmRWs16741s= github.com/google/wire v0.5.0 h1:I7ELFeVBr3yfPIcc8+MWvrjk+3VjbcSzoXm3JVa+jD8= +github.com/google/wire v0.5.0/go.mod h1:ngWDr9Qvq3yZA10YrxfyGELY/AFWGVpy9c1LTRi1EoU= github.com/googleapis/enterprise-certificate-proxy v0.1.0/go.mod h1:17drOmN3MwGY7t0e+Ei9b45FFGA3fBs3x36SsCg1hq8= github.com/googleapis/enterprise-certificate-proxy v0.2.0/go.mod h1:8C0jb7/mgJe/9KK8Lm7X9ctZC2t60YyIpYEI16jx0Qg= github.com/googleapis/enterprise-certificate-proxy v0.2.1/go.mod h1:AwSRAtLfXpU5Nm3pW+v7rGDHp09LsPtGY9MduiEsR9k= @@ -1170,6 +1239,7 @@ github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2z github.com/gorilla/mux v1.7.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs= github.com/gorilla/securecookie v1.1.1 h1:miw7JPhV+b/lAHSXz4qd/nN9jRiAFV5FwjeKyCS8BvQ= +github.com/gorilla/securecookie v1.1.1/go.mod h1:ra0sb63/xPlUeL+yeDciTfxMRAA+MP+HVt/4epWDjd4= github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= github.com/gorilla/websocket v1.4.1/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= @@ -1204,6 +1274,7 @@ github.com/hashicorp/consul/api v1.1.0/go.mod h1:VmuI/Lkw1nC05EYQWNKwWGbkg+FbDBt github.com/hashicorp/consul/api v1.3.0/go.mod h1:MmDNSzIMUjNpY/mQ398R4bk2FnqQLoPndWW5VkKPlCE= github.com/hashicorp/consul/api v1.12.0/go.mod h1:6pVBMo0ebnYdt2S3H87XhekM/HHrUoTD2XXb/VrZVy0= github.com/hashicorp/consul/api v1.18.0 h1:R7PPNzTCeN6VuQNDwwhZWJvzCtGSrNpJqfb22h3yH9g= +github.com/hashicorp/consul/api v1.18.0/go.mod h1:owRRGJ9M5xReDC5nfT8FTJrNAPbT4NM6p/k+d03q2v4= github.com/hashicorp/consul/sdk v0.1.1 h1:LnuDWGNsoajlhGyHJvuWW6FVqRl8JOTPqS6CPTsYjhY= github.com/hashicorp/consul/sdk v0.1.1/go.mod h1:VKf9jXwCTEY1QZP2MOLRhb5i/I/ssyNV1vwHyQBF0x8= github.com/hashicorp/consul/sdk v0.3.0 h1:UOxjlb4xVNF93jak1mzzoBatyFju9nrkxpVwIp/QqxQ= @@ -1221,6 +1292,7 @@ github.com/hashicorp/go-hclog v1.4.0/go.mod h1:W4Qnvbt70Wk/zYJryRzDRU/4r0kIg0PVH github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= github.com/hashicorp/go-immutable-radix v1.2.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= github.com/hashicorp/go-immutable-radix v1.3.1 h1:DKHmCUm2hRBK510BaiZlwvpD40f8bJFeZnpfm2KLowc= +github.com/hashicorp/go-immutable-radix v1.3.1/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60= github.com/hashicorp/go-msgpack v0.5.3 h1:zKjpN5BK/P5lMYrLmBHdBULWbJ0XpYR+7NGzqkZzoD4= github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM= github.com/hashicorp/go-multierror v0.0.0-20161216184304-ed905158d874/go.mod h1:JMRHfdO9jKNzS/+BTlxCjKNQHg/jZAft8U7LloJvN7I= @@ -1262,11 +1334,15 @@ github.com/hashicorp/memberlist v0.3.1/go.mod h1:MS2lj3INKhZjWNqd3N0m3J+Jxf3DAOn github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/JwenrHc= github.com/hashicorp/serf v0.9.6/go.mod h1:TXZNMjZQijwlDvp+r0b63xZ45H7JmCmgg4gpTwn9UV4= github.com/hashicorp/serf v0.10.1 h1:Z1H2J60yRKvfDYAOZLd2MU0ND4AH/WDz7xYHDWQsIPY= +github.com/hashicorp/serf v0.10.1/go.mod h1:yL2t6BqATOLGc5HF7qbFkTfXoPIY0WZdWHfEvMqbG+4= github.com/hashicorp/vault/api v1.9.1/go.mod h1:78kktNcQYbBGSrOjQfHjXN32OhhxXnbYl3zxpd2uPUs= github.com/hashicorp/vault/sdk v0.6.0 h1:6Z+In5DXHiUfZvIZdMx7e2loL1PPyDjA4bVh9ZTIAhs= github.com/hashicorp/yamux v0.1.1 h1:yrQxtgseBDrq9Y652vSRDvsKCJKOUD+GzTS4Y0Y8pvE= github.com/hetznercloud/hcloud-go v1.33.1/go.mod h1:XX/TQub3ge0yWR2yHWmnDVIrB+MQbda1pHxkUmDlUME= +github.com/honeycombio/beeline-go v1.10.0/go.mod h1:Zz5WMeQCJzFt2Mvf8t6HC1X8RLskLVR/e8rvcmXB1G8= +github.com/honeycombio/libhoney-go v1.16.0/go.mod h1:izP4fbREuZ3vqC4HlCAmPrcPT9gxyxejRjGtCYpmBn0= github.com/howeyc/gopass v0.0.0-20190910152052-7cb4b85ec19c h1:aY2hhxLhjEAbfXOx2nRJxCXezC6CO2V/yN+OCr1srtk= +github.com/howeyc/gopass v0.0.0-20190910152052-7cb4b85ec19c/go.mod h1:lADxMC39cJJqL93Duh1xhAs4I2Zs8mKS89XWXFGp9cs= github.com/hpcloud/tail v1.0.0 h1:nfCOvKYfkgYP8hkirhJocXT2+zOD8yUNjXaWfTlyFKI= github.com/huandu/xstrings v1.0.0/go.mod h1:4qWG/gcEcfX4z/mBDHJ++3ReCw9ibxbsNJbcucJdbSo= github.com/huandu/xstrings v1.2.0/go.mod h1:DvyZB1rfVYsBIigL8HwpZgxHwXozlTgGqn63UyNX5k4= @@ -1367,6 +1443,7 @@ github.com/jinzhu/now v1.1.4/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/ github.com/jmespath/go-jmespath v0.0.0-20160202185014-0b12d6b521d8/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= github.com/jmespath/go-jmespath v0.0.0-20160803190731-bd40a432e4c7/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= github.com/jmespath/go-jmespath v0.0.0-20180206201540-c2b33e8439af/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= +github.com/jmhodges/clock v0.0.0-20160418191101-880ee4c33548/go.mod h1:hGT6jSUVzF6no3QaDSMLGLEHtHSBSefs+MgcDWnmhmo= github.com/jmoiron/sqlx v1.3.5/go.mod h1:nRVWtLre0KfCLJvgxzCsLVMogSvQ1zNJtpYr2Ccp0mQ= github.com/joefitzgerald/rainbow-reporter v0.1.0/go.mod h1:481CNgqmVHQZzdIbN52CupLJyoVwB10FQ/IQlF1pdL8= github.com/joho/godotenv v1.3.0 h1:Zjp+RcGpHhGlrMbJzXTrZZPrWj+1vfm90La1wgB6Bhc= @@ -1376,7 +1453,9 @@ github.com/jonboulle/clockwork v0.2.2/go.mod h1:Pkfl5aHPm1nk2H9h0bjmnJD/BcgbGXUB github.com/jonboulle/clockwork v0.3.0 h1:9BSCMi8C+0qdApAp4auwX0RkLGUjs956h0EkuQymUhg= github.com/jonboulle/clockwork v0.3.0/go.mod h1:Pkfl5aHPm1nk2H9h0bjmnJD/BcgbGXUBGnn1kMkgxc8= github.com/joshlf/go-acl v0.0.0-20200411065538-eae00ae38531 h1:hgVxRoDDPtQE68PT4LFvNlPz2nBKd3OMlGKIQ69OmR4= +github.com/joshlf/go-acl v0.0.0-20200411065538-eae00ae38531/go.mod h1:fqTUQpVYBvhCNIsMXGl2GE9q6z94DIP6NtFKXCSTVbg= github.com/joshlf/testutil v0.0.0-20170608050642-b5d8aa79d93d h1:J8tJzRyiddAFF65YVgxli+TyWBi0f79Sld6rJP6CBcY= +github.com/joshlf/testutil v0.0.0-20170608050642-b5d8aa79d93d/go.mod h1:b+Q3v8Yrg5o15d71PSUraUzYb+jWl6wQMSBXSGS/hv0= github.com/jpillora/backoff v0.0.0-20180909062703-3050d21c67d7/go.mod h1:2iMrUgbbvHEiQClaW2NsSzMyGHqN+rDFqY705q49KG0= github.com/jpillora/backoff v1.0.0 h1:uvFg412JmmHBHw7iwprIxkPMI+sGQ4kzOWsMeHnm2EA= github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4= @@ -1396,13 +1475,16 @@ github.com/juju/ratelimit v1.0.1/go.mod h1:qapgC/Gy+xNh9UxzV13HGGl/6UXNN+ct+vwSg github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= github.com/julienschmidt/httprouter v1.3.0 h1:U0609e9tgbseu3rBINet9P48AI/D3oJs4dN7jwJOQ1U= github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= +github.com/k14s/difflib v0.0.0-20201117154628-0c031775bf57/go.mod h1:B0xN2MiNBGWOWi9CcfAo9LBI8IU4J1utlbOIJCsmKr4= github.com/karrick/godirwalk v1.10.3 h1:lOpSw2vJP0y5eLBW906QwKsUK/fe/QDyoqM5rnnuPDY= github.com/kelseyhightower/envconfig v1.4.0 h1:Im6hONhd3pLkfDFsbRgu68RDNkGF1r3dvMUtDTo2cv8= +github.com/kelseyhightower/envconfig v1.4.0/go.mod h1:cccZRl6mQpaq41TPp5QxidR+Sa3axMbJDNb//FQX6Gg= github.com/kevinburke/ssh_config v0.0.0-20190725054713-01f96b0aa0cd h1:Coekwdh0v2wtGp9Gmz1Ze3eVRAWJMLokvN3QjdzCHLY= github.com/kevinburke/ssh_config v0.0.0-20190725054713-01f96b0aa0cd/go.mod h1:CT57kijsi8u/K/BOFA39wgDQJ9CxiF4nAY/ojJ6r6mM= github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q= github.com/kisielk/errcheck v1.2.0/go.mod h1:/BMXB+zMLi60iA8Vv6Ksmxu/1UDYcXs4uQLJ+jE2L00= github.com/kisielk/errcheck v1.6.0 h1:YTDO4pNy7AUN/021p+JGHycQyYNIyMoenM1YDVK6RlY= +github.com/kisielk/errcheck v1.6.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= github.com/kisielk/gotool v1.0.0 h1:AV2c/EiW3KqPNT9ZKl07ehoAGi4C5/01Cfbblndcapg= github.com/klauspost/asmfmt v1.3.2 h1:4Ri7ox3EwapiOjCki+hw14RyKk201CN4rzyCJRFLpK4= github.com/klauspost/compress v1.4.1/go.mod h1:RyIbtBH6LamlWaDj8nUwkbUhJ87Yi3uG0guNDohfE1A= @@ -1411,6 +1493,7 @@ github.com/klauspost/compress v1.11.4/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYs github.com/klauspost/compress v1.11.13/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs= github.com/klauspost/cpuid v1.2.0/go.mod h1:Pj4uuM528wm8OyEC2QMXAi2YiTZ96dNQPGgoMS4s3ek= github.com/klauspost/cpuid/v2 v2.2.3 h1:sxCkb+qR91z4vsqw4vGGZlDgPz3G7gjaLyK3V8y70BU= +github.com/klauspost/cpuid/v2 v2.2.3/go.mod h1:RVVoqg1df56z8g3pUjL/3lE5UfnlrJX8tyFgg4nqhuY= github.com/klauspost/pgzip v1.2.5/go.mod h1:Ch1tH69qFZu15pkjo5kYi6mth2Zzwzt50oCQKQE9RUs= github.com/kolo/xmlrpc v0.0.0-20201022064351-38db28db192b/go.mod h1:pcaDhQK0/NJZEvtCO0qQPPropqV0sJOJ6YW7X+9kRwM= github.com/konsorten/go-windows-terminal-sequences v1.0.2 h1:DB17ag19krx9CFsz4o3enTrPXyIXCl+2iCXH/aMAp9s= @@ -1427,6 +1510,7 @@ github.com/kylelemons/godebug v1.1.0/go.mod h1:9/0rRGxNHcop5bhtWyNeEfOS8JIWk580+ github.com/leodido/go-urn v1.1.0/go.mod h1:+cyI34gQWZcE1eQU7NVgKkkzdXDQHr1dBMtdAPozLkw= github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII= github.com/letsencrypt/challtestsrv v1.2.1 h1:Lzv4jM+wSgVMCeO5a/F/IzSanhClstFMnX6SfrAJXjI= +github.com/letsencrypt/challtestsrv v1.2.1/go.mod h1:Ur4e4FvELUXLGhkMztHOsPIsvGxD/kzSJninOrkM+zc= github.com/letsencrypt/pkcs11key/v4 v4.0.0 h1:qLc/OznH7xMr5ARJgkZCCWk+EomQkiNTOoOF5LAgagc= github.com/letsencrypt/pkcs11key/v4 v4.0.0/go.mod h1:EFUvBDay26dErnNb70Nd0/VW3tJiIbETBPTl9ATXQag= github.com/lib/pq v1.0.0/go.mod h1:5WUZQaWbwv1U+lTReE5YruASi9Al49XbQIvNi/34Woo= @@ -1441,6 +1525,7 @@ github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o= github.com/lib/pq v1.10.9 h1:YXG7RB+JIjhP29X+OtkiDnYaXQwpS4JEWq7dtCCRUEw= github.com/lib/pq v1.10.9/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o= github.com/liggitt/tabwriter v0.0.0-20181228230101-89fcab3d43de h1:9TO3cAIGXtEhnIaL+V+BEER86oLrvS+kWobKpbJuye0= +github.com/liggitt/tabwriter v0.0.0-20181228230101-89fcab3d43de/go.mod h1:zAbeS9B/r2mtpb6U+EI2rYA5OAXxsYw6wTamcNW+zcE= github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743 h1:143Bb8f8DuGWck/xpNUOckBVYfFbBTnLevfRZ1aVVqo= github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM= github.com/lightstep/lightstep-tracer-go v0.18.1 h1:vi1F1IQ8N7hNWytK9DpJsUfQhGuNSc19z330K6vl4zk= @@ -1461,6 +1546,7 @@ github.com/magiconair/properties v1.8.1/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czP github.com/mailru/easyjson v0.0.0-20160728113105-d5b7844b561a/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= github.com/mailru/easyjson v0.7.0/go.mod h1:KAzv3t3aY1NaHWoQz1+4F1ccyAH66Jk7yos7ldAVICs= github.com/manifoldco/promptui v0.9.0 h1:3V4HzJk1TtXW1MTZMP7mdlwbBpIinw3HztaIlYthEiA= +github.com/manifoldco/promptui v0.9.0/go.mod h1:ka04sppxSGFAtxX0qhlYQjISsg9mR4GWtQEhdbn6Pgg= github.com/markbates/oncer v0.0.0-20181203154359-bf2de49a0be2 h1:JgVTCPf0uBVcUSWpyXmGpgOc62nK5HWUBKAGc3Qqa5k= github.com/markbates/safe v1.0.1 h1:yjZkbvRM6IzKj9tlu/zMJLS0n/V351OZWRnF3QfaUxI= github.com/marstr/guid v1.1.0/go.mod h1:74gB1z2wpxxInTG6yaqA7KrtM0NZ+RbrcqDvYHefzho= @@ -1494,6 +1580,7 @@ github.com/mattn/go-sqlite3 v1.14.16/go.mod h1:2eHXhiwb8IkHr+BDWZGa96P6+rkvnG63S github.com/mattn/go-zglob v0.0.1 h1:xsEx/XUoVlI6yXjqBK062zYhRTZltCNmYPx6v+8DNaY= github.com/mattn/go-zglob v0.0.1/go.mod h1:9fxibJccNxU2cnpIKLRRFA7zX7qhkJIQWBb449FYHOo= github.com/mattn/goveralls v0.0.11 h1:eJXea6R6IFlL1QMKNMzDvvHv/hwGrnvyig4N+0+XiMM= +github.com/mattn/goveralls v0.0.11/go.mod h1:gU8SyhNswsJKchEV93xRQxX6X3Ei4PJdQk/6ZHvrvRk= github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= github.com/matttproud/golang_protobuf_extensions v1.0.2-0.20181231171920-c182affec369/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= github.com/matttproud/golang_protobuf_extensions v1.0.2/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4= @@ -1507,6 +1594,7 @@ github.com/miekg/dns v1.1.26/go.mod h1:bPDLeHnStXmXAq1m/Ch/hvfNHr14JKNPMBo3VZKju github.com/miekg/dns v1.1.41/go.mod h1:p6aan82bvRIyn+zDIv9xYNUpwa73JcSh9BKwknJysuI= github.com/miekg/dns v1.1.48/go.mod h1:e3IlAVfNqAllflbibAZEWOXOQ+Ynzk/dDozDxY7XnME= github.com/miekg/dns v1.1.50 h1:DQUfb9uc6smULcREF09Uc+/Gd46YWqJd5DbpPE9xkcA= +github.com/miekg/dns v1.1.50/go.mod h1:e3IlAVfNqAllflbibAZEWOXOQ+Ynzk/dDozDxY7XnME= github.com/miekg/pkcs11 v1.0.2/go.mod h1:XsNlhZGX73bx86s2hdc/FuaLm2CPZJemRLMA+WTFxgs= github.com/miekg/pkcs11 v1.0.3/go.mod h1:XsNlhZGX73bx86s2hdc/FuaLm2CPZJemRLMA+WTFxgs= github.com/minio/asm2plan9s v0.0.0-20200509001527-cdd76441f9d8 h1:AMFGa4R4MiIpspGNG7Z948v4n35fFGB3RR3G/ry4FWs= @@ -1561,11 +1649,14 @@ github.com/modocache/gover v0.0.0-20171022184752-b58185e213c5/go.mod h1:caMODM3P github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826 h1:RWengNIwukTxcDr9M+97sNutRR1RKhG96O6jWumTTnw= github.com/mohae/deepcopy v0.0.0-20170929034955-c48cc78d4826/go.mod h1:TaXosZuwdSHYgviHp1DAtfrULt5eUgsSMsZf+YrPgl8= github.com/monochromegane/go-gitignore v0.0.0-20200626010858-205db1a8cc00 h1:n6/2gBQ3RWajuToeY6ZtZTIKv2v7ThUy5KKusIT0yc0= +github.com/monochromegane/go-gitignore v0.0.0-20200626010858-205db1a8cc00/go.mod h1:Pm3mSP3c5uWn86xMLZ5Sa7JB9GsEZySvHYXCTK4E9q4= github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe h1:iruDEfMl2E6fbMZ9s0scYfZQ84/6SPL6zC8ACM2oIL0= github.com/morikuni/aec v1.0.0 h1:nP9CBfwrvYnBRgY6qfDQkygYDmYwOilePFkwzv4dU8A= github.com/morikuni/aec v1.0.0/go.mod h1:BbKIizmSmc5MMPqRYbxO4ZU0S0+P200+tUnFx7PXmsc= github.com/mozillazg/docker-credential-acr-helper v0.3.0 h1:DVWFZ3/O8BP6Ue3iS/Olw+G07u1hCq1EOVCDZZjCIBI= +github.com/mozillazg/docker-credential-acr-helper v0.3.0/go.mod h1:cZlu3tof523ujmLuiNUb6JsjtHcNA70u1jitrrdnuyA= github.com/mpvl/unique v0.0.0-20150818121801-cbe035fff7de h1:D5x39vF5KCwKQaw+OC9ZPiLVHXz3UFw2+psEX+gYcto= +github.com/mpvl/unique v0.0.0-20150818121801-cbe035fff7de/go.mod h1:kJun4WP5gFuHZgRjZUWWuH1DTxCtxbHDOIJsudS8jzY= github.com/mrunalp/fileutils v0.5.0/go.mod h1:M1WthSahJixYnrXQl/DFQuteStB1weuxD2QJNHXfbSQ= github.com/munnerz/goautoneg v0.0.0-20120707110453-a547fc61f48d/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= @@ -1636,6 +1727,7 @@ github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWEr github.com/open-policy-agent/opa v0.45.0 h1:P5nuhVRtR+e58fk3CMMbiqr6ZFyWQPNOC3otsorGsFs= github.com/open-policy-agent/opa v0.51.0 h1:2hS5xhos8HtkN+mgpqMhNJSFtn/1n/h3wh+AeTPJg6Q= github.com/open-policy-agent/opa v0.52.0 h1:Rv3F+VCDqsufaiYy/3S9/Iuk0yfcREK4iZmWbNsKZjA= +github.com/open-policy-agent/opa v0.52.0/go.mod h1:2n99s7WY/BXZUWUOq10JdTgK+G6XM4FYGoe7kQ5Vg0s= github.com/opencontainers/go-digest v0.0.0-20170106003457-a6d0ee40d420/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= github.com/opencontainers/go-digest v0.0.0-20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= github.com/opencontainers/go-digest v1.0.0-rc1/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s= @@ -1675,10 +1767,15 @@ github.com/openzipkin/zipkin-go v0.2.1/go.mod h1:NaW6tEwdmWMaCDZzg8sh+IBNOxHMPnh github.com/openzipkin/zipkin-go v0.2.2 h1:nY8Hti+WKaP0cRsSeQ026wU03QsM762XBeCXBb9NAWI= github.com/openzipkin/zipkin-go v0.2.2/go.mod h1:NaW6tEwdmWMaCDZzg8sh+IBNOxHMPnhQw8ySjnjRyN4= github.com/ory/fosite v0.42.2 h1:fKfGAgMmmeM1C0DXCyt5TOzQWrKmLOL+PApEC4bIv2o= +github.com/ory/fosite v0.42.2/go.mod h1:qggrqm3ZWQF9i2f/d3RLH5mHHPtv44hsiltkVKLsCYo= github.com/ory/go-acc v0.2.8 h1:rOHHAPQjf0u7eHFGWpiXK+gIu/e0GRSJNr9pDukdNC4= +github.com/ory/go-acc v0.2.8/go.mod h1:iCRZUdGb/7nqvSn8xWZkhfVrtXRZ9Wru2E5rabCjFPI= github.com/ory/go-convenience v0.1.0 h1:zouLKfF2GoSGnJwGq+PE/nJAE6dj2Zj5QlTgmMTsTS8= +github.com/ory/go-convenience v0.1.0/go.mod h1:uEY/a60PL5c12nYz4V5cHY03IBmwIAEm8TWB0yn9KNs= github.com/ory/viper v1.7.5 h1:+xVdq7SU3e1vNaCsk/ixsfxE4zylk1TJUiJrY647jUE= +github.com/ory/viper v1.7.5/go.mod h1:ypOuyJmEUb3oENywQZRgeAMwqgOyDqwboO1tj3DjTaM= github.com/ory/x v0.0.409 h1:DkPNOfV8+rFrudbRxX6V6xRlfakrYpCFJesAzagVjWM= +github.com/ory/x v0.0.409/go.mod h1:Rchv+ANloKAhmN3LZ5KUIAU2TIRlHPF7EYEB2i3xL0Q= github.com/otiai10/copy v1.2.0/go.mod h1:rrF5dJ5F0t/EWSYODDu4j9/vEeYHMkc8jt0zJChqQWw= github.com/otiai10/curr v1.0.0 h1:TJIWdbX0B+kpNagQrjgq8bCMrbhiuX73M2XwgtDMoOI= github.com/otiai10/mint v1.3.1/go.mod h1:/yxELlJQ0ufhjUwhshSj+wFjZ78CnZ48/1wtmBH1OTc= @@ -1689,12 +1786,14 @@ github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FI github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k= github.com/pborman/uuid v1.2.1 h1:+ZZIw58t/ozdjRaXh/3awHfmWRbzYxJoAdNJxe/3pvw= +github.com/pborman/uuid v1.2.1/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k= github.com/pelletier/go-buffruneio v0.2.0 h1:U4t4R6YkofJ5xHm3dJzuRpPZ0mr5MMCoAWooScCR7aA= github.com/pelletier/go-buffruneio v0.2.0/go.mod h1:JkE26KsDizTr40EUHkXVtNPvgGtbSNq5BcowyYOWdKo= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= github.com/pelletier/go-toml v1.8.1/go.mod h1:T2/BmBdy8dvIRq1a/8aqjN41wvWlN4lrapLU/GW4pbc= github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c= github.com/pelletier/go-toml v1.9.5 h1:4yBQzkHv+7BHq2PQUZF3Mx0IYxG7LsP222s7Agd3ve8= +github.com/pelletier/go-toml v1.9.5/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c= github.com/performancecopilot/speed v3.0.0+incompatible h1:2WnRzIquHa5QxaJKShDkLM+sc0JPuwhXzK8OYOyt3Vg= github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac= github.com/peterbourgon/diskv v2.0.1+incompatible h1:UBdAOUP5p4RWqPBg048CAvpKN+vxiaj6gdUUzhl4XmI= @@ -1721,6 +1820,7 @@ github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndr github.com/posener/complete v1.2.3/go.mod h1:WZIdtGGp+qx0sLrYKtIRAruyNpv6hFCicSgv7Sy7s/s= github.com/pquerna/cachecontrol v0.0.0-20171018203845-0dec1b30a021/go.mod h1:prYjPmNq4d1NPVmpShWobRqXY3q7Vp+80DqgxxUrUIA= github.com/pquerna/cachecontrol v0.1.0 h1:yJMy84ti9h/+OEWa752kBTKv4XC30OtVVHYv/8cTqKc= +github.com/pquerna/cachecontrol v0.1.0/go.mod h1:NrUG3Z7Rdu85UNR3vm7SOsl1nFIeSiQnrHV5K9mBcUI= github.com/prashantv/gostub v1.1.0/go.mod h1:A5zLQHz7ieHGG7is6LLXLz7I8+3LZzsrV0P1IAHhP5U= github.com/prometheus/alertmanager v0.24.0/go.mod h1:r6fy/D7FRuZh5YbnX6J3MBY0eI4Pb5yPYS7/bPSXXqI= github.com/prometheus/client_golang v0.0.0-20180209125602-c332b6f63c06/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw= @@ -1788,6 +1888,7 @@ github.com/prometheus/tsdb v0.7.1 h1:YZcsG11NqnK4czYLrWd9mpEuAJIHVQLwdrleYfszMAA github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU= github.com/protocolbuffers/txtpbfmt v0.0.0-20201118171849-f6a6b3f636fc h1:gSVONBi2HWMFXCa9jFdYvYk7IwW/mTLxWOF7rXS4LO0= github.com/protocolbuffers/txtpbfmt v0.0.0-20220428173112-74888fd59c2b h1:zd/2RNzIRkoGGMjE+YIsZ85CnDIz672JK2F3Zl4vux4= +github.com/protocolbuffers/txtpbfmt v0.0.0-20220428173112-74888fd59c2b/go.mod h1:KjY0wibdYKc4DYkerHSbguaf3JeIPGhNJBp2BNiFH78= github.com/pseudomuto/protoc-gen-doc v1.3.2/go.mod h1:y5+P6n3iGrbKG+9O04V5ld71in3v/bX88wUwgt+U8EA= github.com/pseudomuto/protoc-gen-doc v1.4.1/go.mod h1:exDTOVwqpp30eV/EDPFLZy3Pwr2sn6hBC1WIYH/UbIg= github.com/pseudomuto/protoc-gen-doc v1.5.0/go.mod h1:exDTOVwqpp30eV/EDPFLZy3Pwr2sn6hBC1WIYH/UbIg= @@ -1797,7 +1898,9 @@ github.com/pseudomuto/protokit v0.2.0 h1:hlnBDcy3YEDXH7kc9gV+NLaN0cDzhDvD1s7Y6FZ github.com/pseudomuto/protokit v0.2.0/go.mod h1:2PdH30hxVHsup8KpBTOXTBeMVhJZVio3Q8ViKSAXT0Q= github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM= +github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= github.com/redis/go-redis/v9 v9.0.4 h1:FC82T+CHJ/Q/PdyLW++GeCO+Ol59Y4T7R4jbgjvktgc= +github.com/redis/go-redis/v9 v9.0.4/go.mod h1:WqMKv5vnQbRuZstUwxQI195wHy+t4PuXDOjzMvcuQHk= github.com/rogpeppe/clock v0.0.0-20190514195947-2896927a307a/go.mod h1:4r5QyqhjIWCcK8DO4KMclc5Iknq5qVBAlbYYzAbUScQ= github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= github.com/rogpeppe/fastuuid v1.1.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= @@ -1826,6 +1929,7 @@ github.com/ryanuber/go-glob v1.0.0/go.mod h1:807d1WSdnB0XRJzKNil9Om6lcp/3a0v4qIH github.com/safchain/ethtool v0.0.0-20190326074333-42ed695e3de8/go.mod h1:Z0q5wiBQGYcxhMZ6gUqHn6pYNLypFAvaL3UvgZLR0U4= github.com/safchain/ethtool v0.0.0-20210803160452-9aa261dae9b1/go.mod h1:Z0q5wiBQGYcxhMZ6gUqHn6pYNLypFAvaL3UvgZLR0U4= github.com/sagikazarmark/crypt v0.9.0 h1:fipzMFW34hFUEc4D7fsLQFtE7yElkpgyS2zruedRdZk= +github.com/sagikazarmark/crypt v0.9.0/go.mod h1:RnH7sEhxfdnPm1z+XMgSLjWTEIjyK4z2dw6+4vHTMuo= github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da h1:p3Vo3i64TCLY7gIfzeQaUJ+kppEO5WQG3cL8iE8tGHU= github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E= github.com/sassoftware/go-rpmutils v0.0.0-20190420191620-a8f1baeba37b h1:+gCnWOZV8Z/8jehJ2CdqB47Z3S+SREmQcuXkRFLNsiI= @@ -1836,6 +1940,7 @@ github.com/schollz/jsonstore v1.1.0/go.mod h1:15c6+9guw8vDRyozGjN3FoILt0wpruJk9P github.com/sclevine/agouti v3.0.0+incompatible h1:8IBJS6PWz3uTlMP3YBIR5f+KAldcGuOeFkFbUWfBgK4= github.com/sclevine/spec v1.2.0/go.mod h1:W4J29eT/Kzv7/b9IWLB055Z+qvVC9vt0Arko24q7p+U= github.com/sclevine/spec v1.4.0 h1:z/Q9idDcay5m5irkZ28M7PtQM4aOISzOpj4bUPkDee8= +github.com/sclevine/spec v1.4.0/go.mod h1:LvpgJaFyvQzRvc1kaDs0bulYwzC70PbiYjC4QnFHkOM= github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529 h1:nn5Wsu0esKSJiIVhscUtVbo7ada43DJhG55ua/hjS5I= github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc= github.com/seccomp/libseccomp-golang v0.9.1/go.mod h1:GbW5+tmTXfcxTToHLXlScSlAvWlF4P2Ca7zGrPiEpWo= @@ -1860,7 +1965,9 @@ github.com/sigstore/cosign/v2 v2.0.0/go.mod h1:MeJyYfKll3AAsb+CdnhI3YkecDPX2erPv github.com/sigstore/fulcio v0.6.0 h1:YNfnGm9EjYPlzHiPDcIVhslYj846jkPtHQH+FTKNncw= github.com/sigstore/fulcio v1.2.0 h1:I4H764cDbryKXkPtasUvo8bcix/7xLvkxWYWNp+JtWI= github.com/sigstore/fulcio v1.3.1 h1:0ntW9VbQbt2JytoSs8BOGB84A65eeyvGSavWteYp29Y= +github.com/sigstore/fulcio v1.3.1/go.mod h1:/XfqazOec45ulJZpyL9sq+OsVQ8g2UOVoNVi7abFgqU= github.com/sigstore/protobuf-specs v0.1.0 h1:X0l/E2C2c79t/rI/lmSu8WAoKWsQtMqDzAMiDdEMGr8= +github.com/sigstore/protobuf-specs v0.1.0/go.mod h1:5shUCxf82hGnjUEFVWiktcxwzdtn6EfeeJssxZ5Q5HE= github.com/sirupsen/logrus v1.0.4-0.20170822132746-89742aefa4b2/go.mod h1:pMByvHTf9Beacp5x1UXfOR9xyW/9antXMhjMPG0dEzc= github.com/sirupsen/logrus v1.0.6/go.mod h1:pMByvHTf9Beacp5x1UXfOR9xyW/9antXMhjMPG0dEzc= github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= @@ -1912,6 +2019,7 @@ github.com/spf13/viper v1.4.0/go.mod h1:PTJ7Z/lr49W6bUbkmS1V3by4uWynFiR9p7+dSq/y github.com/spf13/viper v1.7.0/go.mod h1:8WkrPz2fc9jxqZNCJI/76HCieCp4Q8HaLFoCha5qpdg= github.com/spiffe/go-spiffe/v2 v2.1.3 h1:P5L9Ixo5eqJiHnktAU0UD/6UfHsQs7yAtc8a/FFUi9M= github.com/spiffe/go-spiffe/v2 v2.1.4 h1:Z31Ycaf2Z5DF38sQGmp+iGKjBhBlSzfAq68bfy67Mxw= +github.com/spiffe/go-spiffe/v2 v2.1.4/go.mod h1:eVDqm9xFvyqao6C+eQensb9ZPkyNEeaUbqbBpOhBnNk= github.com/src-d/gcfg v1.4.0 h1:xXbNR5AlLSA315x2UO+fTSSAXCDf+Ar38/6oyGbDKQ4= github.com/src-d/gcfg v1.4.0/go.mod h1:p/UMsR43ujA89BJY9duynAwIpvqEujIH/jFlfL7jWoI= github.com/stefanberger/go-pkcs11uri v0.0.0-20201008174630-78d3cae3a980/go.mod h1:AO3tvPzVZ/ayst6UlUKUv6rcPQInYe3IknH3jYhAKu8= @@ -1932,8 +2040,11 @@ github.com/syndtr/gocapability v0.0.0-20180916011248-d98352740cb2/go.mod h1:hkRG github.com/syndtr/gocapability v0.0.0-20200815063812-42c35b437635/go.mod h1:hkRG7XYTFWNJGYcbNJQlaLq0fg1yr4J4t/NcTQtrfww= github.com/tchap/go-patricia v2.2.6+incompatible/go.mod h1:bmLyhP68RS6kStMGxByiQ23RP/odRBOTVjwp2cDyi6I= github.com/tchap/go-patricia/v2 v2.3.1 h1:6rQp39lgIYZ+MHmdEq4xzuk1t7OdC35z/xm0BGhTkes= +github.com/tchap/go-patricia/v2 v2.3.1/go.mod h1:VZRHKAb53DLaG+nA9EaYYiaEx6YztwDlLElMsnSHD4k= github.com/tdewolff/minify/v2 v2.12.2 h1:AKIoVwJj/HgBm+d/fPqpEZ31EtCM5FJfJNGagdR9Ecg= +github.com/tdewolff/minify/v2 v2.12.2/go.mod h1:p5pwbvNs1ghbFED/ZW1towGsnnWwzvM8iz8l0eURi9g= github.com/tdewolff/parse/v2 v2.6.3 h1:O5rshbkaRmpRtD7k2lG65bEJpcfUMNg5Cx2uRKWVsI8= +github.com/tdewolff/parse/v2 v2.6.3/go.mod h1:woz0cgbLwFdtbjJu8PIKxhW05KplTFQkOdX78o+Jgrs= github.com/tidwall/pretty v1.2.0/go.mod h1:ITEVvHYasfjBbM0u2Pg8T2nJnzm8xPwvNhhsoaGGjNU= github.com/tilinna/clock v1.1.0 h1:6IQQQCo6KoBxVudv6gwtY8o4eDfhHo8ojA5dP0MfhSs= github.com/tj/assert v0.0.0-20171129193455-018094318fb0/go.mod h1:mZ9/Rh9oLWpLLDRpvE+3b7gP/C2YyLFYxNmcLnPTMe0= @@ -1944,6 +2055,7 @@ github.com/tj/go-kinesis v0.0.0-20171128231115-08b17f58cb1b/go.mod h1:/yhzCV0xPf github.com/tj/go-spin v1.1.0 h1:lhdWZsvImxvZ3q1C5OIB7d72DuOwP4O2NdBg9PyzNds= github.com/tj/go-spin v1.1.0/go.mod h1:Mg1mzmePZm4dva8Qz60H2lHwmJ2loum4VIrLgVnKwh4= github.com/tjfoc/gmsm v1.3.2 h1:7JVkAn5bvUJ7HtU08iW6UiD+UTmJTIToHCfeFzkcCxM= +github.com/tjfoc/gmsm v1.3.2/go.mod h1:HaUcFuY0auTiaHB9MHFGCPx5IaLhTUd2atbCFBQXn9w= github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= github.com/tmc/grpc-websocket-proxy v0.0.0-20200427203606-3cfed13b9966/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U= @@ -1977,9 +2089,12 @@ github.com/urfave/negroni v1.0.0/go.mod h1:Meg73S6kFm/4PpbYdq35yYWoCZ9mS/YSx+lKn github.com/uwu-tools/magex v0.10.0/go.mod h1:TrSEhrL1xHfJVy6n05AUwFdcQndgwrbgL5ybPNKWmVY= github.com/valyala/fastjson v1.6.3 h1:tAKFnnwmeMGPbwJ7IwxcTPCNr3uIzoIj3/Fh90ra4xc= github.com/valyala/fastjson v1.6.4 h1:uAUNq9Z6ymTgGhcm0UynUAB6tlbakBrz6CQFax3BXVQ= +github.com/valyala/fastjson v1.6.4/go.mod h1:CLCAqky6SMuOcxStkYQvblddUtoRxhYMGLrsQns1aXY= github.com/veraison/go-cose v1.0.0 h1:Jxirc0rl3gG7wUFgW+82tBQNeK8T8e2Bk1Vd298ob4A= github.com/veraison/go-cose v1.1.0 h1:AalPS4VGiKavpAzIlBjrn7bhqXiXi4jbMYY/2+UC+4o= +github.com/veraison/go-cose v1.1.0/go.mod h1:7ziE85vSq4ScFTg6wyoMXjucIGOf4JkFEZi/an96Ct4= github.com/vincent-petithory/dataurl v1.0.0 h1:cXw+kPto8NLuJtlMsI152irrVw9fRDX8AbShPRpg2CI= +github.com/vincent-petithory/dataurl v1.0.0/go.mod h1:FHafX5vmDzyP+1CQATJn7WFKc9CvnvxyvZy6I1MrG/U= github.com/vishvananda/netlink v0.0.0-20181108222139-023a6dafdcdf/go.mod h1:+SR5DhBJrl6ZM7CoCKvpw5BKroDKQ+PJqOg65H/2ktk= github.com/vishvananda/netlink v1.1.0/go.mod h1:cTgwzPIzzgDAYoQrMm0EdrjRUBkTqKYppBueQtXaqoE= github.com/vishvananda/netlink v1.1.1-0.20201029203352-d40f9887b852/go.mod h1:twkDnbuQxJYemMlGd4JFIcuhgX83tXhKS2B/PRMpOho= @@ -1988,61 +2103,109 @@ github.com/vishvananda/netns v0.0.0-20180720170159-13995c7128cc/go.mod h1:ZjcWmF github.com/vishvananda/netns v0.0.0-20191106174202-0a2b9b5464df/go.mod h1:JP3t17pCcGlemwknint6hfoeCVQrEMVwxRLRjXpq+BU= github.com/vishvananda/netns v0.0.0-20200728191858-db3c7e526aae/go.mod h1:DD4vA1DwXk04H54A1oHXtwZmA0grkVMdPxx/VGLCah0= github.com/vishvananda/netns v0.0.0-20210104183010-2eb08e3e575f/go.mod h1:DD4vA1DwXk04H54A1oHXtwZmA0grkVMdPxx/VGLCah0= +github.com/vmihailenco/msgpack/v5 v5.3.5/go.mod h1:7xyJ9e+0+9SaZT0Wt1RGleJXzli6Q/V5KbhBonMG9jc= +github.com/vmihailenco/tagparser/v2 v2.0.0/go.mod h1:Wri+At7QHww0WTrCBeu4J6bNtoV6mEfg5OIWRZA9qds= github.com/vmware-tanzu/tanzu-cli/test/e2e v1.0.0-dev/go.mod h1:OletAz4jASbW1fS0a69GvuLT3pnkXAntvQiQRZx0UfE= -github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.0 h1:8u4BYfAFSsNYRHcSZrhDEDeGMNGStRDs7Ywe2BOBpmg= github.com/vmware-tanzu/tanzu-plugin-runtime v1.0.0/go.mod h1:wMK/qpJjU7hytDAGt3FX5/iGdlUK8TsJLu36pCr+Zvk= github.com/weppos/publicsuffix-go v0.20.1-0.20221031080346-e4081aa8a6de h1:eR9jm8DVMdrDUuVji4eOxPK4r/dANDlDBdISSUUV96s= +github.com/weppos/publicsuffix-go v0.20.1-0.20221031080346-e4081aa8a6de/go.mod h1:g9GsAxnaxsUuTLZcQdYbi43vT2k9ubZGHsdCy819VLk= github.com/withfig/autocomplete-tools/integrations/cobra v1.2.1 h1:+dBg5k7nuTE38VVdoroRsT0Z88fmvdYrI2EjzJst35I= +github.com/withfig/autocomplete-tools/integrations/cobra v1.2.1/go.mod h1:nmuySobZb4kFgFy6BptpXp/BBw+xFSyvVPP6auoJB4k= github.com/x448/float16 v0.8.4 h1:qLwI1I70+NjRFUR3zs1JPUCgaCXSh3SW62uAKT1mSBM= +github.com/x448/float16 v0.8.4/go.mod h1:14CWIYCyZA/cWjXOioeEpHeN/83MdbZDRQHoFcYsOfg= github.com/xanzy/ssh-agent v0.2.1 h1:TCbipTQL2JiiCprBWx9frJ2eJlCYT00NmctrHxVAr70= +github.com/xanzy/ssh-agent v0.2.1/go.mod h1:mLlQY/MoOhWBj+gOGMQkOeiEvkx+8pJSI+0Bx9h2kr4= github.com/xdg-go/pbkdf2 v1.0.0 h1:Su7DPu48wXMwC3bs7MCNG+z4FhcyEuz5dlvchbq0B0c= github.com/xdg-go/scram v1.1.1 h1:VOMT+81stJgXW3CpHyqHN3AXDYIMsx56mEFrB37Mb/E= github.com/xdg-go/stringprep v1.0.3 h1:kdwGpVNwPFtjs98xCGkHjQtGKh86rDcRZN17QEMCOIs= github.com/xeipuuv/gojsonpointer v0.0.0-20190905194746-02993c407bfb h1:zGWFAtiMcyryUHoUjUJX0/lt1H2+i2Ka2n+D3DImSNo= +github.com/xeipuuv/gojsonpointer v0.0.0-20190905194746-02993c407bfb/go.mod h1:N2zxlSyiKSe5eX1tZViRH5QA0qijqEDrYZiPEAiq3wU= github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415 h1:EzJWgHovont7NscjpAxXsDA8S8BMYve8Y5+7cuRE7R0= github.com/xeipuuv/gojsonschema v1.2.0 h1:LhYJRs+L4fBtjZUfuSZIKGeVu0QRy8e5Xi7D17UxZ74= github.com/xhit/go-str2duration v1.2.0 h1:BcV5u025cITWxEQKGWr1URRzrcXtu7uk8+luz3Yuhwc= +github.com/xhit/go-str2duration v1.2.0/go.mod h1:3cPSlfZlUHVlneIVfePFWcJZsuwf+P1v2SRTV4cUmp4= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2 h1:eY9dn8+vbi4tKz5Qo6v2eYzo7kUS51QINcR5jNpbZS8= +github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= github.com/xlab/treeprint v1.1.0 h1:G/1DjNkPpfZCFt9CSh6b5/nY4VimlbHF3Rh4obvtzDk= +github.com/xlab/treeprint v1.1.0/go.mod h1:gj5Gd3gPdKtR1ikdDK6fnFLdmIS0X30kTTuNd/WEJu0= github.com/yashtewari/glob-intersection v0.1.0 h1:6gJvMYQlTDOL3dMsPF6J0+26vwX9MB8/1q3uAdhmTrg= +github.com/yashtewari/glob-intersection v0.1.0/go.mod h1:LK7pIC3piUjovexikBbJ26Yml7g8xa5bsjfx2v1fwok= github.com/youmark/pkcs8 v0.0.0-20181117223130-1be2e3e5546d h1:splanxYIlg+5LfHAM6xpdFEAYOk8iySO56hMFq6uLyA= github.com/ysmood/fetchup v0.2.2 h1:Qn8/q5uDW7szclt4sVXCFJ1TXup3hogz94OaLf6kloo= +github.com/ysmood/fetchup v0.2.2/go.mod h1:xhibcRKziSvol0H1/pj33dnKrYyI2ebIvz5cOOkYGns= github.com/ysmood/goob v0.4.0 h1:HsxXhyLBeGzWXnqVKtmT9qM7EuVs/XOgkX7T6r1o1AQ= +github.com/ysmood/goob v0.4.0/go.mod h1:u6yx7ZhS4Exf2MwciFr6nIM8knHQIE22lFpWHnfql18= github.com/ysmood/gson v0.7.3 h1:QFkWbTH8MxyUTKPkVWAENJhxqdBa4lYTQWqZCiLG6kE= +github.com/ysmood/gson v0.7.3/go.mod h1:3Kzs5zDl21g5F/BlLTNcuAGAYLKt2lV5G8D1zF3RNmg= github.com/ysmood/leakless v0.8.0 h1:BzLrVoiwxikpgEQR0Lk8NyBN5Cit2b1z+u0mgL4ZJak= +github.com/ysmood/leakless v0.8.0/go.mod h1:R8iAXPRaG97QJwqxs74RdwzcRHT1SWCGTNqY8q0JvMQ= github.com/yuin/goldmark v1.4.13 h1:fVcFKWvrslecOb/tg+Cc05dkeYx540o0FuFt3nUVDoE= github.com/zalando/go-keyring v0.1.1 h1:w2V9lcx/Uj4l+dzAf1m9s+DJ1O8ROkEHnynonHjTcYE= +github.com/zalando/go-keyring v0.1.1/go.mod h1:OIC+OZ28XbmwFxU/Rp9V7eKzZjamBJwRzC8UFJH9+L8= github.com/zeebo/errs v1.3.0 h1:hmiaKqgYZzcVgRL1Vkc1Mn2914BbzB0IBxs+ebeutGs= +github.com/zeebo/errs v1.3.0/go.mod h1:sgbWHsvVuTPHcqJJGQ1WhI5KbWlHYz+2+2C/LSEtCw4= github.com/zmap/zcrypto v0.0.0-20220402174210-599ec18ecbac h1:+nr36qrZEH0RIYNjcUEnOrCUdcSG3om2ANaFA6iSVWA= +github.com/zmap/zcrypto v0.0.0-20220402174210-599ec18ecbac/go.mod h1:egdRkzUylATvPkWMpebZbXhv0FMEMJGX/ur0D3Csk2s= github.com/zmap/zlint/v3 v3.4.0 h1:Xs/lrMJY74MpJx/jSx2oVvZBrqlyUyFaLLBRyf68cqg= +github.com/zmap/zlint/v3 v3.4.0/go.mod h1:WgepL2QqxyMHnrOWJ54NqrgfMtOyuXr52wEE0tcfo9k= go.etcd.io/bbolt v1.3.7 h1:j+zJOnnEjF/kyHlDDgGnVL/AIqIJPq8UoB2GSNfkUfQ= +go.etcd.io/bbolt v1.3.7/go.mod h1:N9Mkw9X8x5fupy0IKsmuqVtoGDyxsaDlbk4Rd05IAQw= go.etcd.io/etcd/api/v3 v3.5.8 h1:Zf44zJszoU7zRV0X/nStPenegNXoFDWcB/MwrJbA+L4= +go.etcd.io/etcd/api/v3 v3.5.8/go.mod h1:uyAal843mC8uUVSLWz6eHa/d971iDGnCRpmKd2Z+X8k= go.etcd.io/etcd/client/pkg/v3 v3.5.8 h1:tPp9YRn/UBFAHdhOQUII9eUs7aOK35eulpMhX4YBd+M= +go.etcd.io/etcd/client/pkg/v3 v3.5.8/go.mod h1:y+CzeSmkMpWN2Jyu1npecjB9BBnABxGM4pN8cGuJeL4= go.etcd.io/etcd/client/v2 v2.305.8 h1:IGp9Ozt8awy3qRTXSIYJd/o/cr4oUyrm9MF1RJ2dr/c= +go.etcd.io/etcd/client/v2 v2.305.8/go.mod h1:ZlAsxDK5/10I6xVHhFo9zinCMr/DDLKFetDDXlzKwqE= go.etcd.io/etcd/client/v3 v3.5.8 h1:B6ngTKZSWWowHEoaucOKHQR/AtZKaoHLiUpWxOLG4l4= +go.etcd.io/etcd/client/v3 v3.5.8/go.mod h1:idZYIPVkttBJBiRigkB5EM0MmEyx8jcl18zCV3F5noc= go.etcd.io/etcd/etcdctl/v3 v3.5.8 h1:Hc+yvk0e1VOKSzNNA0ZyNqzOQf/jrAZarx/IFd6KcPk= +go.etcd.io/etcd/etcdctl/v3 v3.5.8/go.mod h1:ur5LRmFUo1Rcnwe8i71YVtH5y4RjsW/6YNmTQlz1N8E= go.etcd.io/etcd/etcdutl/v3 v3.5.8 h1:KTVdvP+9unMtYifGPcIQRMOhsbhek78W8DiCoAbYbQE= +go.etcd.io/etcd/etcdutl/v3 v3.5.8/go.mod h1:ttDqxIhpW9PqQdw+jJhUpLF+f37TnnSRJpkJSkCikts= go.etcd.io/etcd/pkg/v3 v3.5.8 h1:hz6w5Cb4p7dbt642m8Y35Ts9yWPWUCymc3v4Z/aiGEU= +go.etcd.io/etcd/pkg/v3 v3.5.8/go.mod h1:C17MJkZHJIyJV+wWWx6Jz6YS6BfdkOnUkSwT9uuEO7s= go.etcd.io/etcd/raft/v3 v3.5.8 h1:wM4IAfiY1+vrCAkUicIOzkyjpV9MawnAul2KvxeMgy4= +go.etcd.io/etcd/raft/v3 v3.5.8/go.mod h1:W6P5WxtOMfYNdLSEJX3vc8Pg6LOt+ewI9UCFKcnIexA= go.etcd.io/etcd/server/v3 v3.5.8 h1:eK9fU6Pd6IJD1k0u4zAq1NZsSsEOOimlP3kIkpcQrho= +go.etcd.io/etcd/server/v3 v3.5.8/go.mod h1:1y2ahPOrlE4pzVV5+rBCDur7QQcEP0MNUPO2dyzwjso= go.etcd.io/etcd/tests/v3 v3.5.8 h1:jrWlrEJfFuvI9nqMGFZNLc+OCdtyBdw8mSfp8ZwLIWs= +go.etcd.io/etcd/tests/v3 v3.5.8/go.mod h1:KFgEgZWwXZILKsOX3f3VyGmUHQgbG/yM9edQNTkXsdE= go.etcd.io/etcd/v3 v3.5.8 h1:AQF+i8f8jLeli9Cmf6SIs3KNryFPnzlIzI7weyK784g= +go.etcd.io/etcd/v3 v3.5.8/go.mod h1:vptUbt0q/yZF9X3xyZ0Q7XHoYJ8okR64FCRpZjz4Zyg= +go.opencensus.io v0.24.0/go.mod h1:vNK8G9p7aAivkbmorf4v+7Hgx+Zs0yY+0fOtgBfjQKo= go.opentelemetry.io/contrib v0.20.0 h1:ubFQUn0VCZ0gPwIoJfBJVpeBlyRMxu8Mm/huKWYd9p0= +go.opentelemetry.io/contrib v0.20.0/go.mod h1:G/EtFaa6qaN7+LxqfIAT3GiZa7Wv5DTBUzl5H4LY0Kc= go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.35.0 h1:xFSRQBbXF6VvYRf2lqMJXxoB72XI1K/azav8TekHHSw= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.35.0/go.mod h1:h8TWwRAhQpOd0aM5nYsRD8+flnkj+526GEIVlarH7eY= go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.35.0 h1:Ajldaqhxqw/gNzQA45IKFWLdG7jZuXX/wBW1d5qvbUI= +go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.35.0/go.mod h1:9NiG9I2aHTKkcxqCILhjtyNA1QEiCjdBACv4IvrFQ+c= go.opentelemetry.io/otel/exporters/otlp v0.20.0 h1:PTNgq9MRmQqqJY0REVbZFvwkYOA85vbdQU/nVfxDyqg= +go.opentelemetry.io/otel/exporters/otlp v0.20.0/go.mod h1:YIieizyaN77rtLJra0buKiNBOm9XQfkPEKBeuhoMwAM= go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.14.0 h1:/fXHZHGvro6MVqV34fJzDhi7sHGpX3Ej/Qjmfn003ho= +go.opentelemetry.io/otel/exporters/otlp/internal/retry v1.14.0/go.mod h1:UFG7EBMRdXyFstOwH028U0sVf+AvukSGhF0g8+dmNG8= go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.14.0 h1:TKf2uAs2ueguzLaxOCBXNpHxfO/aC7PAdDsSH0IbeRQ= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.14.0/go.mod h1:HrbCVv40OOLTABmOn1ZWty6CHXkU8DK/Urc43tHug70= go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.14.0 h1:ap+y8RXX3Mu9apKVtOkM6WSFESLM8K3wNQyOU8sWHcc= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.14.0/go.mod h1:5w41DY6S9gZrbjuq6Y+753e96WfPha5IcsOSZTtullM= go.opentelemetry.io/otel/metric v0.31.0 h1:6SiklT+gfWAwWUR0meEMxQBtihpiEs4c+vL9spDTqUs= +go.opentelemetry.io/otel/metric v0.31.0/go.mod h1:ohmwj9KTSIeBnDBm/ZwH2PSZxZzoOaG2xZeekTRzL5A= +go.opentelemetry.io/otel/sdk v1.14.0/go.mod h1:bwIC5TjrNG6QDCHNWvW4HLHtUQ4I+VQDsnjhvyZCALM= go.opentelemetry.io/otel/sdk/export/metric v0.20.0 h1:c5VRjxCXdQlx1HjzwGdQHzZaVI82b5EbBgOu2ljD92g= +go.opentelemetry.io/otel/sdk/export/metric v0.20.0/go.mod h1:h7RBNMsDJ5pmI1zExLi+bJK+Dr8NQCh0qGhm1KDnNlE= go.opentelemetry.io/otel/sdk/metric v0.20.0 h1:7ao1wpzHRVKf0OQ7GIxiQJA6X7DLX9o14gmVon7mMK8= +go.opentelemetry.io/otel/sdk/metric v0.20.0/go.mod h1:knxiS8Xd4E/N+ZqKmUPf3gTTZ4/0TjTXukfxjzSTpHE= go.opentelemetry.io/proto/otlp v0.19.0 h1:IVN6GR+mhC4s5yfcTbmzHYODqvWAp3ZedA2SJPI1Nnw= +go.opentelemetry.io/proto/otlp v0.19.0/go.mod h1:H7XAot3MsfNsj7EXtrA2q5xSNQ10UqI405h3+duxN4U= go.starlark.net v0.0.0-20200306205701-8dd3e2ee1dd5 h1:+FNtrFTmVw0YZGpBGX56XDee331t6JAXeK2bcyhLOOc= +go.starlark.net v0.0.0-20200306205701-8dd3e2ee1dd5/go.mod h1:nmDLcffg48OtT/PSW0Hg7FvpRQsQh5OSqIylirxKC7o= +go.step.sm/crypto v0.30.0/go.mod h1:6jFFgUoafyHvb6rNq3NJrBByof4SCzj1n8ThyXuMVAM= go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= +go.uber.org/goleak v1.2.1/go.mod h1:qlT2yGI9QafXHhZZLxlSuNsMw3FFLxBr+tBRlmO1xH4= go.uber.org/multierr v1.8.0/go.mod h1:7EAYxJLBy9rStEaz58O2t4Uvip6FSURkq8/ppBp95ak= go4.org v0.0.0-20201209231011-d4a079459e60 h1:iqAGo78tVOJXELHQFRjR6TMwItrvXH4hrGJ32I/NFF8= +go4.org v0.0.0-20201209231011-d4a079459e60/go.mod h1:CIiUVy99QCPfoE13bO4EZaz5GZMZXMSBGhxRdsvzbkg= gocloud.dev v0.29.0 h1:fBy0jwJSmxs0IjT0fE32MO+Mj+307VZQwyHaTyFZbC4= +gocloud.dev v0.29.0/go.mod h1:E3dAjji80g+lIkq4CQeF/BTWqv1CBeTftmOb+gpyapQ= golang.org/x/lint v0.0.0-20210508222113-6edffad5e616 h1:VLliZ0d+/avPrXXH+OakdXhpJuEoBZuwh1m2j7U6Iug= golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= golang.org/x/mod v0.9.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= @@ -2056,30 +2219,60 @@ golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= golang.org/x/tools v0.7.0/go.mod h1:4pg6aUX35JBAogB10C9AtvVL+qowtN4pT3CGSQex14s= golang.org/x/tools v0.9.1/go.mod h1:owI94Op576fPu3cIGQeHs3joujW/2Oc6MtlxbF5dfNc= golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 h1:H2TDz8ibqkAF6YGhCdN3jS9O0/s90v0rJh3X/OLHEUk= +golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8= gonum.org/v1/gonum v0.0.0-20190331200053-3d26580ed485 h1:OB/uP/Puiu5vS5QMRPrXCDWUPb+kt8f1KW8oQzFejQw= +gonum.org/v1/gonum v0.0.0-20190331200053-3d26580ed485/go.mod h1:2ltnJ7xHfj0zHS40VVPYEAAMTa3ZGguvHGBSJeRWqE0= +google.golang.org/api v0.123.0/go.mod h1:gcitW0lvnyWjSp9nKxAbdHKIZ6vF4aajGueeslZOyms= google.golang.org/grpc/cmd/protoc-gen-go-grpc v1.3.0 h1:rNBFJjBCOgVr9pWD7rs/knKL4FRTKgpZmsRfV214zcA= +google.golang.org/grpc/cmd/protoc-gen-go-grpc v1.3.0/go.mod h1:Dk1tviKTvMCz5tvh7t+fh94dhmQVHuCt2OzJB3CTW9Y= google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +gopkg.in/alexcesaro/statsd.v2 v2.0.0/go.mod h1:i0ubccKGzBVNBpdGV5MocxyA/XlLUJzA7SLonnE4drU= gopkg.in/cheggaaa/pb.v1 v1.0.28 h1:n1tBJnnK2r7g9OW2btFH91V92STTUevLXYFb8gy9EMk= +gopkg.in/cheggaaa/pb.v1 v1.0.28/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qStrOgw= gopkg.in/errgo.v2 v2.1.0 h1:0vLT13EuvQ0hNvakwLuFZ/jYrLp5F3kcWHXdRggjCE8= gopkg.in/fsnotify.v1 v1.4.7 h1:xOHLXZwVvI9hhs+cLKq5+I5onOuwQLhQwiu63xxlHs4= gopkg.in/natefinch/lumberjack.v2 v2.0.0 h1:1Lc07Kr7qY4U2YPouBjpCLxpiyxIVoxqXgkXLknAOE8= +gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k= gopkg.in/retry.v1 v1.0.3 h1:a9CArYczAVv6Qs6VGoLMio99GEs7kY9UzSF9+LD+iGs= +gopkg.in/retry.v1 v1.0.3/go.mod h1:FJkXmWiMaAo7xB+xhvDF59zhfjDWyzmyAxiT4dB688g= gopkg.in/src-d/go-billy.v4 v4.3.2 h1:0SQA1pRztfTFx2miS8sA97XvooFeNOmvUenF4o0EcVg= +gopkg.in/src-d/go-billy.v4 v4.3.2/go.mod h1:nDjArDMp+XMs1aFAESLRjfGSgfvoYN0hDfzEk0GjC98= gopkg.in/src-d/go-git.v4 v4.13.1 h1:SRtFyV8Kxc0UP7aCHcijOMQGPxHSmMOPrzulQWolkYE= +gopkg.in/src-d/go-git.v4 v4.13.1/go.mod h1:nx5NYcxdKxq5fpltdHnPa2Exj4Sx0EclMWZQbYDu2z8= gopkg.in/warnings.v0 v0.1.2 h1:wFXVbFY8DY5/xOe1ECiWdKCzZlxgshcYVNkBHstARME= +gopkg.in/warnings.v0 v0.1.2/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI= honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc h1:/hemPrYIhOhy8zYrNj+069zDB68us2sMGsfkFJO0iZs= k8s.io/apiserver v0.26.1 h1:6vmnAqCDO194SVCPU3MU8NcDgSqsUA62tBUSWrFXhsc= +k8s.io/apiserver v0.26.1/go.mod h1:wr75z634Cv+sifswE9HlAo5FQ7UoUauIICRlOE+5dCg= k8s.io/cli-runtime v0.25.0 h1:XBnTc2Fi+w818jcJGzhiJKQuXl8479sZ4FhtV5hVJ1Q= +k8s.io/cli-runtime v0.25.0/go.mod h1:bHOI5ZZInRHhbq12OdUiYZQN8ml8aKZLwQgt9QlLINw= k8s.io/cluster-bootstrap v0.25.0 h1:KJ2/r0dV+bLfTK5EBobAVKvjGel3N4Qqh3bvnzh9qPk= +k8s.io/cluster-bootstrap v0.25.0/go.mod h1:x/TCtY3EiuR/rODkA3SvVQT3uSssQLf9cXcmSjdDTe0= k8s.io/code-generator v0.26.1 h1:dusFDsnNSKlMFYhzIM0jAO1OlnTN5WYwQQ+Ai12IIlo= +k8s.io/code-generator v0.26.1/go.mod h1:OMoJ5Dqx1wgaQzKgc+ZWaZPfGjdRq/Y3WubFrZmeI3I= k8s.io/component-helpers v0.25.0 h1:vNzYfqnVXj7f+CPksduKVv2Z9kC+IDsOs9yaOyxZrj0= +k8s.io/component-helpers v0.25.0/go.mod h1:auaFj2bvb5Zmy0mLk4WJNmwP0w4e7Zk+/Tu9FFBGA20= k8s.io/gengo v0.0.0-20220913193501-391367153a38 h1:yGN2TZt9XIl5wrcYaFtVMqzP2GIzX5gIcOObCZCuDeA= +k8s.io/gengo v0.0.0-20220913193501-391367153a38/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E= k8s.io/klog v1.0.0 h1:Pt+yjF5aB1xDSVbau4VsWe+dQNzA0qv1LlXdC2dF6Q8= +k8s.io/klog v1.0.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I= k8s.io/kms v0.26.1 h1:JE0n4J4+8/Z+egvXz2BTJeJ9ecsm4ZSLKF7ttVXXm/4= +k8s.io/kms v0.26.1/go.mod h1:ReC1IEGuxgfN+PDCIpR6w8+XMmDE7uJhxcCwMZFdIYc= k8s.io/kube-aggregator v0.25.2 h1:NJHDtwmQR0EfoIQ00JNT8QrBIOljojtxtpXcTQqWZeg= +k8s.io/kube-aggregator v0.25.2/go.mod h1:7N5x4bK6jyxkEYCd77mgiz2uGTwiVs18MRwLwCPeUz8= k8s.io/metrics v0.25.0 h1:z/tyqXUCxvmFsKIO7GH6ulvogYvGp+pDmlz5ANSQVPE= +k8s.io/metrics v0.25.0/go.mod h1:HZZrbhuRX+fsDcRc3u59o2FbrKhqD67IGnoFECNmovc= +modernc.org/ccorpus v1.11.6/go.mod h1:2gEUTrWqdpH2pXsmTM1ZkjeSrUWDpjMu2T6m29L/ErQ= +modernc.org/httpfs v1.0.6/go.mod h1:7dosgurJGp0sPaRanU53W4xZYKh14wfzX420oZADeHM= +modernc.org/tcl v1.15.1/go.mod h1:aEjeGJX2gz1oWKOLDVZ2tnEWLUrIn8H+GFu+akoDhqs= +modernc.org/z v1.7.0/go.mod h1:hVdgNMh8ggTuRG1rGU8x+xGRFfiQUIAw0ZqlPy8+HyQ= sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.35 h1:+xBL5uTc+BkPBwmMi3vYfUJjq+N3K+H6PXeETwf5cPI= +sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.35/go.mod h1:WxjusMwXlKzfAs4p9km6XJRndVt2FROgMVCE4cdohFo= sigs.k8s.io/kustomize/api v0.12.1 h1:7YM7gW3kYBwtKvoY216ZzY+8hM+lV53LUayghNRJ0vM= +sigs.k8s.io/kustomize/api v0.12.1/go.mod h1:y3JUhimkZkR6sbLNwfJHxvo1TCLwuwm14sCYnkH6S1s= sigs.k8s.io/kustomize/kustomize/v4 v4.5.7 h1:cDW6AVMl6t/SLuQaezMET8hgnadZGIAr8tUrxFVOrpg= +sigs.k8s.io/kustomize/kustomize/v4 v4.5.7/go.mod h1:VSNKEH9D9d9bLiWEGbS6Xbg/Ih0tgQalmPvntzRxZ/Q= sigs.k8s.io/kustomize/kyaml v0.13.9 h1:Qz53EAaFFANyNgyOEJbT/yoIHygK40/ZcvU3rgry2Tk= +sigs.k8s.io/kustomize/kyaml v0.13.9/go.mod h1:QsRbD0/KcU+wdk0/L0fIp2KLnohkVzs6fQ85/nOXac4= sigs.k8s.io/release-utils v0.7.4 h1:17LmJrydpUloTCtaoWj95uKlcrUp4h2A9Sa+ZL+lV9w= +sigs.k8s.io/release-utils v0.7.4/go.mod h1:JEt2QPHItd5Pg2UKLAU8PEaSlF4bUjCZimpxFDgymVU= diff --git a/test/e2e/framework/go.mod b/test/e2e/framework/go.mod index 330a91f8b..4dd859ec6 100644 --- a/test/e2e/framework/go.mod +++ b/test/e2e/framework/go.mod @@ -1,6 +1,6 @@ module github.com/vmware-tanzu/tanzu-cli/test/e2e/framework -go 1.19 +go 1.21 require ( github.com/onsi/ginkgo/v2 v2.10.0 From ced4f49ea49164842735b6fc34beb9e7b7de594c Mon Sep 17 00:00:00 2001 From: Panchajanya Mysarla Date: Mon, 11 Sep 2023 14:19:49 -0500 Subject: [PATCH 2/4] Update go version to 1.21 in GitHub workflows --- .github/workflows/build.yaml | 4 ++-- .github/workflows/cli-coexistence_tests.yaml | 4 ++-- .github/workflows/cli_core_e2e_test.yaml | 4 ++-- .github/workflows/cli_core_unit_test.yaml | 4 ++-- .github/workflows/release.yaml | 4 ++-- 5 files changed, 10 insertions(+), 10 deletions(-) diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 590bf8b8c..bbe8a52ad 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -12,10 +12,10 @@ jobs: name: Build runs-on: ubuntu-latest steps: - - name: Set up Go 1.19 + - name: Set up Go 1.21 uses: actions/setup-go@v3 with: - go-version: 1.19 + go-version: 1.21 id: go - name: Config credentials diff --git a/.github/workflows/cli-coexistence_tests.yaml b/.github/workflows/cli-coexistence_tests.yaml index 4664ed3c8..c483180b9 100644 --- a/.github/workflows/cli-coexistence_tests.yaml +++ b/.github/workflows/cli-coexistence_tests.yaml @@ -14,10 +14,10 @@ jobs: - name: Checkout code uses: actions/checkout@v1 - - name: Set up Go 1.x + - name: Set up Go 1.21 uses: actions/setup-go@v3 with: - go-version: 1.19 + go-version: 1.21 id: go - name: go cache diff --git a/.github/workflows/cli_core_e2e_test.yaml b/.github/workflows/cli_core_e2e_test.yaml index aa0c2b55f..69e3845e2 100644 --- a/.github/workflows/cli_core_e2e_test.yaml +++ b/.github/workflows/cli_core_e2e_test.yaml @@ -14,10 +14,10 @@ jobs: - name: Check out code into the Go module directory uses: actions/checkout@v1 - - name: Set up Go 1.x + - name: Set up Go 1.21 uses: actions/setup-go@v3 with: - go-version: 1.19 + go-version: 1.21 id: go - name: go cache diff --git a/.github/workflows/cli_core_unit_test.yaml b/.github/workflows/cli_core_unit_test.yaml index b43183263..a205b764a 100644 --- a/.github/workflows/cli_core_unit_test.yaml +++ b/.github/workflows/cli_core_unit_test.yaml @@ -14,10 +14,10 @@ jobs: - name: Check out code into the Go module directory uses: actions/checkout@v1 - - name: Set up Go 1.x + - name: Set up Go 1.21 uses: actions/setup-go@v3 with: - go-version: 1.19 + go-version: 1.21 id: go - name: go cache diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index a194e06d7..3782a4dcd 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -27,10 +27,10 @@ jobs: echo "free space after cleanup:" df -h - - name: Set up Go 1.x + - name: Set up Go 1.21 uses: actions/setup-go@v3 with: - go-version: 1.18 + go-version: 1.21 id: go - name: Check out code into the Go module directory From 3726c79011eb0a21a6db5a799392fd16bf32a814 Mon Sep 17 00:00:00 2001 From: Panchajanya Mysarla Date: Mon, 11 Sep 2023 14:20:19 -0500 Subject: [PATCH 3/4] Update tools and linters --- .golangci.yaml | 100 ++++++++++++++++++++++++++++++++------------ hack/tools/Makefile | 12 +++--- 2 files changed, 79 insertions(+), 33 deletions(-) diff --git a/.golangci.yaml b/.golangci.yaml index 6c26724cd..85e8f561d 100644 --- a/.golangci.yaml +++ b/.golangci.yaml @@ -1,4 +1,63 @@ linters-settings: + depguard: + rules: + main: + files: + - $all + - "!$test" + allow: + - $gostd + - github.com/AlecAivazis/survey/v2 + - github.com/Masterminds/semver + - github.com/adrg/xdg + - github.com/cppforlife/go-cli-ui + - github.com/fatih/color + - github.com/gobwas/glob + - github.com/golang-jwt/jwt + - github.com/google/gnostic + - github.com/google/go-containerregistry + - github.com/google/uuid + - github.com/gorilla/mux + - github.com/imdario/mergo + - github.com/juju/fslock + - github.com/k14s/kbld + - github.com/lithammer/dedent + - github.com/logrusorgru/aurora + - github.com/novln/docker-parser + - github.com/onsi/ginkgo/v2 + - github.com/onsi/gomega + - github.com/otiai10/copy + - github.com/pkg/errors + - github.com/sigstore/cosign/v2 + - github.com/sigstore/sigstore + - github.com/spf13/afero + - github.com/spf13/cobra + - github.com/spf13/pflag + - github.com/stretchr/testify + - github.com/tj/assert + - github.com/verybluebot/tarinator-go + - github.com/vmware-tanzu/carvel-imgpkg + - github.com/vmware-tanzu/carvel-ytt + - github.com/vmware-tanzu/tanzu-cli + - github.com/vmware-tanzu/tanzu-cli/test/e2e/framework + - github.com/vmware-tanzu/tanzu-framework/capabilities/client + - github.com/vmware-tanzu/tanzu-plugin-runtime + - go.pinniped.dev + - go.uber.org/multierr + - google.golang.org/grpc + - golang.org/x/oauth2 + - golang.org/x/sync/errgroup + - golang.org/x/mod/semver + - gopkg.in/yaml.v2 + - gopkg.in/yaml.v3 + - k8s.io/api + - k8s.io/apimachinery + - k8s.io/client-go + - modernc.org/sqlite + - sigs.k8s.io/controller-runtime + deny: + - pkg: github.com/sirupsen/logrus + desc: not allowed dupl: threshold: 100 funlen: @@ -7,7 +66,7 @@ linters-settings: goheader: values: const: - COMPANY: VMware, Inc. + COMPANY: 'VMware, Inc.' LICENSE: Apache-2.0 regexp: YEAR: 20\d*-*\d* @@ -36,7 +95,6 @@ linters-settings: local-prefixes: github.com/vmware-tanzu govet: check-shadowing: true - misspell: locale: US nolintlint: @@ -46,11 +104,9 @@ linters-settings: require-specific: false # don't require nolint directives to be specific about which linter is being skipped whitespace: multi-func: true - linters: disable-all: true enable: - - deadcode - depguard - dogsled - dupl @@ -75,14 +131,10 @@ linters: - typecheck - unconvert - unused - - varcheck - whitespace - bodyclose - noctx - rowserrcheck - - structcheck - - unparam - # don't enable: # - asciicheck # - exhaustive @@ -102,49 +154,43 @@ linters: issues: exclude: - - 'declaration of "(err|ctx)" shadows declaration at' - - "unnamedResult: consider giving a name to these results" - - "(Expect directory permissions to be 0750 or less|Expect (WriteFile|file) permissions to be 0600 or less)" - + - declaration of "(err|ctx)" shadows declaration at + - 'unnamedResult: consider giving a name to these results' + - >- + (Expect directory permissions to be 0750 or less|Expect (WriteFile|file) + permissions to be 0600 or less) exclude-rules: + - linters: + - gosec + text: 'G602:' - path: _test\.go linters: - dupl - gocritic - funlen - # https://github.com/go-critic/go-critic/issues/926 - linters: - gocritic - text: "unnecessaryDefer:" - + text: 'unnecessaryDefer:' - linters: - revive - text: "that stutters" - + text: that stutters - path: zz_.*\.go linters: - revive - text: "it will be inferred from" - - # Ignore the deprecated function use (staticcheck, SA1019) for the test files + text: it will be inferred from - path: (.+)_test.go linters: - staticcheck - text: "SA1019:" - + text: 'SA1019:' include: - - EXC0011 # disable excluding of issues about missing package comments from stylecheck - - # Show all errors for all linters. Setting these to 0 disables limiting error reporting. + - EXC0011 max-same-issues: 0 max-issues-per-linter: 0 - run: skip-dirs: - fakes/ timeout: 15m - # golangci.com configuration # https://github.com/golangci/golangci/wiki/Configuration service: diff --git a/hack/tools/Makefile b/hack/tools/Makefile index 47c02e6bb..2d9b2ff1d 100644 --- a/hack/tools/Makefile +++ b/hack/tools/Makefile @@ -19,15 +19,15 @@ export GOPROXY ROOT_DIR:=$(shell git rev-parse --show-toplevel) BIN_DIR := bin -GOIMPORTS_VERSION=0.1.12 -VALE_VERSION=2.20.1 -GOLANGCI_LINT_VERSION=1.46.0 +GOIMPORTS_VERSION=0.13.0 +VALE_VERSION=2.28.3 +GOLANGCI_LINT_VERSION=1.54.2 MISSPELL_VERSION=0.3.4 CONTROLLER_TOOLS_VERSION=0.9.2 -IMGPKG_VERSION=v0.35.0 +IMGPKG_VERSION=v0.37.3 KUBECTL_VERSION=v1.26.0 KIND_VERSION=v0.17.0 -GINKGO_VERSION=v2.10.0 +GINKGO_VERSION=v2.12.0 COSIGN_VERSION=2.0.3-0.20230519173114-f21081a18209 # Host information. @@ -45,7 +45,7 @@ KUBECTL := $(BIN_DIR)/kubectl KIND := $(BIN_DIR)/kind GINKGO := $(BIN_DIR)/ginkgo COSIGN := $(BIN_DIR)/cosign -GOJUNITREPORT := $(BIN_DIR)/go-junit-report +GOJUNITREPORT := $(BIN_DIR)/go-junit-report ## -------------------------------------- ## Help From dbff5e1217485a9ec0b347179106d8714eae1a71 Mon Sep 17 00:00:00 2001 From: Panchajanya Mysarla Date: Mon, 11 Sep 2023 14:20:35 -0500 Subject: [PATCH 4/4] Fix lint issues --- cmd/plugin/builder/command/cli_compile.go | 2 +- .../builder/command/publish/helper_test.go | 1 + cmd/plugin/builder/inventory_plugin.go | 8 +- cmd/plugin/test/test/main.go | 2 +- cmd/tanzu/main.go | 7 +- pkg/airgapped/plugin_bundle_test.go | 6 +- pkg/auth/csp/grpc.go | 6 +- pkg/auth/csp/selfmanaged.go | 1 + pkg/auth/tkg/cluster_pinniped_info.go | 6 +- pkg/auth/tkg/kube_config.go | 11 +- pkg/auth/wcp/discovery.go | 1 + pkg/carvelhelpers/package.go | 2 +- pkg/carvelhelpers/ytt.go | 8 +- pkg/command/context.go | 16 +- pkg/command/discovery_source.go | 235 ++++- pkg/command/discovery_source_test.go | 419 ++------- pkg/command/login.go | 76 +- pkg/command/plugin.go | 329 +++++-- pkg/command/root_test.go | 2 +- pkg/config/defaults.go | 10 +- pkg/cosignhelper/cosignverify.go | 3 +- pkg/discovery/oci_dbbacked_test.go | 8 +- pkg/discovery/rest.go | 3 +- pkg/discovery/utils.go | 10 +- pkg/plugincmdtree/plugins_cache_test.go | 2 +- pkg/plugininventory/sqlite_inventory_test.go | 4 +- pkg/pluginmanager/default_discoveries.go | 4 +- pkg/pluginmanager/manager.go | 404 ++++++++- pkg/pluginmanager/manager_test.go | 852 ++++++++++++++---- pkg/registry/client.go | 2 +- pkg/telemetry/client_test.go | 2 +- pkg/telemetry/sqlite_metrics_db.go | 2 + pkg/telemetry/sqlite_metrics_db_test.go | 1 + 33 files changed, 1658 insertions(+), 787 deletions(-) diff --git a/cmd/plugin/builder/command/cli_compile.go b/cmd/plugin/builder/command/cli_compile.go index 918700e70..4291519f0 100644 --- a/cmd/plugin/builder/command/cli_compile.go +++ b/cmd/plugin/builder/command/cli_compile.go @@ -126,7 +126,7 @@ func Compile(compileArgs *PluginCompileArgs) error { guard := make(chan struct{}, maxConcurrent) // Mix up IDs so we don't always get the same set. - randSkew := rand.Intn(len(helpers.Identifiers)) // nolint:gosec + randSkew := rand.Intn(len(helpers.Identifiers)) //nolint:gosec var wg sync.WaitGroup plugins := make(chan cli.Plugin, len(files)) fatalErrors := make(chan helpers.ErrInfo, len(files)) diff --git a/cmd/plugin/builder/command/publish/helper_test.go b/cmd/plugin/builder/command/publish/helper_test.go index 37ef915a3..e15eae393 100644 --- a/cmd/plugin/builder/command/publish/helper_test.go +++ b/cmd/plugin/builder/command/publish/helper_test.go @@ -66,6 +66,7 @@ func convertVersionToStringArray(arrOsArchInfo []osArch) []string { return oa } +//nolint:unparam func createDummyArtifactDir(directoryBasePath, pluginName, recommendedVersion, description string, versions []string) { var err error diff --git a/cmd/plugin/builder/inventory_plugin.go b/cmd/plugin/builder/inventory_plugin.go index ca1af3208..f0ba03f75 100644 --- a/cmd/plugin/builder/inventory_plugin.go +++ b/cmd/plugin/builder/inventory_plugin.go @@ -90,9 +90,9 @@ type inventoryPluginActivateDeactivateFlags struct { InventoryDBFile string } -func newInventoryPluginActivateCmd() *cobra.Command { // nolint:dupl +func newInventoryPluginActivateCmd() *cobra.Command { //nolint:dupl pluginActivateCmd, flags := getActivateDeactivateBaseCmd() - pluginActivateCmd.Use = "activate" // nolint:goconst + pluginActivateCmd.Use = "activate" //nolint:goconst pluginActivateCmd.Short = "Activate the existing plugin in the inventory database available on the remote repository" pluginActivateCmd.Example = "" pluginActivateCmd.RunE = func(cmd *cobra.Command, args []string) error { @@ -111,9 +111,9 @@ func newInventoryPluginActivateCmd() *cobra.Command { // nolint:dupl return pluginActivateCmd } -func newInventoryPluginDeactivateCmd() *cobra.Command { // nolint:dupl +func newInventoryPluginDeactivateCmd() *cobra.Command { //nolint:dupl pluginDeactivateCmd, flags := getActivateDeactivateBaseCmd() - pluginDeactivateCmd.Use = "deactivate" // nolint:goconst + pluginDeactivateCmd.Use = "deactivate" //nolint:goconst pluginDeactivateCmd.Short = "Deactivate the existing plugin in the inventory database available on the remote repository" pluginDeactivateCmd.Example = "" pluginDeactivateCmd.RunE = func(cmd *cobra.Command, args []string) error { diff --git a/cmd/plugin/test/test/main.go b/cmd/plugin/test/test/main.go index 332c3ed84..a66b55e98 100644 --- a/cmd/plugin/test/test/main.go +++ b/cmd/plugin/test/test/main.go @@ -27,7 +27,7 @@ func main() { } } -func test(c *cobra.Command, _ []string) error { +func test(_ *cobra.Command, _ []string) error { return nil } diff --git a/cmd/tanzu/main.go b/cmd/tanzu/main.go index 7966558ea..2d55430bc 100644 --- a/cmd/tanzu/main.go +++ b/cmd/tanzu/main.go @@ -17,10 +17,9 @@ func main() { // If a plugin exited with an error, we don't want to print its // exit status as a string, but want to use it as our own exit code. os.Exit(errStr.ExitCode()) - } else { - // We got an error other than a plugin exiting with an error, let's - // print the error message. - log.Fatal(err, "") } + // We got an error other than a plugin exiting with an error, let's + // print the error message. + log.Fatal(err, "") } } diff --git a/pkg/airgapped/plugin_bundle_test.go b/pkg/airgapped/plugin_bundle_test.go index 4c31f5662..5eac40388 100644 --- a/pkg/airgapped/plugin_bundle_test.go +++ b/pkg/airgapped/plugin_bundle_test.go @@ -233,7 +233,7 @@ imagesToCopy: // downloadInventoryMetadataImageWithNoExistingPlugins fakes the image downloads and puts a database // with the table schemas created to provided path - downloadInventoryMetadataImageWithNoExistingPlugins := func(image, path string) error { + downloadInventoryMetadataImageWithNoExistingPlugins := func(_, path string) error { dbFile := filepath.Join(path, plugininventory.SQliteInventoryMetadataDBFileName) err := utils.SaveFile(dbFile, []byte{}) Expect(err).ToNot(HaveOccurred()) @@ -247,7 +247,7 @@ imagesToCopy: // downloadInventoryMetadataImageWithExistingPlugins fakes the image downloads and puts a database // with the table schemas created to provided path - downloadInventoryMetadataImageWithExistingPlugins := func(image, path string) error { + downloadInventoryMetadataImageWithExistingPlugins := func(_, path string) error { dbFile := filepath.Join(path, plugininventory.SQliteInventoryMetadataDBFileName) err := utils.SaveFile(dbFile, []byte{}) Expect(err).ToNot(HaveOccurred()) @@ -272,7 +272,7 @@ imagesToCopy: } // copyImageToTarStub fakes the image downloads and creates a fake tar.gz file for images - copyImageToTarStub := func(image, tarfile string) error { + copyImageToTarStub := func(_, tarfile string) error { _, err := os.Create(tarfile) Expect(err).ToNot(HaveOccurred()) return nil diff --git a/pkg/auth/csp/grpc.go b/pkg/auth/csp/grpc.go index f39b4705a..cf619155f 100644 --- a/pkg/auth/csp/grpc.go +++ b/pkg/auth/csp/grpc.go @@ -62,14 +62,14 @@ type configSource struct { // Token fetches the token. func (c *configSource) Token() (*oauth2.Token, error) { - g, err := c.GetCurrentServer() // nolint:staticcheck // Deprecated + g, err := c.GetCurrentServer() //nolint:staticcheck // Deprecated if err != nil { return nil, err } if g == nil { return nil, fmt.Errorf("current server is nil") } - if !g.IsGlobal() { // nolint:staticcheck // Deprecated + if !g.IsGlobal() { //nolint:staticcheck // Deprecated return nil, fmt.Errorf("trying to fetch token for non global server") } var expiration time.Time @@ -123,7 +123,7 @@ type TokenSource struct { } // GetRequestMetadata gets the request metadata as a map from a TokenSource. -func (ts TokenSource) GetRequestMetadata(ctx context.Context, uri ...string) (map[string]string, error) { +func (ts TokenSource) GetRequestMetadata(_ context.Context, _ ...string) (map[string]string, error) { token, err := ts.Token() if err != nil { return nil, err diff --git a/pkg/auth/csp/selfmanaged.go b/pkg/auth/csp/selfmanaged.go index fec8a3455..3bb83e173 100644 --- a/pkg/auth/csp/selfmanaged.go +++ b/pkg/auth/csp/selfmanaged.go @@ -96,6 +96,7 @@ func runLocalListener() error { mux := http.NewServeMux() mux.HandleFunc("/callback", callbackHandler) tokenExchange, tokenExchangeComplete = context.WithCancel(context.TODO()) + //nolint:gosec l := http.Server{ Addr: "", Handler: mux, diff --git a/pkg/auth/tkg/cluster_pinniped_info.go b/pkg/auth/tkg/cluster_pinniped_info.go index 83af30def..14373521c 100644 --- a/pkg/auth/tkg/cluster_pinniped_info.go +++ b/pkg/auth/tkg/cluster_pinniped_info.go @@ -60,7 +60,7 @@ func GetClusterInfoFromCluster(clusterAPIServerURL, configmapName, endpointCACer clusterAPIServerURL = strings.TrimRight(clusterAPIServerURL, " /") clusterInfoURL := clusterAPIServerURL + fmt.Sprintf("/api/v1/namespaces/%s/configmaps/%s", KubePublicNamespace, configmapName) - req, _ := http.NewRequest("GET", clusterInfoURL, http.NoBody) + req, _ := http.NewRequest("GET", clusterInfoURL, http.NoBody) //nolint:noctx tlsConfig, err := GetTLSConfig(endpointCACertPath, skipTLSVerify) if err != nil { @@ -126,7 +126,7 @@ func GetPinnipedInfoFromCluster(clusterInfo *clientcmdapi.Cluster, discoveryPort } } pinnipedInfoURL := endpoint + fmt.Sprintf("/api/v1/namespaces/%s/configmaps/pinniped-info", KubePublicNamespace) - req, _ := http.NewRequest("GET", pinnipedInfoURL, http.NoBody) + req, _ := http.NewRequest("GET", pinnipedInfoURL, http.NoBody) //nolint:noctx pool := x509.NewCertPool() pool.AppendCertsFromPEM(clusterInfo.CertificateAuthorityData) clusterClient := &http.Client{ @@ -187,7 +187,7 @@ func GetTLSConfig(caCertPath string, skipTLSVerify bool) (*tls.Config, error) { return &tls.Config{ RootCAs: pool, MinVersion: tls.VersionTLS12, - // nolint:gosec + //nolint:gosec // skipTLSVerify: true is only possible if the user has explicitly enabled insecure-skip-tls-verify. InsecureSkipVerify: skipTLSVerify, }, nil diff --git a/pkg/auth/tkg/kube_config.go b/pkg/auth/tkg/kube_config.go index 24f4a2905..c62a460cf 100644 --- a/pkg/auth/tkg/kube_config.go +++ b/pkg/auth/tkg/kube_config.go @@ -65,30 +65,30 @@ func KubeconfigWithPinnipedAuthLoginPlugin(endpoint string, options *KubeConfigO clusterInfo, err := GetClusterInfoFromCluster(endpoint, discoveryStrategy.ClusterInfoConfigMap, endpointCACertPath, skipTLSVerify) if err != nil { err = errors.Wrap(err, "failed to get cluster-info") - return + return "", "", err } pinnipedInfo, err := GetPinnipedInfoFromCluster(clusterInfo, discoveryStrategy.DiscoveryPort) if err != nil { err = errors.Wrap(err, "failed to get pinniped-info") - return + return "", "", err } if pinnipedInfo == nil { err = errors.New("failed to get pinniped-info from cluster") - return + return "", "", err } config, err := GetPinnipedKubeconfig(clusterInfo, pinnipedInfo, pinnipedInfo.Data.ClusterName, pinnipedInfo.Data.Issuer) if err != nil { err = errors.Wrap(err, "unable to get the kubeconfig") - return + return "", "", err } kubeconfigBytes, err := json.Marshal(config) if err != nil { err = errors.Wrap(err, "unable to marshall the kubeconfig") - return + return "", "", err } return MergeAndSaveKubeconfigBytes(kubeconfigBytes, options) @@ -208,7 +208,6 @@ func TanzuLocalKubeConfigPath() (path string, err error) { } func MergeAndSaveKubeconfigBytes(kubeconfigBytes []byte, options *KubeConfigOptions) (mergeFilePath, currentContext string, err error) { - mergeFilePath = "" if options != nil && options.MergeFilePath != "" { mergeFilePath = options.MergeFilePath } else { diff --git a/pkg/auth/wcp/discovery.go b/pkg/auth/wcp/discovery.go index 4aa4e9420..4cc0e29af 100644 --- a/pkg/auth/wcp/discovery.go +++ b/pkg/auth/wcp/discovery.go @@ -22,6 +22,7 @@ const ( func IsVSphereSupervisor(endpoint string, httpClient *http.Client) (bool, error) { loginBannerURL := fmt.Sprintf("%s/wcp/loginbanner", endpoint) + //nolint:noctx req, _ := http.NewRequest("GET", loginBannerURL, http.NoBody) resp, err := httpClient.Do(req) diff --git a/pkg/carvelhelpers/package.go b/pkg/carvelhelpers/package.go index 6d507b15c..81fe600d3 100644 --- a/pkg/carvelhelpers/package.go +++ b/pkg/carvelhelpers/package.go @@ -29,7 +29,7 @@ func ProcessCarvelPackage(image string, valuesFiles ...string) ([]byte, error) { } // CarvelPackageProcessor processes a carvel package and returns a configuration YAML file -func CarvelPackageProcessor(pkgDir, image string, valuesFiles ...string) ([]byte, error) { +func CarvelPackageProcessor(pkgDir, _ string, valuesFiles ...string) ([]byte, error) { // Each package contains `config` and `.imgpkg` directory // `config` directory contains ytt files // `.imgpkg` directory contains ImageLock configuration for ImageResolution diff --git a/pkg/carvelhelpers/ytt.go b/pkg/carvelhelpers/ytt.go index 2e0634985..64c09b15f 100644 --- a/pkg/carvelhelpers/ytt.go +++ b/pkg/carvelhelpers/ytt.go @@ -42,13 +42,13 @@ type NoopUI struct{} var _ yttui.UI = NoopUI{} // Printf noop print -func (ui NoopUI) Printf(str string, args ...interface{}) {} +func (ui NoopUI) Printf(_ string, _ ...interface{}) {} // Debugf noop debug -func (ui NoopUI) Debugf(str string, args ...interface{}) {} +func (ui NoopUI) Debugf(_ string, _ ...interface{}) {} // Warnf noop warn -func (ui NoopUI) Warnf(str string, args ...interface{}) {} +func (ui NoopUI) Warnf(_ string, _ ...interface{}) {} // DebugWriter noop debug writer func (ui NoopUI) DebugWriter() io.Writer { @@ -57,7 +57,7 @@ func (ui NoopUI) DebugWriter() io.Writer { type noopWriter struct{} -func (n noopWriter) Write(p []byte) (int, error) { +func (n noopWriter) Write(_ []byte) (int, error) { return 0, nil } diff --git a/pkg/command/context.go b/pkg/command/context.go index abf00986a..e6d01d7fd 100644 --- a/pkg/command/context.go +++ b/pkg/command/context.go @@ -250,7 +250,7 @@ func createContextWithKubeconfig() (context *configtypes.Context, err error) { promptOpts..., ) if err != nil { - return + return context, err } } else if kubeConfig == "" { kubeConfig = getDefaultKubeconfigPath() @@ -266,7 +266,7 @@ func createContextWithKubeconfig() (context *configtypes.Context, err error) { promptOpts..., ) if err != nil { - return + return context, err } } kubeContext = strings.TrimSpace(kubeContext) @@ -280,7 +280,7 @@ func createContextWithKubeconfig() (context *configtypes.Context, err error) { promptOpts..., ) if err != nil { - return + return context, err } } ctxName = strings.TrimSpace(ctxName) @@ -290,7 +290,7 @@ func createContextWithKubeconfig() (context *configtypes.Context, err error) { } if exists { err = fmt.Errorf("context %q already exists", ctxName) - return + return context, err } context = &configtypes.Context{ @@ -317,7 +317,7 @@ func createContextWithEndpoint() (context *configtypes.Context, err error) { promptOpts..., ) if err != nil { - return + return context, err } } endpoint = strings.TrimSpace(endpoint) @@ -331,7 +331,7 @@ func createContextWithEndpoint() (context *configtypes.Context, err error) { promptOpts..., ) if err != nil { - return + return context, err } } ctxName = strings.TrimSpace(ctxName) @@ -341,7 +341,7 @@ func createContextWithEndpoint() (context *configtypes.Context, err error) { } if exists { err = fmt.Errorf("context %q already exists", ctxName) - return + return context, err } if isGlobalContext(endpoint) || selfManaged { @@ -355,7 +355,7 @@ func createContextWithEndpoint() (context *configtypes.Context, err error) { tkf := NewTKGKubeconfigFetcher(endpoint, endpointCACertPath, skipTLSVerify) kubeConfig, kubeContext, err = tkf.GetPinnipedKubeconfig() if err != nil { - return + return context, err } context = &configtypes.Context{ diff --git a/pkg/command/discovery_source.go b/pkg/command/discovery_source.go index b98e05530..88cbab2c0 100644 --- a/pkg/command/discovery_source.go +++ b/pkg/command/discovery_source.go @@ -5,25 +5,27 @@ package command import ( "fmt" - - "github.com/pkg/errors" + "strings" "github.com/vmware-tanzu/tanzu-cli/pkg/cli" "github.com/vmware-tanzu/tanzu-cli/pkg/config" + "github.com/vmware-tanzu/tanzu-cli/pkg/constants" "github.com/vmware-tanzu/tanzu-cli/pkg/discovery" "github.com/vmware-tanzu/tanzu-cli/pkg/pluginmanager" + "github.com/pkg/errors" "github.com/spf13/cobra" "github.com/vmware-tanzu/tanzu-plugin-runtime/component" configlib "github.com/vmware-tanzu/tanzu-plugin-runtime/config" configtypes "github.com/vmware-tanzu/tanzu-plugin-runtime/config/types" + "github.com/vmware-tanzu/tanzu-cli/pkg/common" "github.com/vmware-tanzu/tanzu-plugin-runtime/log" ) var ( - uri string + discoverySourceType, discoverySourceName, uri string ) func newDiscoverySourceCmd() *cobra.Command { @@ -34,13 +36,43 @@ func newDiscoverySourceCmd() *cobra.Command { } discoverySourceCmd.SetUsageFunc(cli.SubCmdUsageFunc) + listDiscoverySourceCmd := newListDiscoverySourceCmd() + updateDiscoverySourceCmd := newUpdateDiscoverySourceCmd() + deleteDiscoverySourceCmd := newDeleteDiscoverySourceCmd() + + listDiscoverySourceCmd.Flags().StringVarP(&outputFormat, "output", "o", "", "Output format (yaml|json|table)") + discoverySourceCmd.AddCommand( - newListDiscoverySourceCmd(), - newUpdateDiscoverySourceCmd(), - newDeleteDiscoverySourceCmd(), - newInitDiscoverySourceCmd(), + listDiscoverySourceCmd, + updateDiscoverySourceCmd, + deleteDiscoverySourceCmd, ) + if !configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + discoverySourceCmd.AddCommand(newInitDiscoverySourceCmd()) + updateDiscoverySourceCmd.Flags().StringVarP(&uri, "uri", "u", "", "URI for discovery source. The URI must be of an OCI image") + } else { + updateDiscoverySourceCmd.Flags().StringVarP(&discoverySourceType, "type", "t", "", "type of discovery source") + updateDiscoverySourceCmd.Flags().StringVarP(&uri, "uri", "u", "", "URI for discovery source. The URI format might be different based on the type of discovery source") + + // The "add" and "delete" plugin source commands are not needed for the central repo + addDiscoverySourceCmd := newAddDiscoverySourceCmd() + + // TODO: when reactivating the "plugin source add" command, we need to replace the --name flag + // with a argument for consistency with other commands + addDiscoverySourceCmd.Flags().StringVarP(&discoverySourceName, "name", "n", "", "name of discovery source") + addDiscoverySourceCmd.Flags().StringVarP(&discoverySourceType, "type", "t", "", "type of discovery source") + addDiscoverySourceCmd.Flags().StringVarP(&uri, "uri", "u", "", "URI for discovery source. The URI format might be different based on the type of discovery source") + + // Not handling errors below because cobra handles the error when flag user doesn't provide these required flags + _ = cobra.MarkFlagRequired(addDiscoverySourceCmd.Flags(), "name") + _ = cobra.MarkFlagRequired(addDiscoverySourceCmd.Flags(), "type") + _ = cobra.MarkFlagRequired(addDiscoverySourceCmd.Flags(), "uri") + + discoverySourceCmd.AddCommand( + addDiscoverySourceCmd, + ) + } return discoverySourceCmd } @@ -49,40 +81,96 @@ func newListDiscoverySourceCmd() *cobra.Command { Use: "list", Short: "List available discovery sources", RunE: func(cmd *cobra.Command, args []string) error { - output := component.NewOutputWriter(cmd.OutOrStdout(), outputFormat, "name", "image") - discoverySources, err := configlib.GetCLIDiscoverySources() - for _, ds := range discoverySources { - if ds.OCI != nil { - output.AddRow(ds.OCI.Name, ds.OCI.Image) + var err error + if !configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + output := component.NewOutputWriter(cmd.OutOrStdout(), outputFormat, "name", "image") + discoverySources, err := configlib.GetCLIDiscoverySources() + for _, ds := range discoverySources { + if ds.OCI != nil { + output.AddRow(ds.OCI.Name, ds.OCI.Image) + } + } + testPluginSources := pluginmanager.GetAdditionalTestPluginDiscoveries() + for _, ds := range testPluginSources { + if ds.OCI != nil { + output.AddRow(ds.OCI.Name+" (test only)", ds.OCI.Image) + } } + output.Render() + return err + } + + output := component.NewOutputWriter(cmd.OutOrStdout(), outputFormat, "name", "type", "scope") + + // List standalone scoped discoveries + discoverySources, _ := configlib.GetCLIDiscoverySources() + if discoverySources != nil { + outputFromDiscoverySources(discoverySources, common.PluginScopeStandalone, output) } - testPluginSources := pluginmanager.GetAdditionalTestPluginDiscoveries() - for _, ds := range testPluginSources { - if ds.OCI != nil { - output.AddRow(ds.OCI.Name+" (test only)", ds.OCI.Image) + + // If context-target feature is activated, get discovery sources from all active context + // else get discovery sources from current server + if configlib.IsFeatureActivated(constants.FeatureContextCommand) { + mapContexts, err := configlib.GetAllCurrentContextsMap() + if err == nil { + for _, context := range mapContexts { + outputFromDiscoverySources(context.DiscoverySources, common.PluginScopeContext, output) + } + } + } else { + server, err := configlib.GetCurrentServer() //nolint:staticcheck // Deprecated + if err == nil && server != nil { + outputFromDiscoverySources(server.DiscoverySources, common.PluginScopeContext, output) } } output.Render() return err }, } + return listDiscoverySourceCmd +} - listDiscoverySourceCmd.Flags().StringVarP(&outputFormat, "output", "o", "", "Output format (yaml|json|table)") +func outputFromDiscoverySources(discoverySources []configtypes.PluginDiscovery, scope string, output component.OutputWriter) { + for _, ds := range discoverySources { + dsName, dsType := discoverySourceNameAndType(ds) + output.AddRow(dsName, dsType, scope) + } +} +func newAddDiscoverySourceCmd() *cobra.Command { + var addDiscoverySourceCmd = &cobra.Command{ + Use: "add", + Short: "Add a discovery source", + Long: "Add a discovery source. Supported discovery types are: oci, local", + Example: ` + # Add a local discovery source. If URI is relative path, + # $HOME/.config/tanzu-plugins will be considered based path + tanzu plugin source add --name standalone-local --type local --uri path/to/local/discovery - return listDiscoverySourceCmd + # Add an OCI discovery source. URI should be an OCI image. + tanzu plugin source add --name standalone-oci --type oci --uri projects.registry.vmware.com/tkg/tanzu-plugins/standalone:latest`, + RunE: func(cmd *cobra.Command, args []string) error { + newDiscoverySource, err := createDiscoverySource(discoverySourceType, discoverySourceName, uri) + if err != nil { + return err + } + + err = configlib.SetCLIDiscoverySource(newDiscoverySource) + if err != nil { + return err + } + + log.Successf("successfully added discovery source %s", discoverySourceName) + return nil + }, + } + return addDiscoverySourceCmd } func newUpdateDiscoverySourceCmd() *cobra.Command { var updateDiscoverySourceCmd = &cobra.Command{ - Use: "update SOURCE_NAME --uri ", + Use: "update SOURCE_NAME", Short: "Update a discovery source configuration", - // We already include the only flag in the use text, - // we therefore don't show '[flags]' in the usage text. - DisableFlagsInUseLine: true, - Example: ` - # Update the discovery source for an air-gapped scenario. The URI must be an OCI image. - tanzu plugin source update default --uri registry.example.com/tanzu/plugin-inventory:latest`, - Args: cobra.ExactArgs(1), + Args: cobra.ExactArgs(1), RunE: func(cmd *cobra.Command, args []string) error { discoveryName := args[0] @@ -91,7 +179,11 @@ func newUpdateDiscoverySourceCmd() *cobra.Command { return fmt.Errorf("discovery %q does not exist", discoveryName) } - newDiscoverySource, err := createDiscoverySource(discoveryName, uri) + if !configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + // With the central discovery, there is no more --type flag + discoverySourceType = common.DiscoveryTypeOCI + } + newDiscoverySource, err := createDiscoverySource(discoverySourceType, discoveryName, uri) if err != nil { return err } @@ -106,20 +198,29 @@ func newUpdateDiscoverySourceCmd() *cobra.Command { }, } - updateDiscoverySourceCmd.Flags().StringVarP(&uri, "uri", "u", "", "URI for discovery source. The URI must be of an OCI image") - _ = updateDiscoverySourceCmd.MarkFlagRequired("uri") + if !configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + updateDiscoverySourceCmd.Example = ` + # Update the discovery source for an air-gapped scenario. The URI must be an OCI image. + tanzu plugin source update default --uri registry.example.com/tanzu/plugin-inventory:latest` + } else { + updateDiscoverySourceCmd.Example = ` + # Update a local discovery source. If URI is relative path, + # $HOME/.config/tanzu-plugins will be considered base path + tanzu plugin source update standalone-local --type local --uri new/path/to/local/discovery + + # Update an OCI discovery source. URI should be an OCI image. + tanzu plugin source update standalone-oci --type oci --uri projects.registry.vmware.com/tkg/tanzu-plugins/standalone:v1.0` + } return updateDiscoverySourceCmd } func newDeleteDiscoverySourceCmd() *cobra.Command { var deleteDiscoverySourceCmd = &cobra.Command{ - Use: "delete SOURCE_NAME", - Short: "Delete a discovery source", - // There are no flags - DisableFlagsInUseLine: true, - Args: cobra.ExactArgs(1), - Hidden: true, + Use: "delete SOURCE_NAME", + Short: "Delete a discovery source", + Args: cobra.ExactArgs(1), + Hidden: true, Example: ` # Delete a discovery source tanzu plugin discovery delete default`, @@ -147,8 +248,6 @@ func newInitDiscoverySourceCmd() *cobra.Command { Use: "init", Short: "Initialize the discovery source to its default value", Args: cobra.MaximumNArgs(0), - // There are no flags - DisableFlagsInUseLine: true, RunE: func(cmd *cobra.Command, args []string) error { err := config.PopulateDefaultCentralDiscovery(true) if err != nil { @@ -162,18 +261,28 @@ func newInitDiscoverySourceCmd() *cobra.Command { return initDiscoverySourceCmd } -func createDiscoverySource(dsName, uri string) (configtypes.PluginDiscovery, error) { +func createDiscoverySource(dsType, dsName, uri string) (configtypes.PluginDiscovery, error) { pluginDiscoverySource := configtypes.PluginDiscovery{} - + if dsType == "" { + return pluginDiscoverySource, errors.New("discovery source type cannot be empty") + } if dsName == "" { return pluginDiscoverySource, errors.New("discovery source name cannot be empty") } - pluginDiscoverySource = configtypes.PluginDiscovery{ - OCI: &configtypes.OCIDiscovery{ - Name: dsName, - Image: uri, - }} + switch strings.ToLower(dsType) { + case common.DiscoveryTypeLocal: + pluginDiscoverySource.Local = createLocalDiscoverySource(dsName, uri) + case common.DiscoveryTypeOCI: + pluginDiscoverySource.OCI = createOCIDiscoverySource(dsName, uri) + case common.DiscoveryTypeREST: + pluginDiscoverySource.REST = createRESTDiscoverySource(dsName, uri) + case common.DiscoveryTypeGCP, common.DiscoveryTypeKubernetes: + return pluginDiscoverySource, errors.Errorf("discovery source type '%s' is not yet supported", dsType) + default: + return pluginDiscoverySource, errors.Errorf("unknown discovery source type '%s'", dsType) + } + err := checkDiscoverySource(pluginDiscoverySource) return pluginDiscoverySource, err } @@ -188,3 +297,41 @@ func checkDiscoverySource(source configtypes.PluginDiscovery) error { _, err = discObject.List() return err } + +func createLocalDiscoverySource(discoveryName, uri string) *configtypes.LocalDiscovery { + return &configtypes.LocalDiscovery{ + Name: discoveryName, + Path: uri, + } +} + +func createOCIDiscoverySource(discoveryName, uri string) *configtypes.OCIDiscovery { + return &configtypes.OCIDiscovery{ + Name: discoveryName, + Image: uri, + } +} + +func createRESTDiscoverySource(discoveryName, uri string) *configtypes.GenericRESTDiscovery { + return &configtypes.GenericRESTDiscovery{ + Name: discoveryName, + Endpoint: uri, + } +} + +func discoverySourceNameAndType(ds configtypes.PluginDiscovery) (string, string) { + switch { + case ds.GCP != nil: //nolint:staticcheck // Deprecated + return ds.GCP.Name, common.DiscoveryTypeGCP //nolint:staticcheck // Deprecated + case ds.Kubernetes != nil: + return ds.Kubernetes.Name, common.DiscoveryTypeKubernetes + case ds.Local != nil: + return ds.Local.Name, common.DiscoveryTypeLocal + case ds.OCI != nil: + return ds.OCI.Name, common.DiscoveryTypeOCI + case ds.REST != nil: + return ds.REST.Name, common.DiscoveryTypeREST + default: + return "-", "Unknown" // Unknown discovery source found + } +} diff --git a/pkg/command/discovery_source_test.go b/pkg/command/discovery_source_test.go index 7533e4aa7..7e1088e85 100644 --- a/pkg/command/discovery_source_test.go +++ b/pkg/command/discovery_source_test.go @@ -7,389 +7,126 @@ import ( "bytes" "io" "os" - "strings" "testing" "github.com/stretchr/testify/assert" - "github.com/vmware-tanzu/tanzu-cli/pkg/config" + "github.com/vmware-tanzu/tanzu-cli/pkg/common" "github.com/vmware-tanzu/tanzu-cli/pkg/constants" - configlib "github.com/vmware-tanzu/tanzu-plugin-runtime/config" - configtypes "github.com/vmware-tanzu/tanzu-plugin-runtime/config/types" - "github.com/vmware-tanzu/tanzu-plugin-runtime/log" ) func Test_createDiscoverySource(t *testing.T) { assert := assert.New(t) + common.DefaultLocalPluginDistroDir = "../pluginmanager/test/local/" + // When discovery source name is empty - _, err := createDiscoverySource("", "fake/path") + _, err := createDiscoverySource("LOCAL", "", "fake/path") assert.NotNil(err) assert.Equal(err.Error(), "discovery source name cannot be empty") - // With an invalid image - pd, err := createDiscoverySource("fake-oci-discovery-name", "test.registry.com/test-image:v1.0.0") + // When discovery source type is empty + _, err = createDiscoverySource("", "fake-discovery-name", "fake/path") + assert.NotNil(err) + assert.Contains(err.Error(), "discovery source type cannot be empty") + + // When discovery source is `local` and data is provided correctly + // but path is invalid + pd, err := createDiscoverySource("local", "fake-discovery-name", "fake/path") + assert.NotNil(err) + assert.Contains(err.Error(), "error while reading local plugin manifest directory") + assert.NotNil(pd.Local) + assert.Equal(pd.Local.Name, "fake-discovery-name") + assert.Equal(pd.Local.Path, "fake/path") + + // When discovery source is `local` with a valid path + pd, err = createDiscoverySource("local", "fake-discovery-name", "standalone") + assert.Nil(err) + assert.NotNil(pd.Local) + assert.Equal(pd.Local.Name, "fake-discovery-name") + assert.Equal(pd.Local.Path, "standalone") + + // When discovery source is `LOCAL` with a valid path + pd, err = createDiscoverySource("LOCAL", "fake-discovery-name", "standalone") + assert.Nil(err) + assert.NotNil(pd.Local) + assert.Equal(pd.Local.Name, "fake-discovery-name") + assert.Equal(pd.Local.Path, "standalone") + + // When discovery source is `oci` with an invalid image + pd, err = createDiscoverySource("oci", "fake-oci-discovery-name", "test.registry.com/test-image:v1.0.0") assert.NotNil(err) assert.Contains(err.Error(), "unable to fetch the inventory of discovery 'fake-oci-discovery-name' for plugins") assert.NotNil(pd.OCI) assert.Equal(pd.OCI.Name, "fake-oci-discovery-name") assert.Equal(pd.OCI.Image, "test.registry.com/test-image:v1.0.0") -} -// Test_createAndListDiscoverySources test 'tanzu plugin source list' when TANZU_CLI_ADDITIONAL_PLUGIN_DISCOVERY_IMAGES_TEST_ONLY has set test only discovery sources -func Test_createAndListDiscoverySources(t *testing.T) { - assert := assert.New(t) + // When discovery source is gcp + _, err = createDiscoverySource("gcp", "fake-discovery-name", "fake/path") + assert.NotNil(err) + assert.Contains(err.Error(), "not yet supported") - // Set temporary configuration - configFile, _ := os.CreateTemp("", "config") - os.Setenv(configlib.EnvConfigKey, configFile.Name()) - defer os.RemoveAll(configFile.Name()) + // When discovery source is kubernetes + _, err = createDiscoverySource("kubernetes", "fake-discovery-name", "fake/path") + assert.NotNil(err) + assert.Contains(err.Error(), "not yet supported") + + // When discovery source is rest with invalid endpoint + pd, err = createDiscoverySource("rest", "fake-discovery-name", "fake/path") + assert.NotNil(err) + assert.Contains(err.Error(), "unsupported protocol scheme") + assert.NotNil(pd.REST) + assert.Equal(pd.REST.Name, "fake-discovery-name") + assert.Equal(pd.REST.Endpoint, "fake/path") - configFileNG, _ := os.CreateTemp("", "config_ng") - os.Setenv(configlib.EnvConfigNextGenKey, configFileNG.Name()) - defer os.RemoveAll(configFileNG.Name()) + // When discovery source is an unknown value + _, err = createDiscoverySource("unexpectedValue", "fake-discovery-name", "fake/path") + assert.NotNil(err) + assert.Contains(err.Error(), "unknown discovery source type 'unexpectedValue'") +} +// Test_createAndListDiscoverySources test 'tanzu plugin source list' when TANZU_CLI_ADDITIONAL_PLUGIN_DISCOVERY_IMAGES_TEST_ONLY has set test only discovery sources +func Test_createAndListDiscoverySources(t *testing.T) { + oldVal := os.Getenv(constants.ConfigVariableAdditionalDiscoveryForTesting) os.Setenv(constants.CEIPOptInUserPromptAnswer, "No") os.Setenv(constants.EULAPromptAnswer, "Yes") - // Initialize the plugin source to the default one - err := configlib.SetCLIDiscoverySource(configtypes.PluginDiscovery{ - OCI: &configtypes.OCIDiscovery{ - Name: config.DefaultStandaloneDiscoveryName, - Image: constants.TanzuCLIDefaultCentralPluginDiscoveryImage, - }}) - assert.Nil(err) + // Initialize the plugin source + rootCmd, err := NewRootCmd() + assert.Nil(t, err) + rootCmd.SetArgs([]string{"plugin", "source", "init"}) + err = rootCmd.Execute() + assert.Nil(t, err) - // List with one extra plugin source - testSource1 := "harbor-repo.vmware.com/tanzu_cli_stage/plugins/plugin-inventory:latest" - os.Setenv(constants.ConfigVariableAdditionalDiscoveryForTesting, testSource1) + // List plugin source - one + os.Setenv(constants.ConfigVariableAdditionalDiscoveryForTesting, "harbor-repo.vmware.com/tanzu_cli_stage/plugins/plugin-inventory:latest") - rootCmd, err := NewRootCmd() - assert.Nil(err) rootCmd.SetArgs([]string{"plugin", "source", "list"}) b := bytes.NewBufferString("") rootCmd.SetOut(b) err = rootCmd.Execute() - assert.Nil(err) + assert.Nil(t, err) got, err := io.ReadAll(b) - assert.Nil(err) + assert.Nil(t, err) - // whitespace-agnostic match - assert.Contains(strings.Join(strings.Fields(string(got)), " "), - config.DefaultStandaloneDiscoveryName+" "+constants.TanzuCLIDefaultCentralPluginDiscoveryImage) - assert.Contains(strings.Join(strings.Fields(string(got)), " "), - "disc_0 (test only) "+testSource1) + str := string(got) + assert.Contains(t, str, "disc_0 (test only)") - // List with two extra plugin sources - testSource2 := "localhost:9876/tanzu-cli/plugins/sandbox1:small" - os.Setenv(constants.ConfigVariableAdditionalDiscoveryForTesting, testSource1+","+testSource2) + // List plugin source - two + os.Setenv(constants.ConfigVariableAdditionalDiscoveryForTesting, "harbor-repo.vmware.com/tanzu_cli_stage/plugins/plugin-inventory:latest,localhost:9876/tanzu-cli/plugins/sandbox1:small") rootCmd.SetArgs([]string{"plugin", "source", "list"}) b = bytes.NewBufferString("") rootCmd.SetOut(b) err = rootCmd.Execute() - assert.Nil(err) + assert.Nil(t, err) got, err = io.ReadAll(b) - assert.Nil(err) - - // whitespace-agnostic match - assert.Contains(strings.Join(strings.Fields(string(got)), " "), - config.DefaultStandaloneDiscoveryName+" "+constants.TanzuCLIDefaultCentralPluginDiscoveryImage) - assert.Contains(strings.Join(strings.Fields(string(got)), " "), - "disc_0 (test only) "+testSource1) - assert.Contains(strings.Join(strings.Fields(string(got)), " "), - "disc_1 (test only) "+testSource2) - - // Reset variables - os.Unsetenv(configlib.EnvConfigKey) - os.Unsetenv(configlib.EnvConfigNextGenKey) - os.Unsetenv(constants.CEIPOptInUserPromptAnswer) - os.Unsetenv(constants.EULAPromptAnswer) - os.Unsetenv(constants.ConfigVariableAdditionalDiscoveryForTesting) -} - -func Test_initDiscoverySources(t *testing.T) { - tests := []struct { - test string - args []string - expected string - expectedFailure bool - }{ - { - test: "init with extra arg error", - args: []string{"plugin", "source", "init", "extra"}, - expectedFailure: true, - expected: "accepts at most 0 arg(s), received 1", - }, - { - test: "init success", - args: []string{"plugin", "source", "init"}, - expectedFailure: false, - expected: "successfully initialized discovery source", - }, - } - - configFile, _ := os.CreateTemp("", "config") - os.Setenv(configlib.EnvConfigKey, configFile.Name()) - defer os.RemoveAll(configFile.Name()) - - configFileNG, _ := os.CreateTemp("", "config_ng") - os.Setenv(configlib.EnvConfigNextGenKey, configFileNG.Name()) - defer os.RemoveAll(configFileNG.Name()) - - os.Setenv(constants.CEIPOptInUserPromptAnswer, "No") - os.Setenv(constants.EULAPromptAnswer, "Yes") - - for _, spec := range tests { - t.Run(spec.test, func(t *testing.T) { - assert := assert.New(t) - - // Start with a different plugin source than the default one - // so we can test the "plugin source init" command - err := configlib.SetCLIDiscoverySource(configtypes.PluginDiscovery{ - OCI: &configtypes.OCIDiscovery{ - Name: config.DefaultStandaloneDiscoveryName, - Image: "test/uri", - }}) - assert.Nil(err) - - rootCmd, err := NewRootCmd() - assert.Nil(err) - rootCmd.SetArgs(spec.args) - b := bytes.NewBufferString("") - rootCmd.SetOut(b) - rootCmd.SetErr(b) - log.SetStdout(b) - log.SetStderr(b) - - err = rootCmd.Execute() - assert.Equal(err != nil, spec.expectedFailure) - - if spec.expected != "" { - if spec.expectedFailure { - // Check we got the correct error - assert.Contains(err.Error(), spec.expected) - } else { - got, err := io.ReadAll(b) - assert.Nil(err) - assert.Contains(string(got), spec.expected) - - // Check that there is only one plugin source and that it - // is the default one - discoverySources, err := configlib.GetCLIDiscoverySources() - assert.Nil(err) - assert.Equal(1, len(discoverySources)) - - for _, ds := range discoverySources { - assert.NotNil(ds.OCI) - assert.Equal(config.DefaultStandaloneDiscoveryName, ds.OCI.Name) - assert.Equal(constants.TanzuCLIDefaultCentralPluginDiscoveryImage, ds.OCI.Image) - } - } - } - }) - } - os.Unsetenv(configlib.EnvConfigKey) - os.Unsetenv(configlib.EnvConfigNextGenKey) - os.Unsetenv(constants.CEIPOptInUserPromptAnswer) - os.Unsetenv(constants.EULAPromptAnswer) -} - -func Test_updateDiscoverySources(t *testing.T) { - tests := []struct { - test string - args []string - expected string - expectedFailure bool - }{ - { - test: "update missing arg error", - args: []string{"plugin", "source", "update"}, - expectedFailure: true, - expected: "accepts 1 arg(s), received 0", - }, - { - test: "update extra arg error", - args: []string{"plugin", "source", "update", "default", "extra"}, - expectedFailure: true, - expected: "accepts 1 arg(s), received 2", - }, - { - test: "update invalid source", - args: []string{"plugin", "source", "update", "invalid", "-u", constants.TanzuCLIDefaultCentralPluginDiscoveryImage}, - expectedFailure: true, - expected: `discovery "invalid" does not exist`, - }, - { - test: "update invalid uri error", - args: []string{"plugin", "source", "update", "default", "-u", "example.com"}, - expectedFailure: true, - expected: "unable to fetch the inventory of discovery", - }, - { - test: "update success", - args: []string{"plugin", "source", "update", "default", "-u", constants.TanzuCLIDefaultCentralPluginDiscoveryImage}, - expectedFailure: false, - expected: "updated discovery source", - }, - } - - configFile, _ := os.CreateTemp("", "config") - os.Setenv(configlib.EnvConfigKey, configFile.Name()) - defer os.RemoveAll(configFile.Name()) - - configFileNG, _ := os.CreateTemp("", "config_ng") - os.Setenv(configlib.EnvConfigNextGenKey, configFileNG.Name()) - defer os.RemoveAll(configFileNG.Name()) - - os.Setenv(constants.CEIPOptInUserPromptAnswer, "No") - os.Setenv(constants.EULAPromptAnswer, "Yes") - - for _, spec := range tests { - t.Run(spec.test, func(t *testing.T) { - assert := assert.New(t) - - // Set the discovery source to a fake one before each test - // to see being updated - err := configlib.SetCLIDiscoverySource(configtypes.PluginDiscovery{ - OCI: &configtypes.OCIDiscovery{ - Name: config.DefaultStandaloneDiscoveryName, - Image: "test/uri", - }}) - assert.Nil(err) - - rootCmd, err := NewRootCmd() - assert.Nil(err) - rootCmd.SetArgs(spec.args) - b := bytes.NewBufferString("") - rootCmd.SetOut(b) - rootCmd.SetErr(b) - log.SetStdout(b) - log.SetStderr(b) - - err = rootCmd.Execute() - assert.Equal(err != nil, spec.expectedFailure) - - if spec.expected != "" { - if spec.expectedFailure { - // Check we got the correct error - assert.Contains(err.Error(), spec.expected) - } else { - got, err := io.ReadAll(b) - assert.Nil(err) - assert.Contains(string(got), spec.expected) - - // Check that there is only one plugin source and that it - // is the default one - discoverySources, err := configlib.GetCLIDiscoverySources() - assert.Nil(err) - assert.Equal(1, len(discoverySources)) - - for _, ds := range discoverySources { - assert.NotNil(ds.OCI) - assert.Equal(config.DefaultStandaloneDiscoveryName, ds.OCI.Name) - assert.Equal(constants.TanzuCLIDefaultCentralPluginDiscoveryImage, ds.OCI.Image) - } - } - } - }) - } - os.Unsetenv(configlib.EnvConfigKey) - os.Unsetenv(configlib.EnvConfigNextGenKey) - os.Unsetenv(constants.CEIPOptInUserPromptAnswer) - os.Unsetenv(constants.EULAPromptAnswer) -} - -func Test_deleteDiscoverySource(t *testing.T) { - tests := []struct { - test string - args []string - expected string - expectedFailure bool - }{ - { - test: "delete missing arg error", - args: []string{"plugin", "source", "delete"}, - expectedFailure: true, - expected: "accepts 1 arg(s), received 0", - }, - { - test: "delete extra arg error", - args: []string{"plugin", "source", "delete", "default", "extra"}, - expectedFailure: true, - expected: "accepts 1 arg(s), received 2", - }, - { - test: "delete invalid source", - args: []string{"plugin", "source", "delete", "invalid"}, - expectedFailure: true, - expected: `discovery "invalid" does not exist`, - }, - { - test: "delete success", - args: []string{"plugin", "source", "delete", "default"}, - expectedFailure: false, - expected: "deleted discovery source", - }, - } - - configFile, _ := os.CreateTemp("", "config") - os.Setenv(configlib.EnvConfigKey, configFile.Name()) - defer os.RemoveAll(configFile.Name()) - - configFileNG, _ := os.CreateTemp("", "config_ng") - os.Setenv(configlib.EnvConfigNextGenKey, configFileNG.Name()) - defer os.RemoveAll(configFileNG.Name()) - - os.Setenv(constants.CEIPOptInUserPromptAnswer, "No") - os.Setenv(constants.EULAPromptAnswer, "Yes") - - for _, spec := range tests { - t.Run(spec.test, func(t *testing.T) { - assert := assert.New(t) - - // Reset the discovery source to the default one - // before each test - err := configlib.SetCLIDiscoverySource(configtypes.PluginDiscovery{ - OCI: &configtypes.OCIDiscovery{ - Name: config.DefaultStandaloneDiscoveryName, - Image: constants.TanzuCLIDefaultCentralPluginDiscoveryImage, - }}) - assert.Nil(err) - - rootCmd, err := NewRootCmd() - assert.Nil(err) - rootCmd.SetArgs(spec.args) - b := bytes.NewBufferString("") - rootCmd.SetOut(b) - rootCmd.SetErr(b) - log.SetStdout(b) - log.SetStderr(b) - - err = rootCmd.Execute() - assert.Equal(err != nil, spec.expectedFailure) - - if spec.expected != "" { - if spec.expectedFailure { - // Check we got the correct error - assert.Contains(err.Error(), spec.expected) - } else { - got, err := io.ReadAll(b) - assert.Nil(err) - assert.Contains(string(got), spec.expected) + assert.Nil(t, err) - // Check that there are no more plugin sources - discoverySources, err := configlib.GetCLIDiscoverySources() - assert.Nil(err) - assert.Equal(0, len(discoverySources)) - } - } - }) - } - os.Unsetenv(configlib.EnvConfigKey) - os.Unsetenv(configlib.EnvConfigNextGenKey) - os.Unsetenv(constants.CEIPOptInUserPromptAnswer) - os.Unsetenv(constants.EULAPromptAnswer) + str = string(got) + assert.Contains(t, str, "disc_0 (test only)") + assert.Contains(t, str, "disc_1 (test only)") + os.Setenv(constants.ConfigVariableAdditionalDiscoveryForTesting, oldVal) } diff --git a/pkg/command/login.go b/pkg/command/login.go index 134cdc787..b3497afec 100644 --- a/pkg/command/login.go +++ b/pkg/command/login.go @@ -51,9 +51,9 @@ func init() { loginCmd.Flags().BoolVar(&staging, "staging", false, "use CSP staging issuer") loginCmd.Flags().StringVar(&endpointCACertPath, "endpoint-ca-certificate", "", "path to the endpoint public certificate") loginCmd.Flags().BoolVar(&skipTLSVerify, "insecure-skip-tls-verify", false, "skip endpoint's TLS certificate verification") - loginCmd.Flags().MarkHidden("stderr-only") // nolint - loginCmd.Flags().MarkHidden("force-csp") // nolint - loginCmd.Flags().MarkHidden("staging") // nolint + loginCmd.Flags().MarkHidden("stderr-only") //nolint + loginCmd.Flags().MarkHidden("force-csp") //nolint + loginCmd.Flags().MarkHidden("staging") //nolint loginCmd.SetUsageFunc(cli.SubCmdUsageFunc) loginCmd.MarkFlagsMutuallyExclusive("endpoint-ca-certificate", "insecure-skip-tls-verify") @@ -87,14 +87,14 @@ func init() { default kubeconfig file ($HOME/.kube/config) will be used.` } -func login(cmd *cobra.Command, args []string) (err error) { +func login(_ *cobra.Command, _ []string) (err error) { cfg, err := config.GetClientConfig() if err != nil { return err } newServerSelector := "+ new server" - var serverTarget *configtypes.Server // nolint:staticcheck // Deprecated + var serverTarget *configtypes.Server //nolint:staticcheck // Deprecated if name != "" { serverTarget, err = createNewServer() if err != nil { @@ -106,7 +106,7 @@ func login(cmd *cobra.Command, args []string) (err error) { return err } } else { - serverTarget, err = config.GetServer(server) // nolint:staticcheck // Deprecated + serverTarget, err = config.GetServer(server) //nolint:staticcheck // Deprecated if err != nil { return err } @@ -119,7 +119,7 @@ func login(cmd *cobra.Command, args []string) (err error) { } } - if serverTarget.Type == configtypes.GlobalServerType { // nolint:staticcheck // Deprecated + if serverTarget.Type == configtypes.GlobalServerType { //nolint:staticcheck // Deprecated err = globalLoginUsingServer(serverTarget) } else { err = managementClusterLogin(serverTarget) @@ -137,11 +137,11 @@ func login(cmd *cobra.Command, args []string) (err error) { return nil } -func getServerTarget(cfg *configtypes.ClientConfig, newServerSelector string) (*configtypes.Server, error) { // nolint:staticcheck // Deprecated +func getServerTarget(cfg *configtypes.ClientConfig, newServerSelector string) (*configtypes.Server, error) { //nolint:staticcheck // Deprecated promptOpts := getPromptOpts() - servers := map[string]*configtypes.Server{} // nolint:staticcheck // Deprecated - for _, server := range cfg.KnownServers { // nolint:staticcheck // Deprecated - ep, err := config.EndpointFromServer(server) // nolint:staticcheck // Deprecated + servers := map[string]*configtypes.Server{} //nolint:staticcheck // Deprecated + for _, server := range cfg.KnownServers { //nolint:staticcheck // Deprecated + ep, err := config.EndpointFromServer(server) //nolint:staticcheck // Deprecated if err != nil { return nil, err } @@ -159,7 +159,7 @@ func getServerTarget(cfg *configtypes.ClientConfig, newServerSelector string) (* } serverKeys := getKeysFromServerMap(servers) serverKeys = append(serverKeys, newServerSelector) - servers[newServerSelector] = &configtypes.Server{} // nolint:staticcheck // Deprecated + servers[newServerSelector] = &configtypes.Server{} //nolint:staticcheck // Deprecated err := component.Prompt( &component.PromptConfig{ Message: "Select a server", @@ -175,7 +175,7 @@ func getServerTarget(cfg *configtypes.ClientConfig, newServerSelector string) (* return servers[server], nil } -func getKeysFromServerMap(m map[string]*configtypes.Server) []string { // nolint:staticcheck // Deprecated +func getKeysFromServerMap(m map[string]*configtypes.Server) []string { //nolint:staticcheck // Deprecated keys := make([]string, 0, len(m)) for key := range m { keys = append(keys, key) @@ -194,7 +194,7 @@ func isGlobalServer(endpoint string) bool { return false } -func createNewServer() (server *configtypes.Server, err error) { // nolint:staticcheck // Deprecated +func createNewServer() (server *configtypes.Server, err error) { //nolint:staticcheck // Deprecated // user provided command line options to create a server using kubeconfig[optional] and context if kubeContext != "" { return createServerWithKubeconfig() @@ -227,7 +227,7 @@ func createNewServer() (server *configtypes.Server, err error) { // nolint:stati return createServerWithKubeconfig() } -func createServerWithKubeconfig() (server *configtypes.Server, err error) { // nolint:staticcheck // Deprecated +func createServerWithKubeconfig() (server *configtypes.Server, err error) { //nolint:staticcheck // Deprecated promptOpts := getPromptOpts() if kubeConfig == "" && kubeContext == "" { err = component.Prompt( @@ -238,7 +238,7 @@ func createServerWithKubeconfig() (server *configtypes.Server, err error) { // n promptOpts..., ) if err != nil { - return + return server, err } } kubeConfig = strings.TrimSpace(kubeConfig) @@ -255,7 +255,7 @@ func createServerWithKubeconfig() (server *configtypes.Server, err error) { // n promptOpts..., ) if err != nil { - return + return server, err } } kubeContext = strings.TrimSpace(kubeContext) @@ -268,25 +268,25 @@ func createServerWithKubeconfig() (server *configtypes.Server, err error) { // n promptOpts..., ) if err != nil { - return + return server, err } } name = strings.TrimSpace(name) - nameExists, err := config.ServerExists(name) // nolint:staticcheck // Deprecated + nameExists, err := config.ServerExists(name) //nolint:staticcheck // Deprecated if err != nil { return server, err } if nameExists { err = fmt.Errorf("server %q already exists", name) - return + return server, err } - endpointType := configtypes.ManagementClusterServerType // nolint:staticcheck // Deprecated + endpointType := configtypes.ManagementClusterServerType //nolint:staticcheck // Deprecated - server = &configtypes.Server{ // nolint:staticcheck // Deprecated + server = &configtypes.Server{ //nolint:staticcheck // Deprecated Name: name, Type: endpointType, - ManagementClusterOpts: &configtypes.ManagementClusterServer{ // nolint:staticcheck // Deprecated + ManagementClusterOpts: &configtypes.ManagementClusterServer{ //nolint:staticcheck // Deprecated Path: kubeConfig, Context: kubeContext, Endpoint: endpoint}, @@ -294,7 +294,7 @@ func createServerWithKubeconfig() (server *configtypes.Server, err error) { // n return server, err } -func createServerWithEndpoint() (server *configtypes.Server, err error) { // nolint:staticcheck // Deprecated +func createServerWithEndpoint() (server *configtypes.Server, err error) { //nolint:staticcheck // Deprecated promptOpts := getPromptOpts() if endpoint == "" { err = component.Prompt( @@ -305,7 +305,7 @@ func createServerWithEndpoint() (server *configtypes.Server, err error) { // nol promptOpts..., ) if err != nil { - return + return server, err } } endpoint = strings.TrimSpace(endpoint) @@ -318,35 +318,35 @@ func createServerWithEndpoint() (server *configtypes.Server, err error) { // nol promptOpts..., ) if err != nil { - return + return server, err } } name = strings.TrimSpace(name) - nameExists, err := config.ServerExists(name) // nolint:staticcheck // Deprecated + nameExists, err := config.ServerExists(name) //nolint:staticcheck // Deprecated if err != nil { return server, err } if nameExists { err = fmt.Errorf("server %q already exists", name) - return + return server, err } if isGlobalServer(endpoint) { - server = &configtypes.Server{ // nolint:staticcheck // Deprecated + server = &configtypes.Server{ //nolint:staticcheck // Deprecated Name: name, - Type: configtypes.GlobalServerType, // nolint:staticcheck // Deprecated + Type: configtypes.GlobalServerType, //nolint:staticcheck // Deprecated GlobalOpts: &configtypes.GlobalServer{Endpoint: sanitizeEndpoint(endpoint)}, } } else { tkf := NewTKGKubeconfigFetcher(endpoint, endpointCACertPath, skipTLSVerify) kubeConfig, kubeContext, err = tkf.GetPinnipedKubeconfig() if err != nil { - return + return server, err } - server = &configtypes.Server{ // nolint:staticcheck // Deprecated + server = &configtypes.Server{ //nolint:staticcheck // Deprecated Name: name, - Type: configtypes.ManagementClusterServerType, // nolint:staticcheck // Deprecated - ManagementClusterOpts: &configtypes.ManagementClusterServer{ // nolint:staticcheck // Deprecated + Type: configtypes.ManagementClusterServerType, //nolint:staticcheck // Deprecated + ManagementClusterOpts: &configtypes.ManagementClusterServer{ //nolint:staticcheck // Deprecated Path: kubeConfig, Context: kubeContext, Endpoint: endpoint}, @@ -355,7 +355,7 @@ func createServerWithEndpoint() (server *configtypes.Server, err error) { // nol return server, err } -func globalLoginUsingServer(s *configtypes.Server) (err error) { // nolint:staticcheck // Deprecated +func globalLoginUsingServer(s *configtypes.Server) (err error) { //nolint:staticcheck // Deprecated a := configtypes.GlobalServerAuth{} apiTokenValue, apiTokenExists := os.LookupEnv(config.EnvAPITokenKey) @@ -396,7 +396,7 @@ func globalLoginUsingServer(s *configtypes.Server) (err error) { // nolint:stati s.GlobalOpts.Auth = a } - err = config.PutServer(s, true) // nolint:staticcheck // Deprecated + err = config.PutServer(s, true) //nolint:staticcheck // Deprecated if err != nil { return err } @@ -406,7 +406,7 @@ func globalLoginUsingServer(s *configtypes.Server) (err error) { // nolint:stati return nil } -func managementClusterLogin(s *configtypes.Server) error { // nolint:staticcheck // Deprecated +func managementClusterLogin(s *configtypes.Server) error { //nolint:staticcheck // Deprecated if s != nil && s.ManagementClusterOpts != nil && s.ManagementClusterOpts.Path != "" && s.ManagementClusterOpts.Context != "" { _, err := tkgauth.GetServerKubernetesVersion(s.ManagementClusterOpts.Path, s.ManagementClusterOpts.Context) if err != nil { @@ -414,7 +414,7 @@ func managementClusterLogin(s *configtypes.Server) error { // nolint:staticcheck log.Error(err, "") return err } - err = config.PutServer(s, true) // nolint:staticcheck // Deprecated + err = config.PutServer(s, true) //nolint:staticcheck // Deprecated if err != nil { return err } diff --git a/pkg/command/plugin.go b/pkg/command/plugin.go index 39dd4c7e2..7b68e5ee5 100644 --- a/pkg/command/plugin.go +++ b/pkg/command/plugin.go @@ -16,11 +16,13 @@ import ( kerrors "k8s.io/apimachinery/pkg/util/errors" "github.com/vmware-tanzu/tanzu-plugin-runtime/component" + "github.com/vmware-tanzu/tanzu-plugin-runtime/config" configtypes "github.com/vmware-tanzu/tanzu-plugin-runtime/config/types" "github.com/vmware-tanzu/tanzu-plugin-runtime/plugin" "github.com/vmware-tanzu/tanzu-cli/pkg/cli" "github.com/vmware-tanzu/tanzu-cli/pkg/common" + "github.com/vmware-tanzu/tanzu-cli/pkg/constants" "github.com/vmware-tanzu/tanzu-cli/pkg/discovery" "github.com/vmware-tanzu/tanzu-cli/pkg/pluginmanager" "github.com/vmware-tanzu/tanzu-cli/pkg/pluginsupplier" @@ -67,38 +69,40 @@ func newPluginCmd() *cobra.Command { listPluginCmd.Flags().StringVarP(&outputFormat, "output", "o", "", "Output format (yaml|json|table)") describePluginCmd.Flags().StringVarP(&outputFormat, "output", "o", "", "Output format (yaml|json|table)") - installPluginCmd.Flags().StringVar(&group, "group", "", "install the plugins specified by a plugin-group version") + if !config.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + installPluginCmd.Flags().StringVar(&group, "group", "", "install the plugins specified by a plugin-group version") - // --local is renamed to --local-source - installPluginCmd.Flags().StringVarP(&local, "local", "", "", "path to local plugin source") - msg := "this was done in the v1.0.0 release, it will be removed following the deprecation policy (6 months). Use the --local-source flag instead.\n" - if err := installPluginCmd.Flags().MarkDeprecated("local", msg); err != nil { - // Will only fail if the flag does not exist, which would indicate a coding error, - // so let's panic so we notice immediately. - panic(err) - } + // --local is renamed to --local-source + installPluginCmd.Flags().StringVarP(&local, "local", "", "", "path to local plugin source") + msg := "this was done in the v1.0.0 release, it will be removed following the deprecation policy (6 months). Use the --local-source flag instead.\n" + if err := installPluginCmd.Flags().MarkDeprecated("local", msg); err != nil { + // Will only fail if the flag does not exist, which would indicate a coding error, + // so let's panic so we notice immediately. + panic(err) + } - // The --local-source flag for installing plugins is only used in development testing - // and should not be used in production. We mark it as hidden to help convey this reality. - installPluginCmd.Flags().StringVarP(&local, "local-source", "l", "", "path to local plugin source") - if err := installPluginCmd.Flags().MarkHidden("local-source"); err != nil { - // Will only fail if the flag does not exist, which would indicate a coding error, - // so let's panic so we notice immediately. - panic(err) + // The --local-source flag for installing plugins is only used in development testing + // and should not be used in production. We mark it as hidden to help convey this reality. + installPluginCmd.Flags().StringVarP(&local, "local-source", "l", "", "path to local plugin source") + if err := installPluginCmd.Flags().MarkHidden("local-source"); err != nil { + // Will only fail if the flag does not exist, which would indicate a coding error, + // so let's panic so we notice immediately. + panic(err) + } + } else { + installPluginCmd.Flags().StringVarP(&local, "local", "l", "", "path to local discovery/distribution source") + listPluginCmd.Flags().StringVarP(&local, "local", "l", "", "path to local plugin source") } installPluginCmd.Flags().StringVarP(&version, "version", "v", cli.VersionLatest, "version of the plugin") deletePluginCmd.Flags().BoolVarP(&forceDelete, "yes", "y", false, "delete the plugin without asking for confirmation") - targetFlagDesc := fmt.Sprintf("target of the plugin (%s)", common.TargetList) - installPluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) - upgradePluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) - deletePluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) - describePluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) - - installPluginCmd.MarkFlagsMutuallyExclusive("group", "local") - installPluginCmd.MarkFlagsMutuallyExclusive("group", "local-source") - installPluginCmd.MarkFlagsMutuallyExclusive("group", "version") - installPluginCmd.MarkFlagsMutuallyExclusive("group", "target") + if config.IsFeatureActivated(constants.FeatureContextCommand) { + targetFlagDesc := fmt.Sprintf("target of the plugin (%s)", common.TargetList) + installPluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) + upgradePluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) + deletePluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) + describePluginCmd.Flags().StringVarP(&targetStr, "target", "t", "", targetFlagDesc) + } pluginCmd.AddCommand( listPluginCmd, @@ -109,12 +113,23 @@ func newPluginCmd() *cobra.Command { cleanPluginCmd, syncPluginCmd, discoverySourceCmd, - newSearchPluginCmd(), - newPluginGroupCmd(), - newDownloadBundlePluginCmd(), - newUploadBundlePluginCmd(), ) + if !config.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + installPluginCmd.MarkFlagsMutuallyExclusive("group", "local") + installPluginCmd.MarkFlagsMutuallyExclusive("group", "local-source") + installPluginCmd.MarkFlagsMutuallyExclusive("group", "version") + if config.IsFeatureActivated(constants.FeatureContextCommand) { + installPluginCmd.MarkFlagsMutuallyExclusive("group", "target") + } + pluginCmd.AddCommand( + newSearchPluginCmd(), + newPluginGroupCmd(), + newDownloadBundlePluginCmd(), + newUploadBundlePluginCmd(), + ) + } + return pluginCmd } @@ -125,32 +140,61 @@ func newListPluginCmd() *cobra.Command { Long: "List installed standalone plugins or plugins recommended by the contexts being used", RunE: func(cmd *cobra.Command, args []string) error { errorList := make([]error, 0) - // List installed standalone plugins - standalonePlugins, err := pluginsupplier.GetInstalledStandalonePlugins() - if err != nil { - errorList = append(errorList, err) - log.Warningf("there was an error while getting installed standalone plugins, error information: '%v'", err.Error()) + if !config.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + // List installed standalone plugins + standalonePlugins, err := pluginsupplier.GetInstalledStandalonePlugins() + if err != nil { + errorList = append(errorList, err) + log.Warningf("there was an error while getting installed standalone plugins, error information: '%v'", err.Error()) + } + sort.Sort(cli.PluginInfoSorter(standalonePlugins)) + + // List installed context plugins and also missing context plugins. + // Showing missing ones guides the user to know some plugins are recommended for the + // active contexts, but are not installed. + installedContextPlugins, missingContextPlugins, pluginSyncRequired, err := getInstalledAndMissingContextPlugins() + if err != nil { + errorList = append(errorList, err) + log.Warningf(errorWhileGettingContextPlugins, err.Error()) + } + sort.Sort(discovery.DiscoveredSorter(installedContextPlugins)) + sort.Sort(discovery.DiscoveredSorter(missingContextPlugins)) + + if config.IsFeatureActivated(constants.FeatureContextCommand) && (outputFormat == "" || outputFormat == string(component.TableOutputType)) { + displayInstalledAndMissingSplitView(standalonePlugins, installedContextPlugins, missingContextPlugins, pluginSyncRequired, cmd.OutOrStdout()) + } else { + displayInstalledAndMissingListView(standalonePlugins, installedContextPlugins, missingContextPlugins, cmd.OutOrStdout()) + } + + return kerrors.NewAggregate(errorList) + } + + // Plugin listing before the Central Repository feature + var err error + var availablePlugins []discovery.Discovered + if local != "" { + // get absolute local path + local, err = filepath.Abs(local) + if err != nil { + return err + } + availablePlugins, err = pluginmanager.AvailablePluginsFromLocalSource(local) + } else { + availablePlugins, err = pluginmanager.AvailablePlugins() } - sort.Sort(cli.PluginInfoSorter(standalonePlugins)) - // List installed context plugins and also missing context plugins. - // Showing missing ones guides the user to know some plugins are recommended for the - // active contexts, but are not installed. - installedContextPlugins, missingContextPlugins, pluginSyncRequired, err := getInstalledAndMissingContextPlugins() if err != nil { - errorList = append(errorList, err) - log.Warningf(errorWhileGettingContextPlugins, err.Error()) + log.Warningf("there was an error while getting available plugins, error information: '%v'", err.Error()) } - sort.Sort(discovery.DiscoveredSorter(installedContextPlugins)) - sort.Sort(discovery.DiscoveredSorter(missingContextPlugins)) + sort.Sort(discovery.DiscoveredSorter(availablePlugins)) - if outputFormat == "" || outputFormat == string(component.TableOutputType) { - displayInstalledAndMissingSplitView(standalonePlugins, installedContextPlugins, missingContextPlugins, pluginSyncRequired, cmd.OutOrStdout()) + if config.IsFeatureActivated(constants.FeatureContextCommand) && (outputFormat == "" || outputFormat == string(component.TableOutputType)) { + displayPluginListOutputSplitViewContext(availablePlugins, cmd.OutOrStdout()) } else { - displayInstalledAndMissingListView(standalonePlugins, installedContextPlugins, missingContextPlugins, cmd.OutOrStdout()) + displayPluginListOutputListView(availablePlugins, cmd.OutOrStdout()) } - return kerrors.NewAggregate(errorList) + return err }, } @@ -186,28 +230,12 @@ func newDescribePluginCmd() *cobra.Command { return describeCmd } +//nolint:gocyclo func newInstallPluginCmd() *cobra.Command { var installCmd = &cobra.Command{ Use: "install [" + pluginNameCaps + "]", Short: "Install a plugin", - Long: "Install a specific plugin by name or specify all to install all plugins of a group", - Example: ` - # Install all plugins of the vmware-tkg/default plugin group version v2.1.0 - tanzu plugin install --group vmware-tkg/default:v2.1.0 - - # Install all plugins of the latest version of the vmware-tkg/default plugin group - tanzu plugin install --group vmware-tkg/default - - # Install the latest version of plugin "myPlugin" - # If the plugin exists for more than one target, an error will be thrown - tanzu plugin install myPlugin - - # Install the latest version of plugin "myPlugin" for target kubernetes - tanzu plugin install myPlugin --target k8s - - # Install version v1.0.0 of plugin "myPlugin" - tanzu plugin install myPlugin --version v1.0.0`, - Args: cobra.MaximumNArgs(1), + Args: cobra.MaximumNArgs(1), RunE: func(cmd *cobra.Command, args []string) error { var err error var pluginName string @@ -215,6 +243,9 @@ func newInstallPluginCmd() *cobra.Command { if !configtypes.IsValidTarget(targetStr, true, true) { return errors.New(invalidTargetMsg) } + if config.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + return legacyPluginInstall(cmd, args) + } if group != "" { // We are installing from a group @@ -281,9 +312,80 @@ func newInstallPluginCmd() *cobra.Command { return nil }, } + if !config.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + installCmd.Example = ` + # Install all plugins of the vmware-tkg/default plugin group version v2.1.0 + tanzu plugin install --group vmware-tkg/default:v2.1.0 + + # Install all plugins of the latest version of the vmware-tkg/default plugin group + tanzu plugin install --group vmware-tkg/default + + # Install the latest version of plugin "myPlugin" + # If the plugin exists for more than one target, an error will be thrown + tanzu plugin install myPlugin + + # Install the latest version of plugin "myPlugin" for target kubernetes + tanzu plugin install myPlugin --target k8s + + # Install version v1.0.0 of plugin "myPlugin" + tanzu plugin install myPlugin --version v1.0.0` + installCmd.Long = "Install a specific plugin by name or specify all to install all plugins of a group" + } return installCmd } +func legacyPluginInstall(_ *cobra.Command, args []string) error { + var err error + if len(args) == 0 { + return fmt.Errorf("missing plugin name or '%s' as an argument", cli.AllPlugins) + } + pluginName := args[0] + + // Invoke install plugin from local source if local files are provided + if local != "" { + // get absolute local path + local, err = filepath.Abs(local) + if err != nil { + return err + } + err = pluginmanager.InstallPluginsFromLocalSource(pluginName, version, getTarget(), local, false) + if err != nil { + return err + } + if pluginName == cli.AllPlugins { + log.Successf("successfully installed all plugins") + } else { + log.Successf("successfully installed '%s' plugin", pluginName) + } + return nil + } + + // Invoke plugin sync if install all plugins is mentioned + if pluginName == cli.AllPlugins { + err = pluginmanager.SyncPlugins() + if err != nil { + return err + } + log.Successf("successfully installed all plugins") + return nil + } + + pluginVersion := version + if pluginVersion == cli.VersionLatest { + pluginVersion, err = pluginmanager.GetRecommendedVersionOfPlugin(pluginName, getTarget()) + if err != nil { + return err + } + } + + err = pluginmanager.InstallStandalonePlugin(pluginName, pluginVersion, getTarget()) + if err != nil { + return err + } + log.Successf("successfully installed '%s' plugin", pluginName) + return nil +} + func newUpgradePluginCmd() *cobra.Command { var upgradeCmd = &cobra.Command{ Use: "upgrade " + pluginNameCaps, @@ -299,9 +401,19 @@ func newUpgradePluginCmd() *cobra.Command { return errors.New(invalidTargetMsg) } - // With the Central Repository feature we can simply request to install - // the recommendedVersion. - err = pluginmanager.UpgradePlugin(pluginName, cli.VersionLatest, getTarget()) + var pluginVersion string + if !config.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + // With the Central Repository feature we can simply request to install + // the recommendedVersion. + pluginVersion = cli.VersionLatest + } else { + pluginVersion, err = pluginmanager.GetRecommendedVersionOfPlugin(pluginName, getTarget()) + if err != nil { + return err + } + } + + err = pluginmanager.UpgradePlugin(pluginName, pluginVersion, getTarget()) if err != nil { return err } @@ -381,6 +493,16 @@ Plugins installed with this command will only be available while the context rem return syncCmd } +// getInstalledElseAvailablePluginVersion return installed plugin version if plugin is installed +// if not installed it returns available recommended plugin version +func getInstalledElseAvailablePluginVersion(p *discovery.Discovered) string { + installedOrAvailableVersion := p.InstalledVersion + if installedOrAvailableVersion == "" { + installedOrAvailableVersion = p.RecommendedVersion + } + return installedOrAvailableVersion +} + // getInstalledAndMissingContextPlugins returns any context plugins that are not installed func getInstalledAndMissingContextPlugins() (installed, missing []discovery.Discovered, pluginSyncRequired bool, err error) { errorList := make([]error, 0) @@ -427,6 +549,75 @@ func getInstalledAndMissingContextPlugins() (installed, missing []discovery.Disc return installed, missing, pluginSyncRequired, kerrors.NewAggregate(errorList) } +func displayPluginListOutputListView(availablePlugins []discovery.Discovered, writer io.Writer) { + var data [][]string + var output component.OutputWriter + + for index := range availablePlugins { + data = append(data, []string{availablePlugins[index].Name, availablePlugins[index].Description, availablePlugins[index].Scope, + availablePlugins[index].Source, getInstalledElseAvailablePluginVersion(&availablePlugins[index]), availablePlugins[index].Status}) + } + output = component.NewOutputWriter(writer, outputFormat, "Name", "Description", "Scope", "Discovery", "Version", "Status") + + for _, row := range data { + vals := make([]interface{}, len(row)) + for i, val := range row { + vals[i] = val + } + output.AddRow(vals...) + } + output.Render() +} + +func displayPluginListOutputSplitViewContext(availablePlugins []discovery.Discovered, writer io.Writer) { + var dataStandalone [][]string + var outputStandalone component.OutputWriter + dataContext := make(map[string][][]string) + outputContext := make(map[string]component.OutputWriter) + + outputStandalone = component.NewOutputWriter(writer, outputFormat, "Name", "Description", "Target", "Discovery", "Version", "Status") + + for index := range availablePlugins { + if availablePlugins[index].Scope == common.PluginScopeStandalone { + newRow := []string{availablePlugins[index].Name, availablePlugins[index].Description, string(availablePlugins[index].Target), + availablePlugins[index].Source, getInstalledElseAvailablePluginVersion(&availablePlugins[index]), availablePlugins[index].Status} + dataStandalone = append(dataStandalone, newRow) + } else { + newRow := []string{availablePlugins[index].Name, availablePlugins[index].Description, string(availablePlugins[index].Target), + getInstalledElseAvailablePluginVersion(&availablePlugins[index]), availablePlugins[index].Status} + outputContext[availablePlugins[index].ContextName] = component.NewOutputWriter(writer, outputFormat, "Name", "Description", "Target", "Version", "Status") + data := dataContext[availablePlugins[index].ContextName] + data = append(data, newRow) + dataContext[availablePlugins[index].ContextName] = data + } + } + + addDataToOutputWriter := func(output component.OutputWriter, data [][]string) { + for _, row := range data { + vals := make([]interface{}, len(row)) + for i, val := range row { + vals[i] = val + } + output.AddRow(vals...) + } + } + + cyanBold := color.New(color.FgCyan).Add(color.Bold) + cyanBoldItalic := color.New(color.FgCyan).Add(color.Bold, color.Italic) + + _, _ = cyanBold.Println("Standalone Plugins") + addDataToOutputWriter(outputStandalone, dataStandalone) + outputStandalone.Render() + + for context, writer := range outputContext { + fmt.Println("") + _, _ = cyanBold.Println("Plugins from Context: ", cyanBoldItalic.Sprintf(context)) + data := dataContext[context] + addDataToOutputWriter(writer, data) + writer.Render() + } +} + func displayInstalledAndMissingSplitView(installedStandalonePlugins []cli.PluginInfo, installedContextPlugins, missingContextPlugins []discovery.Discovered, pluginSyncRequired bool, writer io.Writer) { // List installed standalone plugins cyanBold := color.New(color.FgCyan).Add(color.Bold) diff --git a/pkg/command/root_test.go b/pkg/command/root_test.go index 67678bb10..2ded3e171 100644 --- a/pkg/command/root_test.go +++ b/pkg/command/root_test.go @@ -361,7 +361,7 @@ func TestEnvVarsSet(t *testing.T) { os.Unsetenv(envVarName) } -func setupFakePlugin(dir, pluginName, version string, commandGroup plugin.CmdGroup, completionType uint8, target configtypes.Target, postInstallResult uint8, hidden bool, aliases []string) error { +func setupFakePlugin(dir, pluginName, _ string, commandGroup plugin.CmdGroup, completionType uint8, target configtypes.Target, postInstallResult uint8, hidden bool, aliases []string) error { filePath := filepath.Join(dir, pluginName) f, err := os.OpenFile(filePath, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0755) diff --git a/pkg/config/defaults.go b/pkg/config/defaults.go index 82cd1d853..44190ff22 100644 --- a/pkg/config/defaults.go +++ b/pkg/config/defaults.go @@ -41,13 +41,13 @@ const CoreRepositoryName = "core" var CoreBucketName = "tanzu-cli-framework" // DefaultVersionSelector is to only use stable versions of plugins -const DefaultVersionSelector = configtypes.NoUnstableVersions // nolint:staticcheck // Deprecated +const DefaultVersionSelector = configtypes.NoUnstableVersions //nolint:staticcheck // Deprecated // DefaultEdition is the edition assumed when there is no value in the local config file const DefaultEdition = "tkg" // CoreGCPBucketRepository is the default GCP bucket repository. -var CoreGCPBucketRepository = configtypes.GCPPluginRepository{ // nolint:staticcheck // Deprecated +var CoreGCPBucketRepository = configtypes.GCPPluginRepository{ //nolint:staticcheck // Deprecated BucketName: CoreBucketName, Name: CoreRepositoryName, } @@ -56,7 +56,7 @@ var CoreGCPBucketRepository = configtypes.GCPPluginRepository{ // nolint:staticc const AdvancedRepositoryName = "advanced" // AdvancedGCPBucketRepository is the GCP bucket repository for advanced plugins. -var AdvancedGCPBucketRepository = configtypes.GCPPluginRepository{ // nolint:staticcheck // Deprecated +var AdvancedGCPBucketRepository = configtypes.GCPPluginRepository{ //nolint:staticcheck // Deprecated BucketName: "tanzu-cli-advanced-plugins", Name: AdvancedRepositoryName, } @@ -65,7 +65,7 @@ var AdvancedGCPBucketRepository = configtypes.GCPPluginRepository{ // nolint:sta const DefaultTMCPluginsArtifactRepository = "https://tmc-cli.s3-us-west-2.amazonaws.com/plugins/artifacts" // DefaultRepositories are the default repositories for the CLI. -var DefaultRepositories = []configtypes.PluginRepository{ // nolint:staticcheck // Deprecated +var DefaultRepositories = []configtypes.PluginRepository{ //nolint:staticcheck // Deprecated { GCPPluginRepository: &CoreGCPBucketRepository, }, @@ -179,7 +179,7 @@ func GetAdditionalTestDiscoveryImages() []string { return additionalImages } -func getHTTPURIForGCPPluginRepository(repo configtypes.GCPPluginRepository) string { // nolint:staticcheck // Deprecated +func getHTTPURIForGCPPluginRepository(repo configtypes.GCPPluginRepository) string { //nolint:staticcheck // Deprecated return fmt.Sprintf("https://storage.googleapis.com/%s/", repo.BucketName) } diff --git a/pkg/cosignhelper/cosignverify.go b/pkg/cosignhelper/cosignverify.go index 1095a82cf..eae3e7989 100644 --- a/pkg/cosignhelper/cosignverify.go +++ b/pkg/cosignhelper/cosignverify.go @@ -118,9 +118,8 @@ func (vo *CosignVerifyOptions) Verify(ctx context.Context, images []string) erro _, _, err = cosign.VerifyImageSignatures(ctx, ref, co) if err == nil { break // if signature verification successful break the loop - } else { - arrErr = append(arrErr, fmt.Errorf("failed validating the signature of the image %s :%w", img, err)) } + arrErr = append(arrErr, fmt.Errorf("failed validating the signature of the image %s :%w", img, err)) } // If all the verifier has returned error then mark the verification as failed // and return the error diff --git a/pkg/discovery/oci_dbbacked_test.go b/pkg/discovery/oci_dbbacked_test.go index ded7b1d81..eb234a645 100644 --- a/pkg/discovery/oci_dbbacked_test.go +++ b/pkg/discovery/oci_dbbacked_test.go @@ -39,16 +39,16 @@ func (stub *stubInventory) GetPluginGroups(filter plugininventory.PluginGroupFil func (stub *stubInventory) CreateSchema() error { return nil } -func (stub *stubInventory) InsertPlugin(pluginInventoryEntry *plugininventory.PluginInventoryEntry) error { +func (stub *stubInventory) InsertPlugin(_ *plugininventory.PluginInventoryEntry) error { return nil } -func (stub *stubInventory) InsertPluginGroup(pg *plugininventory.PluginGroup, override bool) error { +func (stub *stubInventory) InsertPluginGroup(_ *plugininventory.PluginGroup, _ bool) error { return nil } -func (stub *stubInventory) UpdatePluginActivationState(pluginInventoryEntry *plugininventory.PluginInventoryEntry) error { +func (stub *stubInventory) UpdatePluginActivationState(_ *plugininventory.PluginInventoryEntry) error { return nil } -func (stub *stubInventory) UpdatePluginGroupActivationState(pg *plugininventory.PluginGroup) error { +func (stub *stubInventory) UpdatePluginGroupActivationState(_ *plugininventory.PluginGroup) error { return nil } diff --git a/pkg/discovery/rest.go b/pkg/discovery/rest.go index 603535c8b..0b306d2c6 100644 --- a/pkg/discovery/rest.go +++ b/pkg/discovery/rest.go @@ -89,7 +89,8 @@ func (d *RESTDiscovery) doRequest(req *http.Request, v interface{}) error { return fmt.Errorf("API error, status code: %d", res.StatusCode) } - if err := json.NewDecoder(res.Body).Decode(v); err != nil { + err = json.NewDecoder(res.Body).Decode(v) + if err != nil { return err } diff --git a/pkg/discovery/utils.go b/pkg/discovery/utils.go index d7b8ac784..d970bd708 100644 --- a/pkg/discovery/utils.go +++ b/pkg/discovery/utils.go @@ -10,7 +10,7 @@ import ( // CheckDiscoveryName returns true if discovery name exists else return false func CheckDiscoveryName(ds configtypes.PluginDiscovery, dn string) bool { - return (ds.GCP != nil && ds.GCP.Name == dn) || // nolint:staticcheck // Deprecated + return (ds.GCP != nil && ds.GCP.Name == dn) || //nolint:staticcheck // Deprecated (ds.Kubernetes != nil && ds.Kubernetes.Name == dn) || (ds.Local != nil && ds.Local.Name == dn) || (ds.REST != nil && ds.REST.Name == dn) || @@ -39,10 +39,10 @@ func CompareDiscoverySource(ds1, ds2 configtypes.PluginDiscovery, dsType string) } func compareGCPDiscoverySources(ds1, ds2 configtypes.PluginDiscovery) bool { - return ds1.GCP != nil && ds2.GCP != nil && // nolint:staticcheck // Deprecated - ds1.GCP.Name == ds2.GCP.Name && // nolint:staticcheck // Deprecated - ds1.GCP.Bucket == ds2.GCP.Bucket && // nolint:staticcheck // Deprecated - ds1.GCP.ManifestPath == ds2.GCP.ManifestPath // nolint:staticcheck // Deprecated + return ds1.GCP != nil && ds2.GCP != nil && //nolint:staticcheck // Deprecated + ds1.GCP.Name == ds2.GCP.Name && //nolint:staticcheck // Deprecated + ds1.GCP.Bucket == ds2.GCP.Bucket && //nolint:staticcheck // Deprecated + ds1.GCP.ManifestPath == ds2.GCP.ManifestPath //nolint:staticcheck // Deprecated } func compareLocalDiscoverySources(ds1, ds2 configtypes.PluginDiscovery) bool { diff --git a/pkg/plugincmdtree/plugins_cache_test.go b/pkg/plugincmdtree/plugins_cache_test.go index f119db4c7..feee80088 100644 --- a/pkg/plugincmdtree/plugins_cache_test.go +++ b/pkg/plugincmdtree/plugins_cache_test.go @@ -187,7 +187,7 @@ func TestCache_DeleteTree(t *testing.T) { assert.NoError(t, err) } -func getCacheWithSamplePluginCommandTree(pluginName, pluginInstallationPath string) *cacheImpl { +func getCacheWithSamplePluginCommandTree(_, pluginInstallationPath string) *cacheImpl { pluginCMDTree := &CommandNode{ Subcommands: map[string]*CommandNode{ "plugin-subcmd1": &CommandNode{ diff --git a/pkg/plugininventory/sqlite_inventory_test.go b/pkg/plugininventory/sqlite_inventory_test.go index af36b7dcf..d65a07d9e 100644 --- a/pkg/plugininventory/sqlite_inventory_test.go +++ b/pkg/plugininventory/sqlite_inventory_test.go @@ -504,7 +504,7 @@ var _ = Describe("Unit tests for plugin inventory", func() { Expect(len(plugins)).To(Equal(2)) for _, p := range plugins { - if p.Name == "management-cluster" { // nolint: goconst + if p.Name == "management-cluster" { //nolint: goconst Expect(p.RecommendedVersion).To(Equal("v0.28.0")) Expect(string(p.Target)).To(Equal("kubernetes")) Expect(p.Description).To(Equal("Kubernetes management cluster operations")) @@ -515,7 +515,7 @@ var _ = Describe("Unit tests for plugin inventory", func() { artifactList := p.Artifacts["v0.28.0"] Expect(len(artifactList)).To(Equal(2)) for _, a := range artifactList { - if a.OS == "linux" { // nolint: goconst + if a.OS == "linux" { //nolint: goconst Expect(a.Arch).To(Equal("amd64")) Expect(a.Digest).To(Equal("0000000000")) Expect(a.Image).To(Equal(tmpDir + "/vmware/tkg/linux/amd64/k8s/management-cluster:v0.28.0")) diff --git a/pkg/pluginmanager/default_discoveries.go b/pkg/pluginmanager/default_discoveries.go index 22770bbac..8dfc3d67e 100644 --- a/pkg/pluginmanager/default_discoveries.go +++ b/pkg/pluginmanager/default_discoveries.go @@ -16,12 +16,12 @@ const True = "true" const HTTPS = "https" const HTTP = "http" -func defaultDiscoverySourceBasedOnServer(server *configtypes.Server) []configtypes.PluginDiscovery { // nolint:staticcheck // Deprecated +func defaultDiscoverySourceBasedOnServer(server *configtypes.Server) []configtypes.PluginDiscovery { //nolint:staticcheck // Deprecated var defaultDiscoveries []configtypes.PluginDiscovery // If current server type is management-cluster, then add // the default kubernetes discovery endpoint pointing to the // management-cluster kubeconfig - if server != nil && server.Type == configtypes.ManagementClusterServerType && server.ManagementClusterOpts != nil { // nolint:staticcheck // Deprecated + if server != nil && server.Type == configtypes.ManagementClusterServerType && server.ManagementClusterOpts != nil { //nolint:staticcheck // Deprecated defaultDiscoveries = append(defaultDiscoveries, defaultDiscoverySourceForK8sTargetedContext(server.Name, server.ManagementClusterOpts.Path, server.ManagementClusterOpts.Context)) } return defaultDiscoveries diff --git a/pkg/pluginmanager/manager.go b/pkg/pluginmanager/manager.go index 319d08b43..db12d9621 100644 --- a/pkg/pluginmanager/manager.go +++ b/pkg/pluginmanager/manager.go @@ -15,6 +15,8 @@ import ( "strings" "github.com/pkg/errors" + "go.uber.org/multierr" + "golang.org/x/mod/semver" "gopkg.in/yaml.v2" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" kerrors "k8s.io/apimachinery/pkg/util/errors" @@ -29,6 +31,7 @@ import ( "github.com/vmware-tanzu/tanzu-cli/pkg/cli" "github.com/vmware-tanzu/tanzu-cli/pkg/common" "github.com/vmware-tanzu/tanzu-cli/pkg/config" + "github.com/vmware-tanzu/tanzu-cli/pkg/constants" "github.com/vmware-tanzu/tanzu-cli/pkg/discovery" "github.com/vmware-tanzu/tanzu-cli/pkg/distribution" "github.com/vmware-tanzu/tanzu-cli/pkg/plugincmdtree" @@ -62,6 +65,34 @@ type DeletePluginOptions struct { ForceDelete bool } +// ValidatePlugin validates the plugin info. +func ValidatePlugin(p *cli.PluginInfo) (err error) { + // skip builder plugin for bootstrapping + if p.Name == "builder" { + return nil + } + if p.Name == "" { + err = multierr.Append(err, errors.New("plugin name cannot be empty")) + } + if p.Version == "" { + err = multierr.Append(err, fmt.Errorf("plugin %q version cannot be empty", p.Name)) + } + if !semver.IsValid(p.Version) && p.Version != "dev" { + err = multierr.Append(err, fmt.Errorf("version %q %q is not a valid semantic version", p.Name, p.Version)) + } + if p.Description == "" { + err = multierr.Append(err, fmt.Errorf("plugin %q description cannot be empty", p.Name)) + } + if p.Group == "" { + err = multierr.Append(err, fmt.Errorf("plugin %q group cannot be empty", p.Name)) + } + return +} + +func discoverPlugins(pd []configtypes.PluginDiscovery) ([]discovery.Discovered, error) { + return discoverSpecificPlugins(pd, nil) +} + // discoverSpecificPlugins returns all plugins that match the specified criteria from all PluginDiscovery sources, // along with an aggregated error (if any) that occurred while creating the plugin discovery source or fetching plugins. func discoverSpecificPlugins(pd []configtypes.PluginDiscovery, options ...discovery.DiscoveryOptions) ([]discovery.Discovered, error) { @@ -163,6 +194,15 @@ func GetAdditionalTestPluginDiscoveries() []configtypes.PluginDiscovery { // DiscoverServerPlugins returns the available plugins associated all the active contexts func DiscoverServerPlugins() ([]discovery.Discovered, error) { + // If the context and target feature is enabled, discover plugins from all currentContexts + // Else discover plugin based on current Server + if configlib.IsFeatureActivated(constants.FeatureContextCommand) { + return discoverServerPluginsBasedOnAllCurrentContexts() + } + return discoverServerPluginsBasedOnCurrentServer() +} + +func discoverServerPluginsBasedOnAllCurrentContexts() ([]discovery.Discovered, error) { var plugins []discovery.Discovered var errList []error @@ -178,7 +218,7 @@ func DiscoverServerPlugins() ([]discovery.Discovered, error) { var discoverySources []configtypes.PluginDiscovery discoverySources = append(discoverySources, context.DiscoverySources...) discoverySources = append(discoverySources, defaultDiscoverySourceBasedOnContext(context)...) - discoveredPlugins, err := discoverSpecificPlugins(discoverySources) + discoveredPlugins, err := discoverPlugins(discoverySources) // If there is an error while discovering plugins from all of the given plugin sources, // append the error to the error list and continue processing the discoveredPlugins, @@ -204,6 +244,144 @@ func DiscoverServerPlugins() ([]discovery.Discovered, error) { return plugins, kerrors.NewAggregate(errList) } +// discoverServerPluginsBasedOnCurrentServer returns the available plugins associated with the given server +func discoverServerPluginsBasedOnCurrentServer() ([]discovery.Discovered, error) { + var plugins []discovery.Discovered + + server, err := configlib.GetCurrentServer() //nolint:staticcheck // Deprecated + if err != nil || server == nil { + // If servername is not specified than returning empty list + // as there are no server plugins that can be discovered + return plugins, nil + } + var discoverySources []configtypes.PluginDiscovery + discoverySources = append(discoverySources, server.DiscoverySources...) + discoverySources = append(discoverySources, defaultDiscoverySourceBasedOnServer(server)...) + + plugins, err = discoverPlugins(discoverySources) + if err != nil { + log.Warningf(errorWhileDiscoveringPlugins, err.Error()) + } + for i := range plugins { + plugins[i].Scope = common.PluginScopeContext + plugins[i].Status = common.PluginStatusNotInstalled + } + return plugins, nil +} + +// DiscoverPlugins returns all the discovered plugins including standalone and context-scoped plugins +// Context scoped plugin discovery happens for all active contexts +func DiscoverPlugins() ([]discovery.Discovered, []discovery.Discovered) { + serverPlugins, err := DiscoverServerPlugins() + if err != nil { + log.Warningf("unable to discover server plugins, %v", err.Error()) + } + + standalonePlugins, err := DiscoverStandalonePlugins(nil) + if err != nil { + log.Warningf("unable to discover standalone plugins, %v", err.Error()) + } + + // TODO(anuj): Remove duplicate plugins with server plugins getting higher priority + return serverPlugins, standalonePlugins +} + +// AvailablePlugins returns the list of available plugins including discovered and installed plugins. +// Plugin discovery happens for all active contexts +func AvailablePlugins() ([]discovery.Discovered, error) { + discoveredServerPlugins, discoveredStandalonePlugins := DiscoverPlugins() + return availablePlugins(discoveredServerPlugins, discoveredStandalonePlugins) +} + +// AvailablePluginsFromLocalSource returns the list of available plugins from local source +func AvailablePluginsFromLocalSource(localPath string) ([]discovery.Discovered, error) { + localStandalonePlugins, err := DiscoverPluginsFromLocalSource(localPath) + if err != nil { + log.Warningf("Unable to discover standalone plugins from local source, %v", err.Error()) + } + return availablePlugins([]discovery.Discovered{}, localStandalonePlugins) +} + +func availablePlugins(discoveredServerPlugins, discoveredStandalonePlugins []discovery.Discovered) ([]discovery.Discovered, error) { + installedPlugins, err := pluginsupplier.GetInstalledPlugins() + if err != nil { + return nil, err + } + + availablePlugins := availablePluginsFromStandaloneAndServerPlugins(discoveredServerPlugins, discoveredStandalonePlugins) + setAvailablePluginsStatus(availablePlugins, installedPlugins) + + installedStandalonePlugins, err := pluginsupplier.GetInstalledStandalonePlugins() + if err != nil { + return nil, err + } + installedButNotDiscoveredPlugins := getInstalledButNotDiscoveredStandalonePlugins(availablePlugins, installedStandalonePlugins) + availablePlugins = append(availablePlugins, installedButNotDiscoveredPlugins...) + + availablePlugins = combineDuplicatePlugins(availablePlugins) + + return availablePlugins, nil +} + +// combineDuplicatePlugins combines same plugins to eliminate duplicates +// When there is a plugin name conflicts and target of both the plugins are same, remove duplicate one. +// In addition to above, plugin with same name having `k8s` and `none` target are also considered same for +// backward compatibility reasons. Considering, we are adding `k8s` targeted plugins as root level commands. +// +// E.g. A plugin 'foo' getting discovered/installed with `` target and a plugin `foo` getting discovered +// with `k8s` discovery (having `k8s` target) should be treated as same plugin. +// This function takes this case into consideration and removes `` targeted plugin for above the mentioned scenario. +func combineDuplicatePlugins(availablePlugins []discovery.Discovered) []discovery.Discovered { + mapOfSelectedPlugins := make(map[string]discovery.Discovered) + + // TODO: If there are multiple discovered (but not installed) plugins of the same name then we will + // always end up keeping one deterministically (due to the sequence of sources/plugins that we process), + // but we should merge the result and show the combined result for duplicate plugins + combinePluginInstallationStatus := func(plugin1, plugin2 discovery.Discovered) discovery.Discovered { + // Combine the installation status and installedVersion result when combining plugins + if plugin2.Status == common.PluginStatusInstalled { + plugin1.Status = common.PluginStatusInstalled + } + if plugin2.InstalledVersion != "" { + plugin1.InstalledVersion = plugin2.InstalledVersion + } + return plugin1 + } + + for i := range availablePlugins { + if availablePlugins[i].Target == configtypes.TargetUnknown { + // As we are considering None targeted and k8s target plugin to be treated as same plugins + // in the case of plugin name conflicts, using `k8s` target to determine the plugin already + // exists or not. + // If plugin already exists in the map then combining the installation status for both the plugins + key := fmt.Sprintf("%s_%s", availablePlugins[i].Name, configtypes.TargetK8s) + dp, exists := mapOfSelectedPlugins[key] + if !exists { + mapOfSelectedPlugins[key] = availablePlugins[i] + } else { + mapOfSelectedPlugins[key] = combinePluginInstallationStatus(dp, availablePlugins[i]) + } + } else { + // If plugin doesn't exist in the map then add the plugin to the map + // else combine the installation status for both the plugins + key := fmt.Sprintf("%s_%s", availablePlugins[i].Name, availablePlugins[i].Target) + dp, exists := mapOfSelectedPlugins[key] + if !exists { + mapOfSelectedPlugins[key] = availablePlugins[i] + } else if availablePlugins[i].Target == configtypes.TargetK8s || availablePlugins[i].Scope == common.PluginScopeContext { + mapOfSelectedPlugins[key] = combinePluginInstallationStatus(availablePlugins[i], dp) + } + } + } + + var selectedPlugins []discovery.Discovered + for key := range mapOfSelectedPlugins { + selectedPlugins = append(selectedPlugins, mapOfSelectedPlugins[key]) + } + + return selectedPlugins +} + func mergePluginEntries(plugin1, plugin2 *discovery.Discovered) *discovery.Discovered { // Plugins with the same name having `k8s` and `none` targets are also considered the same for // backward compatibility reasons, considering, we are adding `k8s` targeted plugins as root level commands. @@ -362,6 +540,46 @@ func mergeDuplicateGroups(groups []*plugininventory.PluginGroup) []*plugininvent return mergedGroups } +func getInstalledButNotDiscoveredStandalonePlugins(availablePlugins []discovery.Discovered, installedPlugins []cli.PluginInfo) []discovery.Discovered { + var newPlugins []discovery.Discovered + for i := range installedPlugins { + found := false + for j := range availablePlugins { + if installedPlugins[i].Name == availablePlugins[j].Name && installedPlugins[i].Target == availablePlugins[j].Target { + found = true + // If plugin is installed but marked as not installed as part of availablePlugins list + // mark the plugin as installed + // This is possible if user has used --local mode to install the plugin which is also + // getting discovered from the configured discovery sources + if availablePlugins[j].Status == common.PluginStatusNotInstalled { + availablePlugins[j].Status = common.PluginStatusInstalled + } + } + } + if !found { + p := DiscoveredFromPlugininfo(&installedPlugins[i]) + p.Scope = common.PluginScopeStandalone + p.Status = common.PluginStatusInstalled + p.InstalledVersion = installedPlugins[i].Version + newPlugins = append(newPlugins, p) + } + } + return newPlugins +} + +// DiscoveredFromPlugininfo returns discovered plugin object from k8sV1alpha1 +func DiscoveredFromPlugininfo(p *cli.PluginInfo) discovery.Discovered { + dp := discovery.Discovered{ + Name: p.Name, + Description: p.Description, + RecommendedVersion: p.Version, + Source: p.Discovery, + SupportedVersions: []string{p.Version}, + Target: p.Target, + } + return dp +} + func setAvailablePluginsStatus(availablePlugins []discovery.Discovered, installedPlugins []cli.PluginInfo) { for i := range installedPlugins { for j := range availablePlugins { @@ -378,6 +596,41 @@ func setAvailablePluginsStatus(availablePlugins []discovery.Discovered, installe } } +func availablePluginsFromStandaloneAndServerPlugins(discoveredServerPlugins, discoveredStandalonePlugins []discovery.Discovered) []discovery.Discovered { + availablePlugins := discoveredServerPlugins + + // Check whether the default standalone discovery type is local or not + isLocalStandaloneDiscovery := config.GetDefaultStandaloneDiscoveryType() == common.DiscoveryTypeLocal + + for i := range discoveredStandalonePlugins { + matchIndex := pluginIndexForName(availablePlugins, &discoveredStandalonePlugins[i]) + + // Add the standalone plugin to available plugins if it doesn't exist in the serverPlugins list + // OR + // Current standalone discovery or plugin discovered is of type 'local' + // We are overriding the discovered plugins that we got from server in case of 'local' discovery type + // to allow developers to use the plugins that are built locally and not returned from the server + // This local discovery is only used for development purpose and should not be used for production + if matchIndex < 0 { + availablePlugins = append(availablePlugins, discoveredStandalonePlugins[i]) + continue + } + if isLocalStandaloneDiscovery || discoveredStandalonePlugins[i].DiscoveryType == common.DiscoveryTypeLocal { // matchIndex >= 0 is guaranteed here + availablePlugins[matchIndex] = discoveredStandalonePlugins[i] + } + } + return availablePlugins +} + +func pluginIndexForName(availablePlugins []discovery.Discovered, p *discovery.Discovered) int { + for j := range availablePlugins { + if p != nil && p.Name == availablePlugins[j].Name && p.Target == availablePlugins[j].Target { + return j + } + } + return -1 // haven't found a match +} + // DescribePlugin describes a plugin. func DescribePlugin(pluginName string, target configtypes.Target) (info *cli.PluginInfo, err error) { plugins, err := pluginsupplier.GetInstalledPlugins() @@ -446,8 +699,15 @@ func InstallPluginFromContext(pluginName, version string, target configtypes.Tar // installs a plugin by name, version and target. // If the contextName is not empty, it implies the plugin is a context-scope plugin, otherwise // we are installing a standalone plugin. -// nolint: gocyclo +// +//nolint:gocyclo func installPlugin(pluginName, version string, target configtypes.Target, contextName string) error { + if configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + // The legacy installation can figure out if the plugin is from a context + // because it searches all contexts for plugins. So, we don't need to pass on that parameter. + return legacyPluginInstall(pluginName, version, target) + } + discoveries, err := getPluginDiscoveries() if err != nil { return err @@ -522,6 +782,41 @@ func installPlugin(pluginName, version string, target configtypes.Target, contex return kerrors.NewAggregate(errorList) } +// legacyInstallPlugin installs a plugin by name, version and target. +// This function is only used without the Central Repository feature. +func legacyPluginInstall(pluginName, version string, target configtypes.Target) error { + availablePlugins, err := AvailablePlugins() + if err != nil { + return err + } + + var matchedPlugins []discovery.Discovered + for i := range availablePlugins { + if availablePlugins[i].Name == pluginName && + (target == configtypes.TargetUnknown || target == availablePlugins[i].Target) { + matchedPlugins = append(matchedPlugins, availablePlugins[i]) + } + } + if len(matchedPlugins) == 0 { + if target != configtypes.TargetUnknown { + return errors.Errorf("unable to find plugin '%v' with version '%v' for target '%s'", pluginName, version, string(target)) + } + return errors.Errorf("unable to find plugin '%v' with version '%v'", pluginName, version) + } + + if len(matchedPlugins) == 1 { + return installOrUpgradePlugin(&matchedPlugins[0], version, false) + } + + for i := range matchedPlugins { + if matchedPlugins[i].Target == target { + return installOrUpgradePlugin(&matchedPlugins[i], version, false) + } + } + + return errors.Errorf(missingTargetStr, pluginName) +} + // UpgradePlugin upgrades a plugin from the given repository. func UpgradePlugin(pluginName, version string, target configtypes.Target) error { // Upgrade is only triggered from a manual user operation. @@ -607,27 +902,60 @@ func InstallPluginsFromGroup(pluginName, groupIDAndVersion string, options ...Pl } if !pluginExist { - return groupIDAndVersion, fmt.Errorf("plugin '%s' is not part of the group '%s'", pluginName, groupIDAndVersion) + return "", fmt.Errorf("plugin '%s' is not part of the group '%s'", pluginName, groupIDAndVersion) } if !mandatoryPluginsExist { if pluginName == cli.AllPlugins { - return groupIDAndVersion, fmt.Errorf("plugin group '%s' has no mandatory plugins to install", groupIDAndVersion) + return "", fmt.Errorf("plugin group '%s' has no mandatory plugins to install", groupIDAndVersion) } - return groupIDAndVersion, fmt.Errorf("plugin '%s' from group '%s' is not mandatory to install", pluginName, groupIDAndVersion) + return "", fmt.Errorf("plugin '%s' from group '%s' is not mandatory to install", pluginName, groupIDAndVersion) } if numErrors > 0 { - return groupIDAndVersion, fmt.Errorf("could not install %d plugin(s) from group '%s'", numErrors, groupIDAndVersion) + return "", fmt.Errorf("could not install %d plugin(s) from group '%s'", numErrors, groupIDAndVersion) } if numInstalled == 0 { - return groupIDAndVersion, fmt.Errorf("plugin '%s' is not part of the group '%s'", pluginName, groupIDAndVersion) + return "", fmt.Errorf("plugin '%s' is not part of the group '%s'", pluginName, groupIDAndVersion) } return groupIDAndVersion, nil } +// GetRecommendedVersionOfPlugin returns recommended version of the plugin +func GetRecommendedVersionOfPlugin(pluginName string, target configtypes.Target) (string, error) { + availablePlugins, err := AvailablePlugins() + if err != nil { + return "", err + } + + var matchedPlugins []discovery.Discovered + for i := range availablePlugins { + if availablePlugins[i].Name == pluginName && + (target == configtypes.TargetUnknown || target == availablePlugins[i].Target) { + matchedPlugins = append(matchedPlugins, availablePlugins[i]) + } + } + if len(matchedPlugins) == 0 { + if target != configtypes.TargetUnknown { + return "", errors.Errorf("unable to find plugin '%v' for target '%s'", pluginName, string(target)) + } + return "", errors.Errorf("unable to find plugin '%v'", pluginName) + } + + if len(matchedPlugins) == 1 { + return matchedPlugins[0].RecommendedVersion, nil + } + + for i := range matchedPlugins { + if matchedPlugins[i].Target == target { + return matchedPlugins[i].RecommendedVersion, nil + } + } + return "", errors.Errorf(missingTargetStr, pluginName) +} + func installOrUpgradePlugin(p *discovery.Discovered, version string, installTestPlugin bool) error { if p.Target == configtypes.TargetUnknown { log.Infof("Installing plugin '%v:%v'", p.Name, version) @@ -777,19 +1105,13 @@ func doInstallTestPlugin(p *discovery.Discovered, pluginPath, version string) er } func updatePluginInfoAndInitializePlugin(p *discovery.Discovered, plugin *cli.PluginInfo) error { - c, err := catalog.NewContextCatalogUpdater(p.ContextName) + c, err := catalog.NewContextCatalog(p.ContextName) if err != nil { return err } if err := c.Upsert(plugin); err != nil { log.Info("Plugin Info could not be updated in cache") } - - // We are not using defer `c.Unlock()` to release the lock here because we want to unlock the lock as soon as possible - // Using `defer` here will release the lock after `InitializePlugin`, `ConfigureDefaultFeatureFlagsIfMissing`, - // `addPluginToCommandTreeCache` invocations which is not what we want. - c.Unlock() - if err := InitializePlugin(plugin); err != nil { log.Infof("could not initialize plugin after installing: %v", err.Error()) } @@ -900,13 +1222,12 @@ func doDeletePluginFromCatalog(pluginName string, target configtypes.Target, cat // If we re-use the catalogs created above, when we delete the plugin // in one catalog, the next catalog will put it back since that catalog // was created before the plugin was deleted. - c, err := catalog.NewContextCatalogUpdater(n) + c, err := catalog.NewContextCatalog(n) if err != nil { continue } err = c.Delete(catalog.PluginNameTarget(pluginName, target)) - c.Unlock() if err != nil { return fmt.Errorf("plugin %q could not be deleted from cache", pluginName) } @@ -919,22 +1240,31 @@ func doDeletePluginFromCatalog(pluginName string, target configtypes.Target, cat // If the central-repo is disabled, all discovered plugins will be installed. func SyncPlugins() error { log.Info("Checking for required plugins...") + var plugins []discovery.Discovered + var err error errList := make([]error, 0) - // We no longer sync standalone plugins. - // With a centralized approach to discovering plugins, synchronizing - // standalone plugins would install ALL plugins available for ALL - // products. - // Instead, we only synchronize any plugins that are specifically specified - // by the contexts. - // - // Note: to install all plugins for a specific product, plugin groups will - // need to be used. - plugins, err := DiscoverServerPlugins() - if err != nil { - errList = append(errList, err) - } - if installedPlugins, err := pluginsupplier.GetInstalledServerPlugins(); err == nil { - setAvailablePluginsStatus(plugins, installedPlugins) + if !configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + // We no longer sync standalone plugins. + // With a centralized approach to discovering plugins, synchronizing + // standalone plugins would install ALL plugins available for ALL + // products. + // Instead, we only synchronize any plugins that are specifically specified + // by the contexts. + // + // Note: to install all plugins for a specific product, plugin groups will + // need to be used. + plugins, err = DiscoverServerPlugins() + if err != nil { + errList = append(errList, err) + } + if installedPlugins, err := pluginsupplier.GetInstalledServerPlugins(); err == nil { + setAvailablePluginsStatus(plugins, installedPlugins) + } + } else { + plugins, err = AvailablePlugins() + if err != nil { + errList = append(errList, err) + } } installed := false @@ -962,7 +1292,8 @@ func SyncPlugins() error { } // InstallPluginsFromLocalSource installs plugin from local source directory -// nolint: gocyclo +// +//nolint:gocyclo func InstallPluginsFromLocalSource(pluginName, version string, target configtypes.Target, localPath string, installTestPlugin bool) error { // Set default local plugin distro to local-path as while installing the plugin // from local source we should take t @@ -1066,7 +1397,7 @@ func discoverPluginsFromLocalSource(localPath string) ([]discovery.Discovered, e } } - plugins, err := discoverSpecificPlugins(pds) + plugins, err := discoverPlugins(pds) if err != nil { log.Warningf(errorWhileDiscoveringPlugins, err.Error()) } @@ -1327,8 +1658,11 @@ func FindVersion(recommendedPluginVersion, requestedVersion string) string { // getPluginDiscoveries returns the plugin discoveries found in the configuration file. func getPluginDiscoveries() ([]configtypes.PluginDiscovery, error) { - // Look for testing discoveries. Those should be stored and searched AFTER the central repo. - testDiscoveries := GetAdditionalTestPluginDiscoveries() + var testDiscoveries []configtypes.PluginDiscovery + if !configlib.IsFeatureActivated(constants.FeatureDisableCentralRepositoryForTesting) { + // Look for testing discoveries. Those should be stored and searched AFTER the central repo. + testDiscoveries = GetAdditionalTestPluginDiscoveries() + } // The configured discoveries should be searched BEFORE the test discoveries. // For example, if the staging central repo is added as a test discovery, it diff --git a/pkg/pluginmanager/manager_test.go b/pkg/pluginmanager/manager_test.go index 1468b0915..b469b39e0 100644 --- a/pkg/pluginmanager/manager_test.go +++ b/pkg/pluginmanager/manager_test.go @@ -8,11 +8,13 @@ import ( "os" "os/exec" "path/filepath" + "strings" "testing" "github.com/pkg/errors" "github.com/stretchr/testify/assert" + configlib "github.com/vmware-tanzu/tanzu-plugin-runtime/config" configtypes "github.com/vmware-tanzu/tanzu-plugin-runtime/config/types" "github.com/vmware-tanzu/tanzu-cli/pkg/cli" @@ -23,6 +25,7 @@ import ( "github.com/vmware-tanzu/tanzu-cli/pkg/distribution" "github.com/vmware-tanzu/tanzu-cli/pkg/plugininventory" "github.com/vmware-tanzu/tanzu-cli/pkg/pluginsupplier" + "github.com/vmware-tanzu/tanzu-plugin-runtime/log" ) var expectedDiscoveredContextPlugins = []discovery.Discovered{ @@ -50,152 +53,181 @@ var expectedDiscoveredContextPlugins = []discovery.Discovered{ } var expectedDiscoveredStandalonePlugins = []discovery.Discovered{ { - Name: "management-cluster", - Description: "Plugin management-cluster description", - RecommendedVersion: "v1.6.0", - SupportedVersions: []string{"v1.6.0"}, - Scope: common.PluginScopeStandalone, - ContextName: "", - Target: configtypes.TargetK8s, - }, - { - Name: "cluster", - Description: "Plugin cluster description", - RecommendedVersion: "v1.6.0", - SupportedVersions: []string{"v1.6.0"}, - Scope: common.PluginScopeStandalone, - ContextName: "", - Target: configtypes.TargetK8s, - }, - { - Name: "myplugin", - Description: "Plugin myplugin description", - RecommendedVersion: "v1.6.0", - SupportedVersions: []string{"v1.6.0"}, + Name: "login", + RecommendedVersion: "v0.2.0", Scope: common.PluginScopeStandalone, ContextName: "", - Target: configtypes.TargetK8s, + Target: configtypes.TargetUnknown, }, { Name: "feature", - Description: "Plugin feature description", RecommendedVersion: "v0.2.0", - SupportedVersions: []string{"v0.2.0"}, Scope: common.PluginScopeStandalone, ContextName: "", Target: configtypes.TargetK8s, }, - { - Name: "isolated-cluster", - Description: "Plugin isolated-cluster description", - RecommendedVersion: "v1.3.0", - SupportedVersions: []string{"v1.2.3", "v1.3.0"}, - Scope: common.PluginScopeStandalone, - ContextName: "", - Target: configtypes.TargetGlobal, - }, - { - Name: "login", - Description: "Plugin login description", - RecommendedVersion: "v0.2.0", - SupportedVersions: []string{"v0.2.0"}, - Scope: common.PluginScopeStandalone, - ContextName: "", - Target: configtypes.TargetGlobal, - }, { Name: "management-cluster", - Description: "Plugin management-cluster description", - RecommendedVersion: "v0.2.0", - SupportedVersions: []string{"v0.0.1", "v0.0.2", "v0.0.3", "v0.2.0"}, + RecommendedVersion: "v1.6.0", Scope: common.PluginScopeStandalone, ContextName: "", - Target: configtypes.TargetTMC, + Target: configtypes.TargetK8s, }, { - Name: "cluster", - Description: "Plugin cluster description", - RecommendedVersion: "v0.2.0", - SupportedVersions: []string{"v0.2.0"}, + Name: "myplugin", + RecommendedVersion: "v1.6.0", Scope: common.PluginScopeStandalone, ContextName: "", - Target: configtypes.TargetTMC, + Target: configtypes.TargetK8s, }, { Name: "myplugin", - Description: "Plugin myplugin description", RecommendedVersion: "v0.2.0", - SupportedVersions: []string{"v0.2.0"}, Scope: common.PluginScopeStandalone, ContextName: "", Target: configtypes.TargetTMC, }, } -var expectedDiscoveredGroups = []string{"vmware-test/default:v1.6.0", "vmware-test/default:v2.1.0"} - -const ( - testGroupName = "vmware-test/default" - testGroupVersion = "v1.6.0" -) - -func Test_DiscoverStandalonePlugins(t *testing.T) { +func Test_DiscoverPlugins(t *testing.T) { assertions := assert.New(t) - defer setupPluginSourceForTesting()() + defer setupLocalDistroForTesting()() - standalonePlugins, err := DiscoverStandalonePlugins() - assertions.Nil(err) + serverPlugins, standalonePlugins := DiscoverPlugins() + assertions.Equal(len(expectedDiscoveredContextPlugins), len(serverPlugins)) assertions.Equal(len(expectedDiscoveredStandalonePlugins), len(standalonePlugins)) - for i := range expectedDiscoveredStandalonePlugins { - p := findDiscoveredPlugin(standalonePlugins, expectedDiscoveredStandalonePlugins[i].Name, expectedDiscoveredStandalonePlugins[i].Target) + discoveredPlugins := append(serverPlugins, standalonePlugins...) + expectedDiscoveredPlugins := append(expectedDiscoveredContextPlugins, expectedDiscoveredStandalonePlugins...) + + for i := 0; i < len(expectedDiscoveredPlugins); i++ { + p := findDiscoveredPlugin(discoveredPlugins, expectedDiscoveredPlugins[i].Name, expectedDiscoveredPlugins[i].Target) assertions.NotNil(p) - assertions.Equal(expectedDiscoveredStandalonePlugins[i].Description, p.Description) - assertions.Equal(expectedDiscoveredStandalonePlugins[i].RecommendedVersion, p.RecommendedVersion) - assertions.Equal(expectedDiscoveredStandalonePlugins[i].SupportedVersions, p.SupportedVersions) - assertions.Equal(expectedDiscoveredStandalonePlugins[i].Scope, p.Scope) - assertions.Equal(expectedDiscoveredStandalonePlugins[i].ContextName, p.ContextName) + assertions.Equal(expectedDiscoveredPlugins[i].Name, p.Name) + assertions.Equal(expectedDiscoveredPlugins[i].RecommendedVersion, p.RecommendedVersion) + assertions.Equal(expectedDiscoveredPlugins[i].Target, p.Target) } + + err := configlib.SetFeature("global", "context-target-v2", "false") + assertions.Nil(err) + + serverPlugins, standalonePlugins = DiscoverPlugins() + assertions.Equal(1, len(serverPlugins)) + assertions.Equal(len(expectedDiscoveredStandalonePlugins), len(standalonePlugins)) } -func Test_DiscoverServerPlugins(t *testing.T) { +func Test_InstallPlugin_InstalledPlugins_No_Central_Repo(t *testing.T) { assertions := assert.New(t) - defer setupPluginSourceForTesting()() + defer setupLocalDistroForTesting()() + execCommand = fakeInfoExecCommand + defer func() { execCommand = exec.Command }() + + // Turn off central repo feature + featureArray := strings.Split(constants.FeatureDisableCentralRepositoryForTesting, ".") + err := configlib.SetFeature(featureArray[1], featureArray[2], "true") + assertions.Nil(err) - serverPlugins, err := DiscoverServerPlugins() + // Try installing nonexistent plugin + err = InstallStandalonePlugin("not-exists", "v0.2.0", configtypes.TargetUnknown) assertions.NotNil(err) - assertions.Contains(err.Error(), "unable to list plugins from discovery source 'default-mgmt': Failed to load Kubeconfig file") - assertions.Equal(len(expectedDiscoveredContextPlugins), len(serverPlugins)) + assertions.Contains(err.Error(), "unable to find plugin 'not-exists'") - for i := range expectedDiscoveredContextPlugins { - p := findDiscoveredPlugin(serverPlugins, expectedDiscoveredContextPlugins[i].Name, expectedDiscoveredContextPlugins[i].Target) - assertions.NotNil(p) - assertions.Equal(expectedDiscoveredContextPlugins[i].RecommendedVersion, p.RecommendedVersion) - assertions.Equal(expectedDiscoveredContextPlugins[i].Scope, p.Scope) - assertions.Equal(expectedDiscoveredContextPlugins[i].ContextName, p.ContextName) - } -} + // Install login (standalone) plugin + err = InstallStandalonePlugin("login", "v0.2.0", configtypes.TargetUnknown) + assertions.Nil(err) + // Verify installed plugin + installedPlugins, err := pluginsupplier.GetInstalledPlugins() + assertions.Nil(err) + assertions.Equal(1, len(installedPlugins)) + assertions.Equal("login", installedPlugins[0].Name) -func Test_DiscoverPluginGroups(t *testing.T) { - assertions := assert.New(t) + // Try installing cluster plugin with no context-type + err = InstallStandalonePlugin("cluster", "v0.2.0", configtypes.TargetUnknown) + assertions.NotNil(err) + assertions.Contains(err.Error(), fmt.Sprintf(missingTargetStr, "cluster")) + + // Try installing cluster plugin with context-type=tmc + err = InstallStandalonePlugin("cluster", "v0.2.0", configtypes.TargetTMC) + assertions.Nil(err) + + // Try installing cluster plugin through context-type=k8s with incorrect version + err = InstallStandalonePlugin("cluster", "v1.0.0", configtypes.TargetK8s) + assertions.NotNil(err) + assertions.Contains(err.Error(), "plugin pre-download verification failed") + + // Try installing cluster plugin through context-type=k8s + err = InstallStandalonePlugin("cluster", "v1.6.0", configtypes.TargetK8s) + assertions.Nil(err) - defer setupPluginSourceForTesting()() + // Try installing management-cluster plugin from standalone discovery without context-type + err = InstallStandalonePlugin("management-cluster", "v1.6.0", configtypes.TargetUnknown) + assertions.NotNil(err) + assertions.Contains(err.Error(), fmt.Sprintf(missingTargetStr, "management-cluster")) - groups, err := DiscoverPluginGroups() + // Try installing management-cluster plugin from standalone discovery + err = InstallStandalonePlugin("management-cluster", "v1.6.0", configtypes.TargetK8s) assertions.Nil(err) - for _, id := range expectedDiscoveredGroups { - found := findGroupVersion(groups, id) - assertions.True(found, fmt.Sprintf("unable to find group %s", id)) + // Try installing the feature plugin which is targeted for k8s but requesting the TMC target + err = InstallStandalonePlugin("feature", "v0.2.0", configtypes.TargetTMC) + assertions.NotNil(err) + assertions.Contains(err.Error(), "unable to find plugin 'feature' with version 'v0.2.0' for target 'mission-control'") + + // Verify installed plugins + installedStandalonePlugins, err := pluginsupplier.GetInstalledStandalonePlugins() + assertions.Nil(err) + assertions.Equal(2, len(installedStandalonePlugins)) + installedServerPlugins, err := pluginsupplier.GetInstalledServerPlugins() + assertions.Nil(err) + assertions.Equal(2, len(installedServerPlugins)) + + expectedInstalledServerPlugins := []cli.PluginInfo{ + { + Name: "cluster", + Version: "v1.6.0", + Scope: common.PluginScopeContext, + Target: configtypes.TargetK8s, + }, + { + Name: "cluster", + Version: "v0.2.0", + Scope: common.PluginScopeContext, + Target: configtypes.TargetTMC, + }, + } + expectedInstalledStandalonePlugins := []cli.PluginInfo{ + { + Name: "login", + Version: "v0.2.0", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetUnknown, + }, + { + Name: "management-cluster", + Version: "v1.6.0", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetK8s, + }, + } + + for i := 0; i < len(expectedInstalledServerPlugins); i++ { + pd := findPluginInfo(installedServerPlugins, expectedInstalledServerPlugins[i].Name, expectedInstalledServerPlugins[i].Target) + assertions.NotNil(pd) + assertions.Equal(expectedInstalledServerPlugins[i].Version, pd.Version) + } + for i := 0; i < len(expectedInstalledStandalonePlugins); i++ { + pd := findPluginInfo(installedStandalonePlugins, expectedInstalledStandalonePlugins[i].Name, expectedInstalledStandalonePlugins[i].Target) + assertions.NotNil(pd) + assertions.Equal(expectedInstalledStandalonePlugins[i].Version, pd.Version) } } -func Test_InstallStandalonePlugin(t *testing.T) { +func Test_InstallPlugin_InstalledPlugins_Central_Repo(t *testing.T) { assertions := assert.New(t) - defer setupPluginSourceForTesting()() + defer setupLocalDistroForTesting()() execCommand = fakeInfoExecCommand defer func() { execCommand = exec.Command }() @@ -213,25 +245,25 @@ func Test_InstallStandalonePlugin(t *testing.T) { assertions.Equal(1, len(installedPlugins)) assertions.Equal("login", installedPlugins[0].Name) - // Try installing myplugin plugin with no context-type and no specific version - err = InstallStandalonePlugin("myplugin", cli.VersionLatest, configtypes.TargetUnknown) + // Try installing myplugin plugin with no context-type + err = InstallStandalonePlugin("myplugin", "v0.2.0", configtypes.TargetUnknown) assertions.NotNil(err) assertions.Contains(err.Error(), fmt.Sprintf(missingTargetStr, "myplugin")) - // Try installing myplugin plugin with context-type=tmc with no specific version - err = InstallStandalonePlugin("myplugin", cli.VersionLatest, configtypes.TargetTMC) + // Try installing myplugin plugin with context-type=tmc + err = InstallStandalonePlugin("myplugin", "v0.2.0", configtypes.TargetTMC) assertions.Nil(err) // Try installing myplugin plugin through context-type=k8s with incorrect version err = InstallStandalonePlugin("myplugin", "v1.0.0", configtypes.TargetK8s) assertions.NotNil(err) - assertions.Contains(err.Error(), "unable to find plugin 'myplugin' with version 'v1.0.0'") + assertions.Contains(err.Error(), "plugin pre-download verification failed") - // Try installing myplugin plugin through context-type=k8s with the correct version + // Try installing myplugin plugin through context-type=k8s err = InstallStandalonePlugin("myplugin", "v1.6.0", configtypes.TargetK8s) assertions.Nil(err) - // Try installing management-cluster plugin + // Try installing management-cluster plugin from standalone discovery err = InstallStandalonePlugin("management-cluster", "v1.6.0", configtypes.TargetK8s) assertions.Nil(err) @@ -253,7 +285,7 @@ func Test_InstallStandalonePlugin(t *testing.T) { Name: "login", Version: "v0.2.0", Scope: common.PluginScopeStandalone, - Target: configtypes.TargetGlobal, + Target: configtypes.TargetUnknown, }, { Name: "management-cluster", @@ -282,76 +314,23 @@ func Test_InstallStandalonePlugin(t *testing.T) { } } -func Test_InstallPluginsFromGroup(t *testing.T) { +func Test_InstallPluginFromGroup(t *testing.T) { assertions := assert.New(t) - defer setupPluginSourceForTesting()() + defer setupLocalDistroForTesting()() execCommand = fakeInfoExecCommand defer func() { execCommand = exec.Command }() - // Install the management-cluster plugin from a group:version - groupID := testGroupName + ":" + testGroupVersion - fullGroupID, err := InstallPluginsFromGroup("management-cluster", groupID) - assertions.Nil(err) - assertions.Equal(groupID, fullGroupID) - - installedStandalonePlugins, err := pluginsupplier.GetInstalledStandalonePlugins() - assertions.Nil(err) - assertions.Equal(1, len(installedStandalonePlugins)) - pd := findPluginInfo(installedStandalonePlugins, "management-cluster", configtypes.TargetK8s) - assertions.NotNil(pd) - assertions.Equal("v1.6.0", pd.Version) - - // Install the isolated-cluster from the latest group - groupID = testGroupName - fullGroupID, err = InstallPluginsFromGroup("isolated-cluster", groupID) - assertions.Nil(err) - assertions.Equal(groupID+":v2.1.0", fullGroupID) - - installedStandalonePlugins, err = pluginsupplier.GetInstalledStandalonePlugins() - assertions.Nil(err) - assertions.Equal(2, len(installedStandalonePlugins)) - pd = findPluginInfo(installedStandalonePlugins, "management-cluster", configtypes.TargetK8s) - assertions.NotNil(pd) - assertions.Equal("v1.6.0", pd.Version) - pd = findPluginInfo(installedStandalonePlugins, "isolated-cluster", configtypes.TargetGlobal) - assertions.NotNil(pd) - assertions.Equal("v1.3.0", pd.Version) - - // Install all plugins from a group:version - // Note that this should replace isolated-cluster:v1.3.0 with its v1.2.3 version - groupID = testGroupName + ":" + testGroupVersion - fullGroupID, err = InstallPluginsFromGroup(cli.AllPlugins, groupID) - assertions.Nil(err) - assertions.Equal(groupID, fullGroupID) - - installedStandalonePlugins, err = pluginsupplier.GetInstalledStandalonePlugins() - assertions.Nil(err) - assertions.Equal(4, len(installedStandalonePlugins)) - pd = findPluginInfo(installedStandalonePlugins, "management-cluster", configtypes.TargetK8s) - assertions.NotNil(pd) - assertions.Equal("v1.6.0", pd.Version) - pd = findPluginInfo(installedStandalonePlugins, "isolated-cluster", configtypes.TargetGlobal) - assertions.NotNil(pd) - assertions.Equal("v1.2.3", pd.Version) - pd = findPluginInfo(installedStandalonePlugins, "myplugin", configtypes.TargetK8s) - assertions.NotNil(pd) - assertions.Equal("v1.6.0", pd.Version) - pd = findPluginInfo(installedStandalonePlugins, "feature", configtypes.TargetK8s) - assertions.NotNil(pd) - assertions.Equal("v0.2.0", pd.Version) -} - -func Test_InstallPluginsFromGroupErrors(t *testing.T) { - assertions := assert.New(t) - - defer setupPluginSourceForTesting()() - execCommand = fakeInfoExecCommand - defer func() { execCommand = exec.Command }() + // A local discovery currently does not support groups, but we can + // at least do negative testing + groupID := "vmware-tkg/default:v2.1.0" + _, err := InstallPluginsFromGroup("cluster", groupID) + assertions.NotNil(err) + assertions.Contains(err.Error(), "unable to create group discovery: unknown group discovery source") // make sure a poorly formatted group is properly handled - groupID := "invalid" - _, err := InstallPluginsFromGroup("cluster", groupID) + groupID = "invalid" + _, err = InstallPluginsFromGroup("cluster", groupID) assertions.NotNil(err) assertions.Contains(err.Error(), "could not find group") @@ -374,18 +353,295 @@ func Test_InstallPluginsFromGroupErrors(t *testing.T) { _, err = InstallPluginsFromGroup("cluster", groupID) assertions.NotNil(err) assertions.Contains(err.Error(), "could not find group") +} - groupID = testGroupName - fullGroupID, err := InstallPluginsFromGroup("cluster", groupID) - assertions.NotNil(err) - assertions.Equal(groupID+":v2.1.0", fullGroupID) - assertions.Contains(err.Error(), fmt.Sprintf("plugin 'cluster' is not part of the group '%s'", fullGroupID)) +func Test_DiscoverPluginGroups(t *testing.T) { + assertions := assert.New(t) + + defer setupLocalDistroForTesting()() + execCommand = fakeInfoExecCommand + defer func() { execCommand = exec.Command }() - groupID = testGroupName + ":" + testGroupVersion - fullGroupID, err = InstallPluginsFromGroup("cluster", groupID) + // A local discovery currently does not support groups, but we can + // at least do negative testing + _, err := DiscoverPluginGroups(nil) assertions.NotNil(err) - assertions.Equal(groupID, fullGroupID) - assertions.Contains(err.Error(), fmt.Sprintf("plugin 'cluster' from group '%s' is not mandatory to install", fullGroupID)) + assertions.Contains(err.Error(), "unable to create group discovery: unknown group discovery source") +} + +func Test_AvailablePlugins(t *testing.T) { + assertions := assert.New(t) + + defer setupLocalDistroForTesting()() + + expectedDiscoveredPlugins := append(expectedDiscoveredContextPlugins, expectedDiscoveredStandalonePlugins...) + discoveredPlugins, err := AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + for i := 0; i < len(expectedDiscoveredPlugins); i++ { + pd := findDiscoveredPlugin(discoveredPlugins, expectedDiscoveredPlugins[i].Name, expectedDiscoveredPlugins[i].Target) + assertions.NotNil(pd) + assertions.Equal(expectedDiscoveredPlugins[i].Name, pd.Name) + assertions.Equal(expectedDiscoveredPlugins[i].RecommendedVersion, pd.RecommendedVersion) + assertions.Equal(expectedDiscoveredPlugins[i].Target, pd.Target) + assertions.Equal(expectedDiscoveredPlugins[i].Scope, pd.Scope) + assertions.Equal(common.PluginStatusNotInstalled, pd.Status) + } + + // Install login, myplugin plugins + mockInstallPlugin(assertions, "login", "v0.2.0", configtypes.TargetUnknown) + mockInstallPlugin(assertions, "myplugin", "v0.2.0", configtypes.TargetTMC) + + expectedInstallationStatusOfPlugins := []discovery.Discovered{ + { + Name: "myplugin", + Target: configtypes.TargetTMC, + InstalledVersion: "v0.2.0", + Status: common.PluginStatusInstalled, + }, + { + Name: "myplugin", + Target: configtypes.TargetK8s, + InstalledVersion: "", + Status: common.PluginStatusNotInstalled, + }, + { + Name: "login", + Target: configtypes.TargetUnknown, + InstalledVersion: "v0.2.0", + Status: common.PluginStatusInstalled, + }, + } + + // Get available plugin after install and verify installation status + discoveredPlugins, err = AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + for _, eisp := range expectedInstallationStatusOfPlugins { + p := findDiscoveredPlugin(discoveredPlugins, eisp.Name, eisp.Target) + assertions.NotNil(p) + assertions.Equal(eisp.Status, p.Status) + assertions.Equal(eisp.InstalledVersion, p.InstalledVersion) + } + + // Install management-cluster, feature plugins + mockInstallPlugin(assertions, "management-cluster", "v1.6.0", configtypes.TargetK8s) + mockInstallPlugin(assertions, "feature", "v0.2.0", configtypes.TargetK8s) + + expectedInstallationStatusOfPlugins = []discovery.Discovered{ + { + Name: "management-cluster", + Target: configtypes.TargetK8s, + InstalledVersion: "v1.6.0", + Status: common.PluginStatusInstalled, + }, + { + Name: "feature", + Target: configtypes.TargetK8s, + InstalledVersion: "v0.2.0", + Status: common.PluginStatusInstalled, + }, + { + Name: "management-cluster", + Target: configtypes.TargetTMC, + InstalledVersion: "", + Status: common.PluginStatusNotInstalled, + }, + { + Name: "login", + Target: configtypes.TargetUnknown, + InstalledVersion: "v0.2.0", + Status: common.PluginStatusInstalled, + }, + } + + // Get available plugin after install and verify installation status + discoveredPlugins, err = AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + for _, eisp := range expectedInstallationStatusOfPlugins { + p := findDiscoveredPlugin(discoveredPlugins, eisp.Name, eisp.Target) + assertions.NotNil(p) + assertions.Equal(eisp.Status, p.Status, eisp.Name) + assertions.Equal(eisp.InstalledVersion, p.InstalledVersion, eisp.Name) + } +} + +func Test_AvailablePlugins_With_K8s_None_Target_Plugin_Name_Conflict_With_One_Installed_Getting_Discovered(t *testing.T) { + assertions := assert.New(t) + + defer setupLocalDistroForTesting()() + + expectedDiscoveredPlugins := append(expectedDiscoveredContextPlugins, expectedDiscoveredStandalonePlugins...) + discoveredPlugins, err := AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + // Install login, cluster plugins + mockInstallPlugin(assertions, "login", "v0.2.0", configtypes.TargetUnknown) + + // Considering `login` plugin with `` target is already installed and + // getting discovered through some discoveries source + // + // if the same `login` plugin is now getting discovered with `k8s` target + // verify the result of AvailablePlugins + + discoverySource := configtypes.PluginDiscovery{ + Local: &configtypes.LocalDiscovery{ + Name: "fake-with-k8s-target", + Path: "standalone-k8s-target", + }, + } + err = configlib.SetCLIDiscoverySource(discoverySource) + assertions.Nil(err) + + discoveredPlugins, err = AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + expectedInstallationStatusOfPlugins := []discovery.Discovered{ + { + Name: "login", + Target: configtypes.TargetK8s, + InstalledVersion: "v0.2.0", + Status: common.PluginStatusInstalled, + }, + } + + for i := range discoveredPlugins { + log.Infof("Discovered: %v, %v, %v, %v", discoveredPlugins[i].Name, discoveredPlugins[i].Target, discoveredPlugins[i].Status, discoveredPlugins[i].InstalledVersion) + } + + for _, eisp := range expectedInstallationStatusOfPlugins { + p := findDiscoveredPlugin(discoveredPlugins, eisp.Name, eisp.Target) + assertions.NotNil(p) + assertions.Equal(eisp.Status, p.Status, eisp.Name) + assertions.Equal(eisp.InstalledVersion, p.InstalledVersion, eisp.Name) + } +} + +func Test_AvailablePlugins_With_K8s_None_Target_Plugin_Name_Conflict_With_Plugin_Installed_But_Not_Getting_Discovered(t *testing.T) { + assertions := assert.New(t) + + defer setupLocalDistroForTesting()() + + expectedDiscoveredPlugins := append(expectedDiscoveredContextPlugins, expectedDiscoveredStandalonePlugins...) + discoveredPlugins, err := AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + // Install login, cluster plugins + mockInstallPlugin(assertions, "login", "v0.2.0", configtypes.TargetUnknown) + + // Considering `login` plugin with `` target is already installed and + // getting discovered through some discoveries source + // + // if the same `login` plugin is now getting discovered with `k8s` target + // verify the result of AvailablePlugins + + // Replace old discovery source to point to new standalone discovery where the same plugin is getting + // discovered through k8s target + discoverySource := configtypes.PluginDiscovery{ + Local: &configtypes.LocalDiscovery{ + Name: "fake", + Path: "standalone-k8s-target", + }, + } + err = configlib.SetCLIDiscoverySource(discoverySource) + assertions.Nil(err) + + discoveredPlugins, err = AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discoveredPlugins)) + + expectedInstallationStatusOfPlugins := []discovery.Discovered{ + { + Name: "login", + Target: configtypes.TargetK8s, + InstalledVersion: "v0.2.0", + Status: common.PluginStatusInstalled, + }, + } + + for _, eisp := range expectedInstallationStatusOfPlugins { + p := findDiscoveredPlugin(discoveredPlugins, eisp.Name, eisp.Target) + assertions.NotNil(p) + assertions.Equal(eisp.Status, p.Status, eisp.Name) + assertions.Equal(eisp.InstalledVersion, p.InstalledVersion, eisp.Name) + } +} + +func Test_AvailablePlugins_From_LocalSource(t *testing.T) { + assertions := assert.New(t) + + defer setupLocalDistroForTesting()() + + currentDirAbsPath, _ := filepath.Abs(".") + discoveredPlugins, err := AvailablePluginsFromLocalSource(filepath.Join(currentDirAbsPath, "test", "local")) + assertions.Nil(err) + + expectedInstallationStatusOfPlugins := []discovery.Discovered{ + { + Name: "cluster", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetK8s, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "management-cluster", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetK8s, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "management-cluster", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetTMC, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "login", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetK8s, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "feature", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetK8s, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "cluster", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetTMC, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "myplugin", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetK8s, + Status: common.PluginStatusNotInstalled, + }, + { + Name: "myplugin", + Scope: common.PluginScopeStandalone, + Target: configtypes.TargetTMC, + Status: common.PluginStatusNotInstalled, + }, + } + + assertions.Equal(len(expectedInstallationStatusOfPlugins), len(discoveredPlugins)) + + for _, eisp := range expectedInstallationStatusOfPlugins { + p := findDiscoveredPlugin(discoveredPlugins, eisp.Name, eisp.Target) + assertions.NotNil(p, "plugin %q with target %q not found", eisp.Name, eisp.Target) + assertions.Equal(eisp.Status, p.Status, "status mismatch for plugin %q with target %q", eisp.Name, eisp.Target) + assertions.Equal(eisp.Scope, p.Scope, "scope mismatch for plugin %q with target %q", eisp.Name, eisp.Target) + } } func Test_InstallPlugin_InstalledPlugins_From_LocalSource(t *testing.T) { @@ -515,44 +771,104 @@ func Test_DeletePlugin(t *testing.T) { assertions.Contains(err.Error(), fmt.Sprintf(missingTargetStr, "myplugin")) } -func Test_SyncPlugins(t *testing.T) { +func Test_ValidatePlugin(t *testing.T) { + assertions := assert.New(t) + + pd := cli.PluginInfo{} + err := ValidatePlugin(&pd) + assertions.Contains(err.Error(), "plugin name cannot be empty") + + pd.Name = "fake-plugin" + err = ValidatePlugin(&pd) + assertions.NotContains(err.Error(), "plugin name cannot be empty") + assertions.Contains(err.Error(), "plugin \"fake-plugin\" version cannot be empty") + assertions.Contains(err.Error(), "plugin \"fake-plugin\" group cannot be empty") +} + +func Test_SyncPlugins_All_Plugins_No_Central_Repo(t *testing.T) { assertions := assert.New(t) - defer setupPluginSourceForTesting()() + defer setupLocalDistroForTesting()() execCommand = fakeInfoExecCommand defer func() { execCommand = exec.Command }() - // Get the server plugins (they are not installed yet) - serverPlugins, err := DiscoverServerPlugins() - assertions.NotNil(err) - // There is an error for the kubernetes discovery since we don't have a cluster - // but other server plugins will be found, so we use those - assertions.Contains(err.Error(), `Failed to load Kubeconfig file from "config"`) - assertions.Equal(len(expectedDiscoveredContextPlugins), len(serverPlugins)) + // Turn off central repo feature + featureArray := strings.Split(constants.FeatureDisableCentralRepositoryForTesting, ".") + err := configlib.SetFeature(featureArray[1], featureArray[2], "true") + assertions.Nil(err) + + expectedDiscoveredPlugins := append(expectedDiscoveredContextPlugins, expectedDiscoveredStandalonePlugins...) + + // Get all available plugins(standalone+context-aware) and verify the status is `not installed` + discovered, err := AvailablePlugins() + assertions.Nil(err) + assertions.Equal(len(expectedDiscoveredPlugins), len(discovered)) - for _, edp := range expectedDiscoveredContextPlugins { - p := findDiscoveredPlugin(serverPlugins, edp.Name, edp.Target) + for _, edp := range expectedDiscoveredPlugins { + p := findDiscoveredPlugin(discovered, edp.Name, edp.Target) assertions.NotNil(p) assertions.Equal(common.PluginStatusNotInstalled, p.Status) } // Sync all available plugins err = SyncPlugins() - assertions.NotNil(err) - // There is an error for the kubernetes discovery since we don't have a cluster - // but other server plugins will be found, so we use those - assertions.Contains(err.Error(), `Failed to load Kubeconfig file from "config"`) + assertions.Nil(err) - installedServerPlugins, err := pluginsupplier.GetInstalledServerPlugins() + // Get all available plugins(standalone+context-aware) and verify the status is updated to `installed` + discovered, err = AvailablePlugins() assertions.Nil(err) - assertions.Equal(len(installedServerPlugins), len(serverPlugins)) + assertions.Equal(len(expectedDiscoveredPlugins), len(discovered)) - for _, isp := range installedServerPlugins { - p := findDiscoveredPlugin(serverPlugins, isp.Name, isp.Target) + for _, edp := range expectedDiscoveredPlugins { + p := findDiscoveredPlugin(discovered, edp.Name, edp.Target) assertions.NotNil(p) + assertions.Equal(common.PluginStatusInstalled, p.Status) + assertions.Equal(edp.RecommendedVersion, p.InstalledVersion) } } +func Test_getInstalledButNotDiscoveredStandalonePlugins(t *testing.T) { + assertions := assert.New(t) + + availablePlugins := []discovery.Discovered{{Name: "fake1", DiscoveryType: "oci", RecommendedVersion: "v1.0.0", Status: common.PluginStatusInstalled}} + installedPlugin := []cli.PluginInfo{{Name: "fake2", Version: "v2.0.0", Discovery: "local"}} + + // If installed plugin is not part of available(discovered) plugins + plugins := getInstalledButNotDiscoveredStandalonePlugins(availablePlugins, installedPlugin) + assertions.Equal(len(plugins), 1) + assertions.Equal("fake2", plugins[0].Name) + assertions.Equal("v2.0.0", plugins[0].RecommendedVersion) + assertions.Equal(common.PluginStatusInstalled, plugins[0].Status) + + // If installed plugin is part of available(discovered) plugins and provided available plugin is already marked as `installed` + installedPlugin = append(installedPlugin, cli.PluginInfo{Name: "fake1", Version: "v1.0.0", Discovery: "local"}) + plugins = getInstalledButNotDiscoveredStandalonePlugins(availablePlugins, installedPlugin) + assertions.Equal(len(plugins), 1) + assertions.Equal("fake2", plugins[0].Name) + assertions.Equal("v2.0.0", plugins[0].RecommendedVersion) + assertions.Equal(common.PluginStatusInstalled, plugins[0].Status) + + // If installed plugin is part of available(discovered) plugins and provided available plugin is already marked as `not installed` + // then test the availablePlugin status gets updated to `installed` + availablePlugins[0].Status = common.PluginStatusNotInstalled + plugins = getInstalledButNotDiscoveredStandalonePlugins(availablePlugins, installedPlugin) + assertions.Equal(len(plugins), 1) + assertions.Equal("fake2", plugins[0].Name) + assertions.Equal("v2.0.0", plugins[0].RecommendedVersion) + assertions.Equal(common.PluginStatusInstalled, plugins[0].Status) + assertions.Equal(common.PluginStatusInstalled, availablePlugins[0].Status) + + // If installed plugin is part of available(discovered) plugins and versions installed is different than discovered version + availablePlugins[0].Status = common.PluginStatusNotInstalled + availablePlugins[0].RecommendedVersion = "v4.0.0" + plugins = getInstalledButNotDiscoveredStandalonePlugins(availablePlugins, installedPlugin) + assertions.Equal(len(plugins), 1) + assertions.Equal("fake2", plugins[0].Name) + assertions.Equal("v2.0.0", plugins[0].RecommendedVersion) + assertions.Equal(common.PluginStatusInstalled, plugins[0].Status) + assertions.Equal(common.PluginStatusInstalled, availablePlugins[0].Status) +} + func Test_setAvailablePluginsStatus(t *testing.T) { assertions := assert.New(t) @@ -837,7 +1153,142 @@ func TestVerifyPluginPostDownload(t *testing.T) { } } -func TestHelperProcess(t *testing.T) { +func Test_removeDuplicates(t *testing.T) { + assertions := assert.New(t) + + tcs := []struct { + name string + inputPlugins []discovery.Discovered + expectedResult []discovery.Discovered + }{ + { + name: "when plugin name-target conflict happens with '' and 'k8s' targeted plugins ", + inputPlugins: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetUnknown, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + { + Name: "bar", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + }, + expectedResult: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + { + Name: "bar", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + }, + }, + { + name: "when same plugin exists for '', 'k8s' and 'tmc' target as standalone plugin", + inputPlugins: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetUnknown, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetTMC, + Scope: common.PluginScopeStandalone, + }, + }, + expectedResult: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetTMC, + Scope: common.PluginScopeStandalone, + }, + }, + }, + { + name: "when foo standalone plugin is available with `k8s` and `` target and also available as context-scoped plugin with `k8s` target", + inputPlugins: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetUnknown, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeContext, + }, + }, + expectedResult: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetK8s, + Scope: common.PluginScopeContext, + }, + }, + }, + { + name: "when tmc targeted plugin exists as standalone as well as context-scope", + inputPlugins: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetTMC, + Scope: common.PluginScopeStandalone, + }, + { + Name: "foo", + Target: configtypes.TargetTMC, + Scope: common.PluginScopeContext, + }, + }, + expectedResult: []discovery.Discovered{ + { + Name: "foo", + Target: configtypes.TargetTMC, + Scope: common.PluginScopeContext, + }, + }, + }, + } + + for _, tc := range tcs { + t.Run(tc.name, func(t *testing.T) { + result := combineDuplicatePlugins(tc.inputPlugins) + assertions.Equal(len(result), len(tc.expectedResult)) + for i := range tc.expectedResult { + p := findDiscoveredPlugin(result, tc.expectedResult[i].Name, tc.expectedResult[i].Target) + assertions.Equal(p.Scope, tc.expectedResult[i].Scope) + } + }) + } +} + +func TestHelperProcess(_ *testing.T) { if os.Getenv("GO_WANT_HELPER_PROCESS") != "1" { return } @@ -902,8 +1353,6 @@ func TestGetAdditionalTestPluginDiscoveries(t *testing.T) { assertions.Equal(expectedDiscoveries[1], discoveries[1].OCI.Image) assertions.Equal(expectedDiscoveries[2], discoveries[2].OCI.Image) assertions.Equal(expectedDiscoveries[3], discoveries[3].OCI.Image) - - os.Unsetenv(constants.ConfigVariableAdditionalDiscoveryForTesting) } func TestGetPluginDiscoveries(t *testing.T) { @@ -958,7 +1407,16 @@ func TestGetPluginDiscoveries(t *testing.T) { assertions.Equal(expectedTestDiscoveries[2], discoveries[4].OCI.Image) assertions.Equal(expectedTestDiscoveries[3], discoveries[5].OCI.Image) - os.Unsetenv(constants.ConfigVariableAdditionalDiscoveryForTesting) + // Test with the Central Repo feature disabled + featureArray := strings.Split(constants.FeatureDisableCentralRepositoryForTesting, ".") + err = configlib.SetFeature(featureArray[1], featureArray[2], "true") + assertions.Nil(err) + + discoveries, err = getPluginDiscoveries() + assertions.Nil(err) + assertions.Equal(2, len(discoveries)) + assertions.Equal("default-local", discoveries[0].Local.Name) + assertions.Equal("fake", discoveries[1].Local.Name) } func TestMergeDuplicatePlugins(t *testing.T) { diff --git a/pkg/registry/client.go b/pkg/registry/client.go index ba211c1ef..dbc251fa0 100644 --- a/pkg/registry/client.go +++ b/pkg/registry/client.go @@ -104,7 +104,7 @@ func getFilesFromLayer(imgLayer regv1.Layer) (map[string][]byte, error) { } return files, err } - if hdr.Typeflag == tar.TypeReg || hdr.Typeflag == tar.TypeRegA { + if hdr.Typeflag == tar.TypeReg { buf, err := io.ReadAll(tarReader) if err != nil { return files, err diff --git a/pkg/telemetry/client_test.go b/pkg/telemetry/client_test.go index 46ccdad6d..fc2d782bc 100644 --- a/pkg/telemetry/client_test.go +++ b/pkg/telemetry/client_test.go @@ -45,7 +45,7 @@ func (mc *mockMetricsDB) CreateSchema() error { return mc.createSchemaReturnError } -func (mc *mockMetricsDB) SaveOperationMetric(payload *OperationMetricsPayload) error { +func (mc *mockMetricsDB) SaveOperationMetric(_ *OperationMetricsPayload) error { mc.saveOperationMetricCalled = true return mc.saveOperationMetricReturnError } diff --git a/pkg/telemetry/sqlite_metrics_db.go b/pkg/telemetry/sqlite_metrics_db.go index 849e584ee..865320cb0 100644 --- a/pkg/telemetry/sqlite_metrics_db.go +++ b/pkg/telemetry/sqlite_metrics_db.go @@ -148,6 +148,7 @@ func (b *sqliteMetricsDB) GetRowCount() (int, error) { defer db.Close() dbQuery := cliOperationMetricRowClause + //nolint:rowserrcheck rows, err := db.Query(dbQuery) if err != nil { return 0, errors.Wrapf(err, "failed to execute the DB query : %v", dbQuery) @@ -161,6 +162,7 @@ func (b *sqliteMetricsDB) GetRowCount() (int, error) { } func isDBRowCountThresholdReached(db *sql.DB) (bool, error) { dbQuery := cliOperationMetricRowClause + //nolint:rowserrcheck rows, err := db.Query(dbQuery) if err != nil { return false, errors.Wrapf(err, "failed to execute the DB query : %v", dbQuery) diff --git a/pkg/telemetry/sqlite_metrics_db_test.go b/pkg/telemetry/sqlite_metrics_db_test.go index 73dd9c30f..0748470bc 100644 --- a/pkg/telemetry/sqlite_metrics_db_test.go +++ b/pkg/telemetry/sqlite_metrics_db_test.go @@ -100,6 +100,7 @@ func getOperationMetrics(metricsDB *sqliteMetricsDB) ([]*cliOperationsRow, error defer db.Close() dbQuery := selectAllFromCLIOperationMetrics + //nolint:rowserrcheck rows, err := db.Query(dbQuery) if err != nil { return nil, errors.Wrapf(err, "failed to execute the DB query : %v", dbQuery)