diff --git a/Makefile b/Makefile index eb1779c0..70d98330 100644 --- a/Makefile +++ b/Makefile @@ -80,16 +80,6 @@ crds.clean: generate: crds.clean -# Ensure a PR is ready for review. -reviewable: generate lint - @go mod tidy - -# Ensure branch is clean. -check-diff: reviewable - @$(INFO) checking that branch is clean - @test -z "$$(git status --porcelain)" || $(FAIL) - @$(OK) branch is clean - # integration tests e2e.run: test-integration @@ -127,7 +117,7 @@ export TEST_ASSET_KUBE_APISERVER TEST_ASSET_ETCD test.init: $(KUBEBUILDER) -.PHONY: cobertura reviewable submodules fallthrough test-integration run manifests crds.clean +.PHONY: cobertura submodules fallthrough test-integration run manifests crds.clean # ==================================================================================== # Special Targets @@ -135,7 +125,6 @@ test.init: $(KUBEBUILDER) define CROSSPLANE_MAKE_HELP Crossplane Targets: cobertura Generate a coverage report for cobertura applying exclusions on generated files. - reviewable Ensure a PR is ready for review. submodules Update the submodules, such as the common build scripts. run Run crossplane locally, out-of-cluster. Useful for development. diff --git a/build b/build index 8e7a7c53..70b7766c 160000 --- a/build +++ b/build @@ -1 +1 @@ -Subproject commit 8e7a7c5309856ca3316dee2c2d179523ad035738 +Subproject commit 70b7766c9cc2e1f4fc36d5b8a2b3ffd4661a6df5 diff --git a/cmd/provider/main.go b/cmd/provider/main.go index f18ab35a..bbbd95f0 100644 --- a/cmd/provider/main.go +++ b/cmd/provider/main.go @@ -19,25 +19,30 @@ package main import ( "os" "path/filepath" + "time" "gopkg.in/alecthomas/kingpin.v2" + "k8s.io/client-go/tools/leaderelection/resourcelock" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/log/zap" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/provider-azure/apis" - "github.com/crossplane/provider-azure/pkg/controller" + azure "github.com/crossplane/provider-azure/pkg/controller" ) func main() { var ( app = kingpin.New(filepath.Base(os.Args[0]), "Azure support for Crossplane.").DefaultEnvars() debug = app.Flag("debug", "Run with debug logging.").Short('d').Bool() - syncInterval = app.Flag("sync", "Sync interval controls how often all resources will be double checked for drift.").Short('s').Default("1h").Duration() - pollInterval = app.Flag("poll", "Poll interval controls how often an individual resource should be checked for drift.").Default("1m").Duration() leaderElection = app.Flag("leader-election", "Use leader election for the conroller manager.").Short('l').Default("false").OverrideDefaultFromEnvar("LEADER_ELECTION").Bool() + + syncInterval = app.Flag("sync", "How often all resources will be double-checked for drift from the desired state.").Short('s').Default("1h").Duration() + pollInterval = app.Flag("poll", "How often individual resources will be checked for drift from the desired state").Default("1m").Duration() + maxReconcileRate = app.Flag("max-reconcile-rate", "The global maximum rate per second at which resources may checked for drift from the desired state.").Default("10").Int() ) kingpin.MustParse(app.Parse(os.Args[1:])) @@ -50,20 +55,35 @@ func main() { ctrl.SetLogger(zl) } - log.Debug("Starting", "sync-period", syncInterval.String()) - cfg, err := ctrl.GetConfig() kingpin.FatalIfError(err, "Cannot get API server rest config") mgr, err := ctrl.NewManager(cfg, ctrl.Options{ - LeaderElection: *leaderElection, - LeaderElectionID: "crossplane-leader-election-provider-azure", - SyncPeriod: syncInterval, + SyncPeriod: syncInterval, + + // controller-runtime uses both ConfigMaps and Leases for leader + // election by default. Leases expire after 15 seconds, with a + // 10 second renewal deadline. We've observed leader loss due to + // renewal deadlines being exceeded when under high load - i.e. + // hundreds of reconciles per second and ~200rps to the API + // server. Switching to Leases only and longer leases appears to + // alleviate this. + LeaderElection: *leaderElection, + LeaderElectionID: "crossplane-leader-election-provider-azure", + LeaderElectionResourceLock: resourcelock.LeasesResourceLock, + LeaseDuration: func() *time.Duration { d := 60 * time.Second; return &d }(), + RenewDeadline: func() *time.Duration { d := 50 * time.Second; return &d }(), }) kingpin.FatalIfError(err, "Cannot create controller manager") + o := controller.Options{ + Logger: log, + MaxConcurrentReconciles: *maxReconcileRate, + PollInterval: *pollInterval, + GlobalRateLimiter: ratelimiter.NewGlobal(*maxReconcileRate), + } + kingpin.FatalIfError(apis.AddToScheme(mgr.GetScheme()), "Cannot add Azure APIs to scheme") - kingpin.FatalIfError(controller.Setup(mgr, log, ratelimiter.NewDefaultProviderRateLimiter(ratelimiter.DefaultProviderRPS), *pollInterval), "Cannot setup Azure controllers") + kingpin.FatalIfError(azure.Setup(mgr, o), "Cannot setup Azure controllers") kingpin.FatalIfError(mgr.Start(ctrl.SetupSignalHandler()), "Cannot start controller manager") - } diff --git a/go.mod b/go.mod index 94a13392..89b2da7a 100644 --- a/go.mod +++ b/go.mod @@ -6,29 +6,25 @@ require ( github.com/Azure/azure-pipeline-go v0.2.2 // indirect github.com/Azure/azure-sdk-for-go v42.3.0+incompatible github.com/Azure/azure-storage-blob-go v0.7.0 - github.com/Azure/go-autorest/autorest v0.11.1 + github.com/Azure/go-autorest/autorest v0.11.12 github.com/Azure/go-autorest/autorest/adal v0.9.5 github.com/Azure/go-autorest/autorest/azure/auth v0.4.0 github.com/Azure/go-autorest/autorest/date v0.3.0 github.com/Azure/go-autorest/autorest/to v0.3.0 github.com/Azure/go-autorest/autorest/validation v0.2.0 // indirect - github.com/crossplane/crossplane-runtime v0.14.0 + github.com/crossplane/crossplane-runtime v0.15.1-0.20211202230900-d43d510ec578 github.com/crossplane/crossplane-tools v0.0.0-20210320162312-1baca298c527 - github.com/google/go-cmp v0.5.2 + github.com/google/go-cmp v0.5.6 github.com/google/uuid v1.1.2 - github.com/kr/text v0.2.0 // indirect github.com/mattn/go-ieproxy v0.0.0-20190805055040-f9202b1cfdeb // indirect github.com/mitchellh/copystructure v1.2.0 - github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e // indirect - github.com/onsi/gomega v1.10.2 + github.com/onsi/gomega v1.14.0 github.com/pkg/errors v0.9.1 github.com/satori/go.uuid v1.2.0 // indirect - golang.org/x/tools v0.0.0-20200916195026-c9a70fc28ce3 // indirect gopkg.in/alecthomas/kingpin.v2 v2.2.6 - gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f // indirect - k8s.io/api v0.20.1 - k8s.io/apimachinery v0.20.2 - k8s.io/client-go v0.20.1 - sigs.k8s.io/controller-runtime v0.8.0 - sigs.k8s.io/controller-tools v0.4.0 + k8s.io/api v0.21.3 + k8s.io/apimachinery v0.21.3 + k8s.io/client-go v0.21.3 + sigs.k8s.io/controller-runtime v0.9.6 + sigs.k8s.io/controller-tools v0.6.2 ) diff --git a/go.sum b/go.sum index e3221f53..4fdf3e5f 100644 --- a/go.sum +++ b/go.sum @@ -9,18 +9,33 @@ cloud.google.com/go v0.50.0/go.mod h1:r9sluTvynVuxRIOHXQEHMFffphuXHOMZMycpNR5e6T cloud.google.com/go v0.52.0/go.mod h1:pXajvRH/6o3+F9jDHZWQ5PbGhn+o8w9qiu/CffaVdO4= cloud.google.com/go v0.53.0/go.mod h1:fp/UouUEsRkN6ryDKNW/Upv/JBKnv6WDthjR6+vze6M= cloud.google.com/go v0.54.0/go.mod h1:1rq2OEkV3YMf6n/9ZvGWI3GWw0VoqH/1x2nd8Is/bPc= +cloud.google.com/go v0.56.0/go.mod h1:jr7tqZxxKOVYizybht9+26Z/gUq7tiRzu+ACVAMbKVk= +cloud.google.com/go v0.57.0/go.mod h1:oXiQ6Rzq3RAkkY7N6t3TcE6jE+CIBBbA36lwQ1JyzZs= +cloud.google.com/go v0.62.0/go.mod h1:jmCYTdRCQuc1PHIIJ/maLInMho30T/Y0M4hTdTShOYc= +cloud.google.com/go v0.65.0/go.mod h1:O5N8zS7uWy9vkA9vayVHs65eM1ubvY4h553ofrNHObY= +cloud.google.com/go v0.72.0/go.mod h1:M+5Vjvlc2wnp6tjzE102Dw08nGShTscUx2nZMufOKPI= +cloud.google.com/go v0.74.0/go.mod h1:VV1xSbzvo+9QJOxLDaJfTjx5e+MePCpCWwvftOeQmWk= +cloud.google.com/go v0.78.0/go.mod h1:QjdrLG0uq+YwhjoVOLsS1t7TW8fs36kLs4XO5R5ECHg= +cloud.google.com/go v0.79.0/go.mod h1:3bzgcEeQlzbuEAYu4mrWhKqWjmpprinYgKJLgKHnbb8= +cloud.google.com/go v0.81.0/go.mod h1:mk/AM35KwGk/Nm2YSeZbxXdrNK3KZOYHmLkOqC2V6E0= cloud.google.com/go/bigquery v1.0.1/go.mod h1:i/xbL2UlR5RvWAURpBYZTtm/cXjCha9lbfbpx4poX+o= cloud.google.com/go/bigquery v1.3.0/go.mod h1:PjpwJnslEMmckchkHFfq+HTD2DmtT67aNFKH1/VBDHE= cloud.google.com/go/bigquery v1.4.0/go.mod h1:S8dzgnTigyfTmLBfrtrhyYhwRxG72rYxvftPBK2Dvzc= +cloud.google.com/go/bigquery v1.5.0/go.mod h1:snEHRnqQbz117VIFhE8bmtwIDY80NLUZUMb4Nv6dBIg= +cloud.google.com/go/bigquery v1.7.0/go.mod h1://okPTzCYNXSlb24MZs83e2Do+h+VXtc4gLoIoXIAPc= +cloud.google.com/go/bigquery v1.8.0/go.mod h1:J5hqkt3O0uAFnINi6JXValWIb1v0goeZM77hZzJN/fQ= cloud.google.com/go/datastore v1.0.0/go.mod h1:LXYbyblFSglQ5pkeyhO+Qmw7ukd3C+pD7TKLgZqpHYE= cloud.google.com/go/datastore v1.1.0/go.mod h1:umbIZjpQpHh4hmRpGhH4tLFup+FVzqBi1b3c64qFpCk= cloud.google.com/go/firestore v1.1.0/go.mod h1:ulACoGHTpvq5r8rxGJ4ddJZBZqakUQqClKRT5SZwBmk= cloud.google.com/go/pubsub v1.0.1/go.mod h1:R0Gpsv3s54REJCy4fxDixWD93lHJMoZTyQ2kNxGRt3I= cloud.google.com/go/pubsub v1.1.0/go.mod h1:EwwdRX2sKPjnvnqCa270oGRyludottCI76h+R3AArQw= cloud.google.com/go/pubsub v1.2.0/go.mod h1:jhfEVHT8odbXTkndysNHCcx0awwzvfOlguIAii9o8iA= +cloud.google.com/go/pubsub v1.3.1/go.mod h1:i+ucay31+CNRpDW4Lu78I4xXG+O1r/MAHgjpRVR+TSU= cloud.google.com/go/storage v1.0.0/go.mod h1:IhtSnM/ZTZV8YYJWCY8RULGVqBDmpoyjwiyrjsg+URw= cloud.google.com/go/storage v1.5.0/go.mod h1:tpKbwo567HUNpVclU5sGELwQWBDZ8gh0ZeosJ0Rtdos= cloud.google.com/go/storage v1.6.0/go.mod h1:N7U0C8pVQ/+NIKOBQyamJIeKQKkZ+mxpohlUTyfDhBk= +cloud.google.com/go/storage v1.8.0/go.mod h1:Wv1Oy7z6Yz3DshWRJFhqM/UCfaWIRTdp0RXyy7KQOVs= +cloud.google.com/go/storage v1.10.0/go.mod h1:FLPqc6j+Ki4BU591ie1oL6qBQGu2Bl/tZ9ullr3+Kg0= dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU= github.com/Azure/azure-pipeline-go v0.2.1/go.mod h1:UGSo8XybXnIGZ3epmeBw7Jdz+HiUVpqIlpz/HKHylF4= github.com/Azure/azure-pipeline-go v0.2.2 h1:6oiIS9yaG6XCCzhgAgKFfIWyo4LLCiDhZot6ltoThhY= @@ -34,12 +49,11 @@ github.com/Azure/go-autorest v14.2.0+incompatible h1:V5VMDjClD3GiElqLWO7mz2MxNAK github.com/Azure/go-autorest v14.2.0+incompatible/go.mod h1:r+4oMnoxhatjLLJ6zxSWATqVooLgysK6ZNox3g/xq24= github.com/Azure/go-autorest/autorest v0.9.0/go.mod h1:xyHB1BMZT0cuDHU7I0+g046+BFDTQ8rEZB0s4Yfa6bI= github.com/Azure/go-autorest/autorest v0.9.2/go.mod h1:xyHB1BMZT0cuDHU7I0+g046+BFDTQ8rEZB0s4Yfa6bI= -github.com/Azure/go-autorest/autorest v0.11.1 h1:eVvIXUKiTgv++6YnWb42DUA1YL7qDugnKP0HljexdnQ= -github.com/Azure/go-autorest/autorest v0.11.1/go.mod h1:JFgpikqFJ/MleTTxwepExTKnFUKKszPS8UavbQYUMuw= +github.com/Azure/go-autorest/autorest v0.11.12 h1:gI8ytXbxMfI+IVbI9mP2JGCTXIuhHLgRlvQ9X4PsnHE= +github.com/Azure/go-autorest/autorest v0.11.12/go.mod h1:eipySxLmqSyC5s5k1CLupqet0PSENBEDP93LQ9a8QYw= github.com/Azure/go-autorest/autorest/adal v0.5.0/go.mod h1:8Z9fGy2MpX0PvDjB1pEgQTmVqjGhiHBW7RJJEciWzS0= github.com/Azure/go-autorest/autorest/adal v0.6.0/go.mod h1:Z6vX6WXXuyieHAXwMj0S6HY6e6wcHn37qQMBQlvY3lc= github.com/Azure/go-autorest/autorest/adal v0.7.0/go.mod h1:Z6vX6WXXuyieHAXwMj0S6HY6e6wcHn37qQMBQlvY3lc= -github.com/Azure/go-autorest/autorest/adal v0.9.0/go.mod h1:/c022QCutn2P7uY+/oQWWNcK9YU+MH96NgK+jErpbcg= github.com/Azure/go-autorest/autorest/adal v0.9.5 h1:Y3bBUV4rTuxenJJs41HU3qmqsb+auo+a3Lz+PlJPpL0= github.com/Azure/go-autorest/autorest/adal v0.9.5/go.mod h1:B7KF7jKIeC9Mct5spmyCB/A8CG/sEz1vwIRGv/bbw7A= github.com/Azure/go-autorest/autorest/azure/auth v0.4.0 h1:18ld/uw9Rr7VkNie7a7RMAcFIWrJdlUL59TWGfcu530= @@ -53,7 +67,6 @@ github.com/Azure/go-autorest/autorest/date v0.3.0/go.mod h1:BI0uouVdmngYNUzGWeSY github.com/Azure/go-autorest/autorest/mocks v0.1.0/go.mod h1:OTyCOPRA2IgIlWxVYxBee2F5Gr4kF2zd2J5cFRaIDN0= github.com/Azure/go-autorest/autorest/mocks v0.2.0/go.mod h1:OTyCOPRA2IgIlWxVYxBee2F5Gr4kF2zd2J5cFRaIDN0= github.com/Azure/go-autorest/autorest/mocks v0.3.0/go.mod h1:a8FDP3DYzQ4RYfVAxAN3SVSiiO77gL2j2ronKKP0syM= -github.com/Azure/go-autorest/autorest/mocks v0.4.0/go.mod h1:LTp+uSrOhSkaKrUy935gNZuuIPPVsHlr9DSOxSayd+k= github.com/Azure/go-autorest/autorest/mocks v0.4.1 h1:K0laFcLE6VLTOwNgSxaGbUcLPuGXlNkbVvq4cW4nIHk= github.com/Azure/go-autorest/autorest/mocks v0.4.1/go.mod h1:LTp+uSrOhSkaKrUy935gNZuuIPPVsHlr9DSOxSayd+k= github.com/Azure/go-autorest/autorest/to v0.3.0 h1:zebkZaadz7+wIQYgC7GXaz3Wb28yKYfVkkBKwc38VF8= @@ -66,17 +79,13 @@ github.com/Azure/go-autorest/logger v0.2.0/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZ github.com/Azure/go-autorest/tracing v0.5.0/go.mod h1:r/s2XiOKccPW3HrqB+W0TQzfbtp2fGCgRFtBroKn4Dk= github.com/Azure/go-autorest/tracing v0.6.0 h1:TYi4+3m5t6K48TGI9AUdb+IzbnSxvnvUMfuitfgcfuo= github.com/Azure/go-autorest/tracing v0.6.0/go.mod h1:+vhtPC754Xsa23ID7GlGsrdKBpUA79WCAKPPZVC2DeU= -github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo= github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ= +github.com/NYTimes/gziphandler v1.1.1/go.mod h1:n/CVRwUEOgIxrgPvAQhUUr9oeUtvrhMomdKFjzJNB0c= github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU= -github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= -github.com/PuerkitoBio/purell v1.1.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= github.com/PuerkitoBio/purell v1.1.1/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0= -github.com/PuerkitoBio/urlesc v0.0.0-20160726150825-5bd2802263f2/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE= -github.com/agnivade/levenshtein v1.0.1/go.mod h1:CURSv5d9Uaml+FovSIICkLbAUZ9S4RqaHDIsdSBg7lM= github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751 h1:JYp7IbQjafoB+tBA3gMyHYHrpOtNuDiK/uB5uXxq5wM= github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc= @@ -84,14 +93,14 @@ github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRF github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0= github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d h1:UQZhZ2O0vMHr2cI+DC1Mbh0TJxzA3RcLoMsFw+aXw7E= github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho= -github.com/andreyvit/diff v0.0.0-20170406064948-c7f18ee00883/go.mod h1:rCTlJbsFo29Kk6CurOXKm700vrz8f0KW0JNfpkRJY/8= +github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= github.com/armon/circbuf v0.0.0-20150827004946-bbbad097214e/go.mod h1:3U/XgcO3hCbHZ8TKRvWD2dDTCfh9M9ya+I9JpbB7O8o= -github.com/armon/consul-api v0.0.0-20180202201655-eb2c6b5be1b6/go.mod h1:grANhF5doyWs3UAsr3K4I6qtAmlQcZDesFNEHPZAzj8= github.com/armon/go-metrics v0.0.0-20180917152333-f0300d1749da/go.mod h1:Q73ZrmVTwzkszR9V5SSuryQ31EELlFMUz1kKyl939pY= github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8= -github.com/asaskevich/govalidator v0.0.0-20180720115003-f9ffefc3facf/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY= github.com/asaskevich/govalidator v0.0.0-20190424111038-f61b66f89f4a/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY= github.com/aws/aws-sdk-go v1.15.78/go.mod h1:E3/ieXAlvM0XWO57iftYVDLLvQ824smPP3ATZkfNZeM= +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 v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q= github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8= github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= @@ -99,7 +108,7 @@ github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6r github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d/go.mod h1:6QX/PXZ00z/TKoufEY6K/a0k6AhaJrQKdFe6OfVXsa4= github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs= github.com/bketelsen/crypt v0.0.3-0.20200106085610-5cbc8cc4026c/go.mod h1:MKsuJmJgSg28kpZDP6UIiPt0e0Oz0kqKNGyRaWEPv84= -github.com/blang/semver v3.5.0+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk= +github.com/bketelsen/crypt v0.0.4/go.mod h1:aI6NrJ0pMGgvZKL1iVgXLnfIFJtfV+bKCoqOes/6LfM= github.com/blang/semver v3.5.1+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk= github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU= github.com/cespare/xxhash v1.1.0 h1:a6HrQnmkObjyL+Gs60czilIUGqrzKutQD6XZog3p+ko= @@ -111,32 +120,30 @@ github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWR github.com/chzyer/readline v0.0.0-20180603132655-2972be24d48e/go.mod h1:nSuG5e5PlCu98SY8svDHJxuZscDgtXS6KTTbou5AhLI= github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU= github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw= +github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc= +github.com/cncf/udpa/go v0.0.0-20200629203442-efcf912fb354/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= +github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk= github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa/go.mod h1:zn76sxSg3SzpJ0PPJaLDCu+Bu0Lg3sKTORVIj19EIF8= -github.com/coreos/bbolt v1.3.1-coreos.6/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk= 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= github.com/coreos/etcd v3.3.13+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= -github.com/coreos/etcd v3.3.15+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE= -github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk= github.com/coreos/go-oidc v2.1.0+incompatible/go.mod h1:CgnwVTmzoESiwO9qyAFEMiHoZ1nMCKZlZ9V6mm3/LKc= github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= github.com/coreos/go-semver v0.3.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk= github.com/coreos/go-systemd v0.0.0-20180511133405-39ca1b05acc7/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= github.com/coreos/go-systemd v0.0.0-20190321100706-95778dfbb74e/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4= +github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= github.com/coreos/pkg v0.0.0-20160727233714-3ac0863d7acf/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= -github.com/coreos/pkg v0.0.0-20180108230652-97fdf19511ea/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA= -github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE= github.com/cpuguy83/go-md2man/v2 v2.0.0/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7DoTY= github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= -github.com/crossplane/crossplane-runtime v0.14.0 h1:alBvQAwg9wJ88wEBnzyzmlN0N/v1W3Jx4OvBX3Fmrkg= -github.com/crossplane/crossplane-runtime v0.14.0/go.mod h1:Bc54/KBvV9ld/tvervcnhcSzk13FYguTqmYt72Mybps= +github.com/creack/pty v1.1.11/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= +github.com/crossplane/crossplane-runtime v0.15.1-0.20211202230900-d43d510ec578 h1:I27eBDYFfIyOPecjlKsqWCqNiozikWSvkt0RAMqsACo= +github.com/crossplane/crossplane-runtime v0.15.1-0.20211202230900-d43d510ec578/go.mod h1:gKix9Gq5kRzVe/4XOpwlFgG7OurzrYayviJxWZakhw0= github.com/crossplane/crossplane-tools v0.0.0-20210320162312-1baca298c527 h1:9M6hMLKqjxtL9d9nwfcaAt59Ey0CPfSXQ3iIdYRUNaE= github.com/crossplane/crossplane-tools v0.0.0-20210320162312-1baca298c527/go.mod h1:C735A9X0x0lR8iGVOOxb49Mt70Ua4EM2b7PGaRPBLd4= github.com/dave/jennifer v1.3.0 h1:p3tl41zjjCZTNBytMwrUuiAnherNUZktlhPTKoF/sEk= github.com/dave/jennifer v1.3.0/go.mod h1:fIb+770HOpJ2fmN9EPPKOqm1vMGhB+TwXKMZhrIygKg= -github.com/davecgh/go-spew v0.0.0-20151105211317-5215b55f46b2/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= 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= @@ -144,99 +151,64 @@ github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZm github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no= github.com/dimchansky/utfbom v1.1.0 h1:FcM3g+nofKgUteL8dm/UpdRXNC9KmADgTpLKsu0TRo4= github.com/dimchansky/utfbom v1.1.0/go.mod h1:rO41eb7gLfo8SF1jd9F8HplJm1Fewwi4mQvIirEdv+8= -github.com/docker/docker v0.7.3-0.20190327010347-be7ac8be2ae0/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk= -github.com/docker/go-units v0.3.3/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk= -github.com/docker/go-units v0.4.0/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk= -github.com/docker/spdystream v0.0.0-20160310174837-449fdfce4d96/go.mod h1:Qh8CwZgvJUkLughtfhJv5dyTYa91l1fOUCrgjqmcifM= github.com/docopt/docopt-go v0.0.0-20180111231733-ee0de3bc6815/go.mod h1:WwZ+bS3ebgob9U8Nd0kOddGdZWjyMGR8Wziv+TBNwSE= github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk= -github.com/elazarl/goproxy v0.0.0-20170405201442-c4fc26588b6e/go.mod h1:/Zj4wYkgs4iZTTu3o/KG3Itv/qCCa8VVMlb3i9OVuzc= 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= github.com/emicklei/go-restful v2.9.5+incompatible/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs= +github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= +github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= +github.com/envoyproxy/go-control-plane v0.9.7/go.mod h1:cwu0lG7PUMfa9snN8LXBig5ynNVH9qI8YYLbd1fK2po= +github.com/envoyproxy/go-control-plane v0.9.9-0.20201210154907-fd9021fe5dad/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= +github.com/envoyproxy/go-control-plane v0.9.9-0.20210217033140-668b12f5399d/go.mod h1:cXg6YxExXjJnVBQHBLXeUAgxn2UodCpnH306RInaBQk= github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c= -github.com/evanphx/json-patch v4.2.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= -github.com/evanphx/json-patch v4.5.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= -github.com/evanphx/json-patch v4.9.0+incompatible h1:kLcOMZeuLAJvL2BPWLMIj5oaZQobrkAqrL+WFZwQses= +github.com/evanphx/json-patch v0.5.2/go.mod h1:ZWS5hhDbVDyob71nXKNL0+PWn6ToqBHMikGIFbs31qQ= github.com/evanphx/json-patch v4.9.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= -github.com/fatih/color v1.7.0 h1:DkWD4oS2D8LGGgTQ6IvwJJXSL5Vp2ffcQg58nFV38Ys= +github.com/evanphx/json-patch v4.11.0+incompatible h1:glyUF9yIYtMHzn8xaKw5rMhdWcwsYV8dZHIq5567/xs= +github.com/evanphx/json-patch v4.11.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk= github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4= +github.com/fatih/color v1.12.0 h1:mRhaKNwANqRgUBGKmnI5ZxEk7QXmjQeCcuYFMX2bfcc= +github.com/fatih/color v1.12.0/go.mod h1:ELkj/draVOlAH/xkhN6mQ50Qd0MPOk5AAr3maGEBuJM= github.com/form3tech-oss/jwt-go v3.2.2+incompatible h1:TcekIExNqud5crz4xD2pavyTgWiPvpYe4Xau31I0PRk= github.com/form3tech-oss/jwt-go v3.2.2+incompatible/go.mod h1:pbq4aXjuKjdthFRnoDwaVPLA+WlJuPGy+QneDUgJi2k= github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo= github.com/fsnotify/fsnotify v1.4.9 h1:hsms1Qyu0jgnwNXIxa+/V/PDsU6CfLf6CNO8H7IWoS4= github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ= -github.com/ghodss/yaml v0.0.0-20150909031657-73d445a93680/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04= -github.com/globalsign/mgo v0.0.0-20180905125535-1ca0a4f7cbcb/go.mod h1:xkRDCp4j0OGD1HRkm4kmhM+pmpv3AKq5SU7GMg4oO/Q= -github.com/globalsign/mgo v0.0.0-20181015135952-eeefdecb41b8/go.mod h1:xkRDCp4j0OGD1HRkm4kmhM+pmpv3AKq5SU7GMg4oO/Q= 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/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as= +github.com/go-kit/log v0.1.0/go.mod h1:zbhenjAZHb184qTLMA9ZjW7ThYL0H2mk7Q6pNt4vbaY= 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= github.com/go-logr/logr v0.1.0/go.mod h1:ixOQHD9gLJUVQQ2ZOR7zLEifBX6tGkNJF4QyIY7sIas= github.com/go-logr/logr v0.2.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= -github.com/go-logr/logr v0.3.0 h1:q4c+kbcR0d5rSurhBR8dIgieOaYpXtsdTYfx22Cu6rs= -github.com/go-logr/logr v0.3.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= -github.com/go-logr/zapr v0.2.0 h1:v6Ji8yBW77pva6NkJKQdHLAJKrIJKRHz0RXwPqCHSR4= -github.com/go-logr/zapr v0.2.0/go.mod h1:qhKdvif7YF5GI9NWEpyxTSSBdGmzkNguibrdCNVPunU= -github.com/go-openapi/analysis v0.0.0-20180825180245-b006789cd277/go.mod h1:k70tL6pCuVxPJOHXQ+wIac1FUrvNkHolPie/cLEU6hI= -github.com/go-openapi/analysis v0.17.0/go.mod h1:IowGgpVeD0vNm45So8nr+IcQ3pxVtpRoBWb8PVZO0ik= -github.com/go-openapi/analysis v0.18.0/go.mod h1:IowGgpVeD0vNm45So8nr+IcQ3pxVtpRoBWb8PVZO0ik= -github.com/go-openapi/analysis v0.19.2/go.mod h1:3P1osvZa9jKjb8ed2TPng3f0i/UY9snX6gxi44djMjk= -github.com/go-openapi/analysis v0.19.5/go.mod h1:hkEAkxagaIvIP7VTn8ygJNkd4kAYON2rCu0v0ObL0AU= -github.com/go-openapi/errors v0.17.0/go.mod h1:LcZQpmvG4wyF5j4IhA73wkLFQg+QJXOQHVjmcZxhka0= -github.com/go-openapi/errors v0.18.0/go.mod h1:LcZQpmvG4wyF5j4IhA73wkLFQg+QJXOQHVjmcZxhka0= -github.com/go-openapi/errors v0.19.2/go.mod h1:qX0BLWsyaKfvhluLejVpVNwNRdXZhEbTA4kxxpKBC94= -github.com/go-openapi/jsonpointer v0.0.0-20160704185906-46af16f9f7b1/go.mod h1:+35s3my2LFTysnkMfxsJBAMHj/DoqoB9knIWoYG/Vk0= -github.com/go-openapi/jsonpointer v0.17.0/go.mod h1:cOnomiV+CVVwFLk0A/MExoFMjwdsUdVpsRhURCKh+3M= -github.com/go-openapi/jsonpointer v0.18.0/go.mod h1:cOnomiV+CVVwFLk0A/MExoFMjwdsUdVpsRhURCKh+3M= +github.com/go-logr/logr v0.4.0 h1:K7/B1jt6fIBQVd4Owv2MqGQClcgf0R266+7C/QjRcLc= +github.com/go-logr/logr v0.4.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU= +github.com/go-logr/zapr v0.4.0 h1:uc1uML3hRYL9/ZZPdgHS/n8Nzo+eaYL/Efxkkamf7OM= +github.com/go-logr/zapr v0.4.0/go.mod h1:tabnROwaDl0UNxkVeFRbY8bwB37GwRv0P8lg6aAiEnk= github.com/go-openapi/jsonpointer v0.19.2/go.mod h1:3akKfEdA7DF1sugOqz1dVQHBcuDBPKZGEoHC/NkiQRg= github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= -github.com/go-openapi/jsonreference v0.0.0-20160704190145-13c6e3589ad9/go.mod h1:W3Z9FmVs9qj+KR4zFKmDPGiLdk1D9Rlm7cyMvf57TTg= -github.com/go-openapi/jsonreference v0.17.0/go.mod h1:g4xxGn04lDIRh0GJb5QlpE3HfopLOL6uZrK/VgnsK9I= -github.com/go-openapi/jsonreference v0.18.0/go.mod h1:g4xxGn04lDIRh0GJb5QlpE3HfopLOL6uZrK/VgnsK9I= github.com/go-openapi/jsonreference v0.19.2/go.mod h1:jMjeRr2HHw6nAVajTXJ4eiUwohSTlpa0o73RUL1owJc= github.com/go-openapi/jsonreference v0.19.3/go.mod h1:rjx6GuL8TTa9VaixXglHmQmIL98+wF9xc8zWvFonSJ8= -github.com/go-openapi/loads v0.17.0/go.mod h1:72tmFy5wsWx89uEVddd0RjRWPZm92WRLhf7AC+0+OOU= -github.com/go-openapi/loads v0.18.0/go.mod h1:72tmFy5wsWx89uEVddd0RjRWPZm92WRLhf7AC+0+OOU= -github.com/go-openapi/loads v0.19.0/go.mod h1:72tmFy5wsWx89uEVddd0RjRWPZm92WRLhf7AC+0+OOU= -github.com/go-openapi/loads v0.19.2/go.mod h1:QAskZPMX5V0C2gvfkGZzJlINuP7Hx/4+ix5jWFxsNPs= -github.com/go-openapi/loads v0.19.4/go.mod h1:zZVHonKd8DXyxyw4yfnVjPzBjIQcLt0CCsn0N0ZrQsk= -github.com/go-openapi/runtime v0.0.0-20180920151709-4f900dc2ade9/go.mod h1:6v9a6LTXWQCdL8k1AO3cvqx5OtZY/Y9wKTgaoP6YRfA= -github.com/go-openapi/runtime v0.19.0/go.mod h1:OwNfisksmmaZse4+gpV3Ne9AyMOlP1lt4sK4FXt0O64= -github.com/go-openapi/runtime v0.19.4/go.mod h1:X277bwSUBxVlCYR3r7xgZZGKVvBd/29gLDlFGtJ8NL4= -github.com/go-openapi/spec v0.0.0-20160808142527-6aced65f8501/go.mod h1:J8+jY1nAiCcj+friV/PDoE1/3eeccG9LYBs0tYvLOWc= -github.com/go-openapi/spec v0.17.0/go.mod h1:XkF/MOi14NmjsfZ8VtAKf8pIlbZzyoTvZsdfssdxcBI= -github.com/go-openapi/spec v0.18.0/go.mod h1:XkF/MOi14NmjsfZ8VtAKf8pIlbZzyoTvZsdfssdxcBI= -github.com/go-openapi/spec v0.19.2/go.mod h1:sCxk3jxKgioEJikev4fgkNmwS+3kuYdJtcsZsD5zxMY= github.com/go-openapi/spec v0.19.3/go.mod h1:FpwSN1ksY1eteniUU7X0N/BgJ7a4WvBFVA8Lj9mJglo= -github.com/go-openapi/strfmt v0.17.0/go.mod h1:P82hnJI0CXkErkXi8IKjPbNBM6lV6+5pLP5l494TcyU= -github.com/go-openapi/strfmt v0.18.0/go.mod h1:P82hnJI0CXkErkXi8IKjPbNBM6lV6+5pLP5l494TcyU= -github.com/go-openapi/strfmt v0.19.0/go.mod h1:+uW+93UVvGGq2qGaZxdDeJqSAqBqBdl+ZPMF/cC8nDY= -github.com/go-openapi/strfmt v0.19.3/go.mod h1:0yX7dbo8mKIvc3XSKp7MNfxw4JytCfCD6+bY1AVL9LU= -github.com/go-openapi/swag v0.0.0-20160704191624-1d0bd113de87/go.mod h1:DXUve3Dpr1UfpPtxFw+EFuQ41HhCWZfha5jSVRG7C7I= -github.com/go-openapi/swag v0.17.0/go.mod h1:AByQ+nYG6gQg71GINrmuDXCPWdL640yX49/kXLo40Tg= -github.com/go-openapi/swag v0.18.0/go.mod h1:AByQ+nYG6gQg71GINrmuDXCPWdL640yX49/kXLo40Tg= +github.com/go-openapi/spec v0.19.5/go.mod h1:Hm2Jr4jv8G1ciIAo+frC/Ft+rR2kQDh8JHKHb3gWUSk= github.com/go-openapi/swag v0.19.2/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= -github.com/go-openapi/validate v0.18.0/go.mod h1:Uh4HdOzKt19xGIGm1qHf/ofbX1YQ4Y+MYsct2VUrAJ4= -github.com/go-openapi/validate v0.19.2/go.mod h1:1tRCw7m3jtI8eNWEEliiAqUIcBztB2KDnRCRMUi7GTA= -github.com/go-openapi/validate v0.19.5/go.mod h1:8DJv2CVJQ6kGNpFW6eV9N3JviE1C85nY1c2z52x1Gk4= github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY= -github.com/gobuffalo/flect v0.1.5/go.mod h1:W3K3X9ksuZfir8f/LrfVtWmCDQFfayuylOJ7sz/Fj80= -github.com/gobuffalo/flect v0.2.0 h1:EWCvMGGxOjsgwlWaP+f4+Hh6yrrte7JeFL2S6b+0hdM= -github.com/gobuffalo/flect v0.2.0/go.mod h1:W3K3X9ksuZfir8f/LrfVtWmCDQFfayuylOJ7sz/Fj80= +github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE= +github.com/gobuffalo/flect v0.2.3 h1:f/ZukRnSNA/DUpSNDadko7Qc0PhGvsew35p/2tu+CRY= +github.com/gobuffalo/flect v0.2.3/go.mod h1:vmkQwuZYhN5Pc4ljYQZzP+1sq+NEkK+lh20jmEmX3jc= +github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ= github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4= -github.com/gogo/protobuf v1.2.2-0.20190723190241-65acae22fc9d/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXPKa29o= -github.com/gogo/protobuf v1.3.1 h1:DqDEcV5aeaTmdFBePNpYsp3FlcVH/2ISVVM9Qf8PSls= -github.com/gogo/protobuf v1.3.1/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXPKa29o= +github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= +github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20190129154638-5b532d6fd5ef/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= @@ -249,12 +221,15 @@ github.com/golang/mock v1.2.0/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfb github.com/golang/mock v1.3.1/go.mod h1:sBzyDLLjw3U8JLTeZvSv8jJB+tU5PVekmnlKIyFUx0Y= github.com/golang/mock v1.4.0/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= github.com/golang/mock v1.4.1/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= -github.com/golang/protobuf v0.0.0-20161109072736-4bd1920723d7/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= +github.com/golang/mock v1.4.3/go.mod h1:UOMv5ysSaYNkG+OFQykRIcU/QvvxJf3p21QfJ2Bt3cw= +github.com/golang/mock v1.4.4/go.mod h1:l3mdAwkq5BuhzHwde/uurv3sEJeZMXNpwsxVWU71h+4= +github.com/golang/mock v1.5.0/go.mod h1:CWnOUgYIOo4TcNZ0wHX3YZCqsaM1I1Jvs6v3mP3KVu8= github.com/golang/protobuf v1.2.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= github.com/golang/protobuf v1.3.1/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= github.com/golang/protobuf v1.3.2/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U= github.com/golang/protobuf v1.3.3/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= github.com/golang/protobuf v1.3.4/go.mod h1:vzj43D7+SQXF/4pzW/hwtAqwc6iTitCiVSaWz5lYuqw= +github.com/golang/protobuf v1.3.5/go.mod h1:6O5/vntMXwX2lRkT1hjjk0nAC1IDOTvTlVgjlRvqsdk= github.com/golang/protobuf v1.4.0-rc.1/go.mod h1:ceaxUfeHdC40wWswd/P6IGgMaK3YpKi5j83Wpe3EHw8= github.com/golang/protobuf v1.4.0-rc.1.0.20200221234624-67d41d38c208/go.mod h1:xKAWHe0F5eneWXFV3EuXVDTCmh+JuBKY0li0aMyXATA= github.com/golang/protobuf v1.4.0-rc.2/go.mod h1:LlEzMj4AhA7rCAGe4KMBDvJI+AwstrUpVNzEA03Pprs= @@ -262,27 +237,43 @@ github.com/golang/protobuf v1.4.0-rc.4.0.20200313231945-b860323f09d0/go.mod h1:W github.com/golang/protobuf v1.4.0/go.mod h1:jodUvKwWbYaEsadDk5Fwe5c77LiNKVO9IDvqG2KuDX0= github.com/golang/protobuf v1.4.1/go.mod h1:U8fpvMrcmy5pZrNK1lt4xCsGvpyWQ/VVv6QDs8UjoX8= github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= -github.com/golang/protobuf v1.4.3 h1:JjCZWpVbqXDqFVmTfYWEVTMIYrL/NPdPSCHPJ0T/raM= github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI= +github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= +github.com/golang/protobuf v1.5.1/go.mod h1:DopwsBzvsk0Fs44TXzsVbJyPhcCPeIwnvohx4u74HPM= +github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw= +github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= github.com/google/btree v0.0.0-20180813153112-4030bb1f1f0c/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= github.com/google/btree v1.0.0/go.mod h1:lNA+9X1NB3Zf8V7Ke586lFgjr2dZNuvo3lPJSGZ5JPQ= github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M= github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.4.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.2 h1:X2ev0eStA3AbceY54o37/0PQ/UWqKEiiO2dKL5OPaFM= +github.com/google/go-cmp v0.5.1/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/gofuzz v0.0.0-20161122191042-44d81051d367/go.mod h1:HP5RmnzzSNb993RKQDq4+1A4ia9nllfqcQFTQJedwGI= +github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.4/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= +github.com/google/go-cmp v0.5.6 h1:BKbKCqvP6I+rmFHt06ZmyQtvB8xAkWdhFyr0ZUNZcxQ= +github.com/google/go-cmp v0.5.6/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/gofuzz v1.1.0 h1:Hsa8mG0dQ46ij8Sl2AYJDUv1oA9/d6Vk+3LG99Oe02g= github.com/google/gofuzz v1.1.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= +github.com/google/martian/v3 v3.0.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= +github.com/google/martian/v3 v3.1.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0= github.com/google/pprof v0.0.0-20181206194817-3ea8567a2e57/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= github.com/google/pprof v0.0.0-20190515194954-54271f7e092f/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= github.com/google/pprof v0.0.0-20191218002539-d4f498aebedc/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= github.com/google/pprof v0.0.0-20200212024743-f11f1df84d12/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= github.com/google/pprof v0.0.0-20200229191704-1ebb73c60ed3/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20200430221834-fc25d7d30c6d/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20200708004538-1a94d8640e99/go.mod h1:ZgVRPoUq/hfqzAqh7sHMqb3I9Rq5C59dIz2SbBwJ4eM= +github.com/google/pprof v0.0.0-20201023163331-3e6fc7fc9c4c/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20201203190320-1bf35d6f28c2/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210122040257-d980be63207e/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= +github.com/google/pprof v0.0.0-20210226084205-cbba55b83ad5/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE= github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= @@ -290,25 +281,19 @@ github.com/google/uuid v1.1.2 h1:EVhdT+1Kseyi1/pUmXKaFxYsDNy9RQYkMWRH68J/W7Y= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/googleapis/gax-go/v2 v2.0.4/go.mod h1:0Wqv26UfaUD9n4G6kQubkQ+KchISgw+vpHVxEJEs9eg= github.com/googleapis/gax-go/v2 v2.0.5/go.mod h1:DWXyrwAJ9X0FpwwEdw+IPEYBICEFu5mhpdKc/us6bOk= -github.com/googleapis/gnostic v0.0.0-20170729233727-0c5108395e2d/go.mod h1:sJBsCZ4ayReDTBIg8b9dl28c5xFWyhBTVRp3pOg5EKY= -github.com/googleapis/gnostic v0.1.0/go.mod h1:sJBsCZ4ayReDTBIg8b9dl28c5xFWyhBTVRp3pOg5EKY= github.com/googleapis/gnostic v0.4.1/go.mod h1:LRhVm6pbyptWbWbuZ38d1eyptfvIytN3ir6b65WBswg= -github.com/googleapis/gnostic v0.5.1 h1:A8Yhf6EtqTv9RMsU6MQTyrtV1TjWlR6xU9BsZIwuTCM= -github.com/googleapis/gnostic v0.5.1/go.mod h1:6U4PtQXGIEt/Z3h5MAT7FNofLnw9vXk2cUuW7uA/OeU= -github.com/gophercloud/gophercloud v0.1.0/go.mod h1:vxM41WHh5uqHVBMZHzuwNOHh8XEoIEcSTewFxm1c5g8= +github.com/googleapis/gnostic v0.5.5 h1:9fHAtK0uDfpveeqqo1hkEZJcFvYXAiCN3UutL8F9xHw= +github.com/googleapis/gnostic v0.5.5/go.mod h1:7+EbHbldMins07ALC74bsA81Ovc97DwqyJO1AENw9kA= github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY= 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.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE= -github.com/gregjones/httpcache v0.0.0-20170728041850-787624de3eb7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA= github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA= -github.com/grpc-ecosystem/go-grpc-middleware v0.0.0-20190222133341-cfaf5686ec79/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs= github.com/grpc-ecosystem/go-grpc-middleware v1.0.0/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs= github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs= github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk= -github.com/grpc-ecosystem/grpc-gateway v1.3.0/go.mod h1:RSKVYQBd5MCa4OVpNdGskqpgL2+G+NZTnrVHpWWfpdw= github.com/grpc-ecosystem/grpc-gateway v1.9.0/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY= github.com/grpc-ecosystem/grpc-gateway v1.9.5/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY= +github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw= github.com/hashicorp/consul/api v1.1.0/go.mod h1:VmuI/Lkw1nC05EYQWNKwWGbkg+FbDBtguAZLlVdkD9Q= github.com/hashicorp/consul/sdk v0.1.1/go.mod h1:VKf9jXwCTEY1QZP2MOLRhb5i/I/ssyNV1vwHyQBF0x8= github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4= @@ -337,28 +322,32 @@ github.com/hashicorp/memberlist v0.1.3/go.mod h1:ajVTdAv/9Im8oMAAj5G31PhhMCZJV2p github.com/hashicorp/serf v0.8.2/go.mod h1:6hOLApaqBFA1NXqRQAsxw9QxuDEvNxSQRwA/JwenrHc= github.com/hpcloud/tail v1.0.0/go.mod h1:ab1qPbhIpdTxEkNHXyeSf5vhxWSCs/tWer42PpOxQnU= github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= +github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc= github.com/imdario/mergo v0.3.5/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA= -github.com/imdario/mergo v0.3.10 h1:6q5mVkdH/vYmqngx7kZQTjJ5HRsx+ImorDIEQ+beJgc= -github.com/imdario/mergo v0.3.10/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA= +github.com/imdario/mergo v0.3.12 h1:b6R2BslTbIEToALKP7LxUvijTsNI9TAe80pLWN2g/HU= +github.com/imdario/mergo v0.3.12/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA= github.com/inconshreveable/mousetrap v1.0.0 h1:Z8tu5sraLXCXIcARxBp/8cbvlwVa7Z1NHg9XEKhtSvM= github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8= +github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= github.com/jmespath/go-jmespath v0.0.0-20160202185014-0b12d6b521d8/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k= github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo= -github.com/json-iterator/go v0.0.0-20180612202835-f2b4162afba3/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU= +github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4= github.com/json-iterator/go v1.1.6/go.mod h1:+SdeFBvtyEkXs7REEP0seUULqWtbJapLOCVDaaPEHmU= github.com/json-iterator/go v1.1.7/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= -github.com/json-iterator/go v1.1.8/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= -github.com/json-iterator/go v1.1.10 h1:Kz6Cvnvv2wGdaG/V8yMvfkmNiXq9Ya2KUv4rouJJr68= github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= +github.com/json-iterator/go v1.1.11 h1:uVUAXhF2To8cbw/3xN3pxj6kk7TYKs98NIrTqPlMWAQ= +github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU= github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk= github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU= github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= +github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= 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.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8= github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= +github.com/kr/fs v0.1.0/go.mod h1:FFnZGqtBN9Gxj7eW1uZ42v5BccTP0vu6NEaFoC2HwRg= github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc= github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI= @@ -367,25 +356,22 @@ github.com/kr/pty v1.1.5/go.mod h1:9r2w37qlBe7rQ6e1fg1S/9xpWHSnaqNdHD3WcMdbPDA= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= -github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= github.com/magiconair/properties v1.8.1/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ= -github.com/mailru/easyjson v0.0.0-20160728113105-d5b7844b561a/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= -github.com/mailru/easyjson v0.0.0-20180823135443-60711f1a8329/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= -github.com/mailru/easyjson v0.0.0-20190312143242-1de009706dbe/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= +github.com/magiconair/properties v1.8.5/go.mod h1:y3VJvCyxH9uVvJTWEGAELF3aiYNyPKd5NZ3oSwXrF60= github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= github.com/mailru/easyjson v0.7.0/go.mod h1:KAzv3t3aY1NaHWoQz1+4F1ccyAH66Jk7yos7ldAVICs= github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU= -github.com/mattn/go-colorable v0.1.2 h1:/bC9yWikZXAL9uJdulbSfyVNIR3n3trXl+v8+1sx8mU= -github.com/mattn/go-colorable v0.1.2/go.mod h1:U0ppj6V5qS13XJ6of8GYAs25YV2eR4EVcfRqFIhoBtE= +github.com/mattn/go-colorable v0.1.8 h1:c1ghPdyEDarC70ftn0y+A/Ee++9zz8ljHG1b13eJ0s8= +github.com/mattn/go-colorable v0.1.8/go.mod h1:u6P/XSegPjTcexA+o6vUJrdnUu04hMope9wVRipJSqc= github.com/mattn/go-ieproxy v0.0.0-20190610004146-91bb50d98149/go.mod h1:31jz6HNzdxOmlERGGEc4v/dMssOfmp2p5bT/okiKFFc= github.com/mattn/go-ieproxy v0.0.0-20190702010315-6dee0af9227d/go.mod h1:31jz6HNzdxOmlERGGEc4v/dMssOfmp2p5bT/okiKFFc= github.com/mattn/go-ieproxy v0.0.0-20190805055040-f9202b1cfdeb h1:hXqqXzQtJbENrsb+rsIqkVqcg4FUJL0SQFGw08Dgivw= github.com/mattn/go-ieproxy v0.0.0-20190805055040-f9202b1cfdeb/go.mod h1:31jz6HNzdxOmlERGGEc4v/dMssOfmp2p5bT/okiKFFc= github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= -github.com/mattn/go-isatty v0.0.8 h1:HLtExJ+uU2HOZ+wI0Tt5DtUDrx8yhUqDcp7fYERX4CE= -github.com/mattn/go-isatty v0.0.8/go.mod h1:Iq45c/XA43vh69/j3iqttzPXn0bhXyGjM0Hdxcsrc5s= +github.com/mattn/go-isatty v0.0.12 h1:wuysRhFDzyxgEmMf5xjvJ2M9dZoWAXNNr5LSBS7uHXY= +github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU= github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= github.com/mattn/go-runewidth v0.0.4/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0= @@ -403,191 +389,179 @@ github.com/mitchellh/gox v0.4.0/go.mod h1:Sd9lOJ0+aimLBi73mGofS1ycjY8lL3uZM3JPS4 github.com/mitchellh/iochan v1.0.0/go.mod h1:JwYml1nuB7xOzsp52dPpHFffvOCDupsG0QubkSMEySY= github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y= +github.com/mitchellh/mapstructure v1.4.1/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= github.com/mitchellh/reflectwalk v1.0.2 h1:G2LzWKi524PWgd3mLHV8Y5k7s6XUvT0Gef6zxSIeXaQ= github.com/mitchellh/reflectwalk v1.0.2/go.mod h1:mSTlrgnPZtwu0c4WaC2kGObEpuNDbx0jmZXqmk4esnw= -github.com/moby/term v0.0.0-20200312100748-672ec06f55cd/go.mod h1:DdlQx2hp0Ss5/fLikoLlEeIYiATotOjgB//nb973jeo= +github.com/moby/spdystream v0.2.0/go.mod h1:f7i0iNDQJ059oMTcWxx8MA/zKFIuD/lY+0GqbN2Wy8c= +github.com/moby/term v0.0.0-20201216013528-df9cb8a40635/go.mod h1:FBS0z0QWA44HXygs7VXDUOGoN/1TV3RuWkLO04am3wc= github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg= github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= -github.com/modern-go/reflect2 v0.0.0-20180320133207-05fbef0ca5da/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/modern-go/reflect2 v1.0.1 h1:9f412s+6RmYXLWZSEzVVgPGK7C2PphHj5RJrvfx9AWI= github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0= github.com/munnerz/goautoneg v0.0.0-20120707110453-a547fc61f48d/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= +github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U= github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f/go.mod h1:ZdcZmHo+o7JKHSa8/e818NopupXU1YMK5fe1lsApnBw= github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs= github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= -github.com/nxadm/tail v1.4.4 h1:DQuhQpB1tVlglWS2hLQ5OV6B5r8aGxSrPc5Qo6uTN78= github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI8A= +github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE= +github.com/nxadm/tail v1.4.8/go.mod h1:+ncqLTQzXmGhMZNUePPaPqPvBxHAIsmXswZKocGu+AU= github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U= github.com/olekukonko/tablewriter v0.0.0-20170122224234-a0225b3f23b5/go.mod h1:vsDQFd/mU46D+Z4whnwzcISnGGzXWMclvtLoiIKAKIo= github.com/onsi/ginkgo v0.0.0-20170829012221-11459a886d9c/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= -github.com/onsi/ginkgo v1.8.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE= github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk= -github.com/onsi/ginkgo v1.14.1 h1:jMU0WaQrP0a/YAEq8eJmJKjBoMs+pClEr1vDMlM/Do4= -github.com/onsi/ginkgo v1.14.1/go.mod h1:iSB4RoI2tjJc9BBv4NKIKWKya62Rps+oPG/Lv9klQyY= +github.com/onsi/ginkgo v1.16.4 h1:29JGrr5oVBm5ulCWet69zQkzWipVXIol6ygQUe/EzNc= +github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0= github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA= -github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY= github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY= -github.com/onsi/gomega v1.8.1/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA= github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= -github.com/onsi/gomega v1.10.2 h1:aY/nuoWlKJud2J6U0E3NWsjlg+0GtwXxgEqthRdzlcs= -github.com/onsi/gomega v1.10.2/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo= +github.com/onsi/gomega v1.14.0 h1:ep6kpPVwmr/nTbklSx2nrLNSIO62DoYAhnPNIMhK8gI= +github.com/onsi/gomega v1.14.0/go.mod h1:cIuvLEne0aoVhAgh/O6ac0Op8WWw9H6eYCriF+tEHG0= github.com/pascaldekloe/goe v0.0.0-20180627143212-57f6aae5913c/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc= -github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k= github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic= +github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c= github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU= github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= -github.com/pmezard/go-difflib v0.0.0-20151028094244-d8ed2627bdf0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/pkg/sftp v1.10.1/go.mod h1:lYOWFsE0bwd1+KfKJaKeuokY15vzFx25BLbzYYoAxZI= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI= github.com/pquerna/cachecontrol v0.0.0-20171018203845-0dec1b30a021/go.mod h1:prYjPmNq4d1NPVmpShWobRqXY3q7Vp+80DqgxxUrUIA= github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw= -github.com/prometheus/client_golang v0.9.2/go.mod h1:OsXs2jCmiKlQ1lTBmv21f2mNfw4xf/QclQDMrYNZzcM= github.com/prometheus/client_golang v0.9.3/go.mod h1:/TN21ttK/J9q6uSwhBd54HahCDft0ttaMvbicHlPoso= github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo= -github.com/prometheus/client_golang v1.7.1 h1:NTGy1Ja9pByO+xAeH/qiWnLrKtr3hJPNjaVUwnjpdpA= github.com/prometheus/client_golang v1.7.1/go.mod h1:PY5Wy2awLA44sXw4AOSfFBetzPP4j5+D6mVACh+pe2M= +github.com/prometheus/client_golang v1.11.0 h1:HNkLOAEQMIDv/K+04rukrLx6ch7msSRwf3/SASFAGtQ= +github.com/prometheus/client_golang v1.11.0/go.mod h1:Z6t4BnS23TR94PD6BsDNk8yVqroYurpAkEiz0P2BEV0= github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo= github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/client_model v0.0.0-20190812154241-14fe0d1b01d4/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/client_model v0.2.0 h1:uq5h0d+GuxiXLJLNABMgp2qUWDPiLvgCzz2dUR+/W/M= github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA= github.com/prometheus/common v0.0.0-20181113130724-41aa239b4cce/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro= -github.com/prometheus/common v0.0.0-20181126121408-4724e9255275/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro= github.com/prometheus/common v0.4.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4= -github.com/prometheus/common v0.10.0 h1:RyRA7RzGXQZiW+tGMr7sxa85G1z0yOpM1qq5c8lNawc= github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo= +github.com/prometheus/common v0.26.0 h1:iMAkS2TDoNWnKM+Kopnx/8tnEStIfpYA0ur0xQzzhMQ= +github.com/prometheus/common v0.26.0/go.mod h1:M7rCNAaPfAosfx8veZJCuw84e35h3Cfd9VFqTh1DIvc= github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk= -github.com/prometheus/procfs v0.0.0-20181204211112-1dc9a6cbc91a/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk= github.com/prometheus/procfs v0.0.0-20190507164030-5867b95ac084/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU= -github.com/prometheus/procfs v0.2.0 h1:wH4vA7pcjKuZzjF7lM8awk4fnuJO6idemZXoKnULUx4= github.com/prometheus/procfs v0.2.0/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU= +github.com/prometheus/procfs v0.6.0 h1:mxy4L2jP6qMonqmq+aTtOx1ifVWUgG/TAmntgbh3xv4= +github.com/prometheus/procfs v0.6.0/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1xBZuNvfVA= github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU= -github.com/remyoudompheng/bigfft v0.0.0-20170806203942-52369c62f446/go.mod h1:uYEyJGbgTkfkS4+E/PavXkNJcbFIpEtjt2B0KDQ5+9M= github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg= +github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= -github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g= github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts= github.com/satori/go.uuid v1.2.0 h1:0uYX9dsZ2yD7q2RtLRtPSdGDWzjeM3TbMJP9utgA0ww= github.com/satori/go.uuid v1.2.0/go.mod h1:dA0hQrYB0VpLJoorglMZABFdXlWrHn1NEOzdhQKdks0= github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc= -github.com/sergi/go-diff v1.0.0/go.mod h1:0CfEIISq7TuYL3j771MWULgwwjU+GofnZX9QAmXWZgo= github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo= github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE= github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88= +github.com/sirupsen/logrus v1.7.0/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0= github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc= github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA= -github.com/soheilhy/cmux v0.1.3/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM= github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM= github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA= github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ= -github.com/spf13/afero v1.2.2 h1:5jhuqJyZCZf2JRofRvN/nIFgIWNzPa3/Vz8mYylgbWc= github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk= +github.com/spf13/afero v1.6.0 h1:xoax2sJ2DT8S8xA2paPFjDCScCNeWsg75VG0DLRreiY= +github.com/spf13/afero v1.6.0/go.mod h1:Ai8FlHk4v/PARR026UzYexafAt9roJ7LcLMAmO6Z93I= github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= +github.com/spf13/cast v1.3.1/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE= github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ= -github.com/spf13/cobra v0.0.5/go.mod h1:3K3wKZymM7VvHMDS9+Akkh4K60UwM26emMESw8tLCHU= -github.com/spf13/cobra v1.0.0/go.mod h1:/6GTrnGXV9HjY+aR4k0oJ5tcvakLuG6EuKReYlHNrgE= -github.com/spf13/cobra v1.1.1 h1:KfztREH0tPxJJ+geloSLaAkaPkr4ki2Er5quFV1TDo4= github.com/spf13/cobra v1.1.1/go.mod h1:WnodtKOvamDL/PwE2M4iKs8aMDBZ5Q5klgD3qfVJQMI= +github.com/spf13/cobra v1.2.1 h1:+KmjbUw1hriSNMF55oPrkZcb27aECyrj8V2ytv7kWDw= +github.com/spf13/cobra v1.2.1/go.mod h1:ExllRjgxM/piMAM+3tAZvg8fsklGAf3tPfi+i8t68Nk= github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo= +github.com/spf13/jwalterweatherman v1.1.0/go.mod h1:aNWZUN0dPAAO/Ljvb5BEdw96iTZ0EXowPYD95IqWIGo= github.com/spf13/pflag v0.0.0-20170130214245-9ff6c6923cff/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/spf13/pflag v1.0.1/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4= github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= -github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s= -github.com/spf13/viper v1.4.0/go.mod h1:PTJ7Z/lr49W6bUbkmS1V3by4uWynFiR9p7+dSq/yZzE= github.com/spf13/viper v1.7.0/go.mod h1:8WkrPz2fc9jxqZNCJI/76HCieCp4Q8HaLFoCha5qpdg= +github.com/spf13/viper v1.8.1/go.mod h1:o0Pch8wJ9BVSWGQMbra6iw0oQ5oktSIBaujf1rJH9Ns= github.com/stoewer/go-strcase v1.2.0/go.mod h1:IBiWB2sKIp3wVVQ3Y035++gc+knqhUQag1KpM8ahLw8= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/objx v0.2.0/go.mod h1:qt09Ya8vawLte6SNmTgCsAVtYtaKzEcn8ATUoHMkEqE= -github.com/stretchr/testify v0.0.0-20151208002404-e3a8ff8ce365/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4= github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA= -github.com/stretchr/testify v1.6.1 h1:hDPOHmpOpP40lSULcqw7IrRb/u7w6RpDC9399XyoNd0= github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= +github.com/stretchr/testify v1.7.0 h1:nwc3DEeHmmLAfoZucVR881uASk0Mfjw8xYJ99tb5CcY= +github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw= -github.com/tidwall/pretty v1.0.0/go.mod h1:XNkn88O1ChpSDQmQeStsy+sBenx6DDtFZJxhVysOjyk= 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/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc= -github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0= github.com/ulikunitz/xz v0.5.5/go.mod h1:2bypXElzHzzJZwzH67Y6wb67pO62Rzfn7BSiF4ABRW8= github.com/urfave/cli v1.20.0/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA= -github.com/vektah/gqlparser v1.1.2/go.mod h1:1ycwN7Ij5njmMkPPAOaRFY4rET2Enx7IkVv3vaXspKw= -github.com/xiang90/probing v0.0.0-20160813154853-07dd2e8dfe18/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU= -github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q= +github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= +github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k= go.etcd.io/bbolt v1.3.2/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU= go.etcd.io/bbolt v1.3.5/go.mod h1:G5EMThwa9y8QZGBClrRx5EY+Yw9kAhnjy3bSjsnlVTQ= -go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg= go.etcd.io/etcd v0.5.0-alpha.5.0.20200910180754-dd1b699fc489/go.mod h1:yVHk9ub3CSBatqGNg7GRmsnfLWtoW60w4eDYfh7vHDg= -go.mongodb.org/mongo-driver v1.0.3/go.mod h1:u7ryQJ+DOzQmeO7zB6MHyr8jkEQvC8vH7qLUO4lqsUM= -go.mongodb.org/mongo-driver v1.1.1/go.mod h1:u7ryQJ+DOzQmeO7zB6MHyr8jkEQvC8vH7qLUO4lqsUM= -go.mongodb.org/mongo-driver v1.1.2/go.mod h1:u7ryQJ+DOzQmeO7zB6MHyr8jkEQvC8vH7qLUO4lqsUM= +go.etcd.io/etcd/api/v3 v3.5.0/go.mod h1:cbVKeC6lCfl7j/8jBhAK6aIYO9XOjdptoxU/nLQcPvs= +go.etcd.io/etcd/client/pkg/v3 v3.5.0/go.mod h1:IJHfcCEKxYu1Os13ZdwCwIUTUVGYTSAM3YSwc9/Ac1g= +go.etcd.io/etcd/client/v2 v2.305.0/go.mod h1:h9puh54ZTgAKtEbut2oe9P4L/oqKCVB6xsXlzd7alYQ= go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU= go.opencensus.io v0.22.0/go.mod h1:+kGneAE2xo2IficOXnaByMWTGM9T73dGwxeWcUqIpI8= go.opencensus.io v0.22.2/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= go.opencensus.io v0.22.3/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= -go.uber.org/atomic v0.0.0-20181018215023-8dc6146f7569/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= +go.opencensus.io v0.22.4/go.mod h1:yxeiOL68Rb0Xd1ddK5vPZ/oVn4vY4Ynel7k9FzqtOIw= +go.opencensus.io v0.22.5/go.mod h1:5pWMHQbX5EPX2/62yrJeAkowc+lfs/XD7Uxpq3pI6kk= +go.opencensus.io v0.23.0/go.mod h1:XItmlyltB5F7CS4xOC1DcqMoFqwtC6OG2xF7mCv7P7E= go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE= -go.uber.org/atomic v1.6.0 h1:Ezj3JGmsOnG1MoRWQkPBsKLe9DwWD9QeXzTRzzldNVk= -go.uber.org/atomic v1.6.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ= +go.uber.org/atomic v1.7.0 h1:ADUqmZGgLDDfbSL9ZmPxKTybcoEYHgpYfELNoN+7hsw= +go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= go.uber.org/goleak v1.1.10 h1:z+mqJhf6ss6BSfSM671tgKyZBFPTTJM+HLxnhPC3wu0= go.uber.org/goleak v1.1.10/go.mod h1:8a7PlsEVH3e/a/GLqe5IIrQx6GzcnRmZEufDUTk4A7A= -go.uber.org/multierr v0.0.0-20180122172545-ddea229ff1df/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0= -go.uber.org/multierr v1.5.0 h1:KCa4XfM8CWFCpxXRGok+Q0SS/0XBhMDbHHGABQLvD2A= -go.uber.org/multierr v1.5.0/go.mod h1:FeouvMocqHpRaaGuG9EjoKcStLC43Zu/fmqdUMPcKYU= -go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee h1:0mgffUl7nfd+FpvXMVz4IDEaUSmT1ysygQC7qYo7sG4= -go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee/go.mod h1:vJERXedbb3MVM5f9Ejo0C68/HhF8uaILCdgjnY+goOA= -go.uber.org/zap v0.0.0-20180814183419-67bc79d13d15/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= -go.uber.org/zap v1.8.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= +go.uber.org/multierr v1.6.0 h1:y6IPFStTAIT5Ytl7/XYmHvzXQ7S3g/IeZW9hyZ5thw4= +go.uber.org/multierr v1.6.0/go.mod h1:cdWPpRnG4AhwMwsgIHip0KRBQjJy5kYEpYjJxpXp9iU= go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q= -go.uber.org/zap v1.15.0 h1:ZZCA22JRF2gQE5FoNmhmrf7jeJJ2uhqDUNRYKm8dvmM= -go.uber.org/zap v1.15.0/go.mod h1:Mb2vm2krFEG5DV0W9qcHBYFtp/Wku1cvYaqPsS/WYfc= +go.uber.org/zap v1.17.0/go.mod h1:MXVU+bhUf/A7Xi2HNOnopQOrmycQ5Ih87HtOu4q5SSo= +go.uber.org/zap v1.18.1 h1:CSUJ2mjFszzEWt4CdKISEuChVIXGBn3lAPwkRGyVrc4= +go.uber.org/zap v1.18.1/go.mod h1:xg/QME4nWcxGxrpdeYfq7UvYrLh66cuVKdrbD1XF/NI= golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= golang.org/x/crypto v0.0.0-20181029021203-45a5f77698d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= -golang.org/x/crypto v0.0.0-20181203042331-505ab145d0a9/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= -golang.org/x/crypto v0.0.0-20190211182817-74369b46fc67/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= -golang.org/x/crypto v0.0.0-20190320223903-b7391e95e576/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20190418165655-df01cb2cc480/go.mod h1:WFFai1msRO1wXaEeE5yQxYXgSfI8pQAWXbQop6sCtWE= golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20190611184440-5c40567a22f8/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= -golang.org/x/crypto v0.0.0-20190617133340-57b3e21c3d56/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= +golang.org/x/crypto v0.0.0-20190820162420-60c769a6c586/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= -golang.org/x/crypto v0.0.0-20200220183623-bac4c82f6975/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= -golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0 h1:hb9wdF1z5waM+dSIICn1l0DkLVDT3hqhhQsDNUmHPRE= golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= +golang.org/x/crypto v0.0.0-20210220033148-5ea612d1eb83 h1:/ZScEX8SfEmUGRHs0gxpqteO5nfNW6axyZbBdw9A12g= +golang.org/x/crypto v0.0.0-20210220033148-5ea612d1eb83/go.mod h1:jdWPYTVW3xRLrWPugEBEK3UY2ZEsg3UU495nc5E+M+I= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= -golang.org/x/exp v0.0.0-20190125153040-c74c464bbbf2/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= -golang.org/x/exp v0.0.0-20190312203227-4b39c73a6495/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= golang.org/x/exp v0.0.0-20190829153037-c13cbed26979/go.mod h1:86+5VVa7VpoJ4kLfm080zCjGlMRFzhUhsZKEZO7MGek= golang.org/x/exp v0.0.0-20191030013958-a1ab85dbe136/go.mod h1:JXzH8nQsPlswgeRAPE3MuO9GYsAcnJvJ4vnMwN/5qkY= @@ -607,8 +581,10 @@ golang.org/x/lint v0.0.0-20190909230951-414d861bb4ac/go.mod h1:6SW0HCj/g11FgYtHl golang.org/x/lint v0.0.0-20190930215403-16217165b5de/go.mod h1:6SW0HCj/g11FgYtHlgUYUwCkIfeOF89ocIRzGO/8vkc= golang.org/x/lint v0.0.0-20191125180803-fdd1cda4f05f/go.mod h1:5qLYkcX4OjUUV8bRuDixDT3tpyyb+LUpUlRWLxfhWrs= golang.org/x/lint v0.0.0-20200130185559-910be7a94367/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= -golang.org/x/lint v0.0.0-20200302205851-738671d3881b h1:Wh+f8QHJXR411sJR8/vRBTZ7YapZaRvUcLFFJhusH0k= golang.org/x/lint v0.0.0-20200302205851-738671d3881b/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= +golang.org/x/lint v0.0.0-20201208152925-83fdc39ff7b5/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= +golang.org/x/lint v0.0.0-20210508222113-6edffad5e616 h1:VLliZ0d+/avPrXXH+OakdXhpJuEoBZuwh1m2j7U6Iug= +golang.org/x/lint v0.0.0-20210508222113-6edffad5e616/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY= golang.org/x/mobile v0.0.0-20190312151609-d3739f865fa6/go.mod h1:z+o9i4GpDbdi3rU15maQ/Ox0txvL9dWGYEHz965HBQE= golang.org/x/mobile v0.0.0-20190719004257-d2bd2a29d028/go.mod h1:E/iHnbuqvinMTCcRqshq8CkpyQDoeVncDDYHnLhea+o= golang.org/x/mod v0.0.0-20190513183733-4bf6d317e70e/go.mod h1:mXi4GBBbnImb6dmsKGUJ2LatrhH/nqhxcFungHvyanc= @@ -616,13 +592,15 @@ golang.org/x/mod v0.1.0/go.mod h1:0QHyrYULN0/3qlju5TqG8bIK38QM8yzMo5ekMj3DlcY= golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= golang.org/x/mod v0.1.1-0.20191107180719-034126e5016b/go.mod h1:QqPTAvyqsEbceGzBzNggFXnrqF1CaUcvgkdR5Ot7KZg= golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= -golang.org/x/mod v0.3.0 h1:RM4zey1++hCTbCVQfnWeKs9/IEsaBLA8vTkd0WVtmH4= golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= -golang.org/x/net v0.0.0-20170114055629-f2499483f923/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= +golang.org/x/mod v0.3.1-0.20200828183125-ce943fd02449/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.1/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= +golang.org/x/mod v0.4.2 h1:Gz96sIWK3OalVv/I/qNygP42zyoKp3xptRVCWRFEBvo= +golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= -golang.org/x/net v0.0.0-20181005035420-146acd28ed58/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20181023162649-9b4f9f5ad519/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20181201002055-351d144fa1fc/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= @@ -630,19 +608,16 @@ golang.org/x/net v0.0.0-20181220203305-927f97764cc3/go.mod h1:mL1N/T3taQHkDXs73r golang.org/x/net v0.0.0-20190108225652-1e06a53dbb7e/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190213061140-3a22650c66bd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= -golang.org/x/net v0.0.0-20190320064053-1272bf9dcd53/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= golang.org/x/net v0.0.0-20190503192946-f4e77d36d62c/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= -golang.org/x/net v0.0.0-20190522155817-f3200d17e092/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks= golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= +golang.org/x/net v0.0.0-20190628185345-da137c7871d7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20190724013045-ca1201d0de80/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20190812203447-cdfb69ac37fc/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= -golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200202094626-16171245cfb2/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= @@ -650,24 +625,49 @@ golang.org/x/net v0.0.0-20200222125558-5a598a2470a0/go.mod h1:z5CRVTTTmAJ677TzLL golang.org/x/net v0.0.0-20200226121028-0de0cce0169b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200301022130-244492dfa37a/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s= golang.org/x/net v0.0.0-20200324143707-d3edc9973b7e/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200501053045-e0ff5e5a1de5/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200506145744-7e3656a0809f/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200513185701-a91f0712d120/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A= +golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= +golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA= -golang.org/x/net v0.0.0-20201110031124-69a78807bb2b h1:uwuIcX0g4Yl1NC5XAz37xsr2lTtcqevgzYNVt49waME= +golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20201031054903-ff519b6c9102/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU= +golang.org/x/net v0.0.0-20201209123823-ac852fbbde11/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210119194325-5f4716e94777/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210224082022-3d97a244fca7/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= +golang.org/x/net v0.0.0-20210316092652-d523dce5a7f4/go.mod h1:RBQZq4jEuRlivfhVLdyRGr576XBO4/greRjx4P4O3yc= +golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM= +golang.org/x/net v0.0.0-20210428140749-89ef3d95e781 h1:DzZ89McO9/gWPsQXS/FVKAlG02ZjaQ6AlZRBimEYOd0= +golang.org/x/net v0.0.0-20210428140749-89ef3d95e781/go.mod h1:OJAsFXCWl8Ukc7SiCT/9KSuxbyM7479/AVlXFRxuMCk= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= golang.org/x/oauth2 v0.0.0-20191202225959-858c2ad4c8b6/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= -golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d h1:TzXSXBo42m9gQenoE3b9BGiEpg5IG2JkU5FkPIawgtw= golang.org/x/oauth2 v0.0.0-20200107190931-bf48bf16ab8d/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= +golang.org/x/oauth2 v0.0.0-20200902213428-5d25da1a8d43/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20201109201403-9fd604954f58/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20201208152858-08078c50e5b5/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210218202405-ba52d332ba99/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210220000619-9bb904979d93/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210313182246-cd4f82c27b84/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= +golang.org/x/oauth2 v0.0.0-20210402161424-2e8d93401602 h1:0Ja1LBD+yisY6RWM/BH7TJVXWsSjs2VwBSmvSX4HdBc= +golang.org/x/oauth2 v0.0.0-20210402161424-2e8d93401602/go.mod h1:KelEdhl1UZF7XfJ4dDtk6s++YSgaE7mD/BuKKDLBl4A= golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190227155943-e225da77a7e6/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20200317015054-43a5402ce75a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20200625203802-6e8e738ad208/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sys v0.0.0-20170830134202-bb24a47a89ea/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= +golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20201207232520-09787c993a3a/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= +golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -675,12 +675,8 @@ golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5h golang.org/x/sys v0.0.0-20181026203630-95b1ffbd15a5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20181107165924-66b7b1311ac8/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20181116152217-5ac8a444bdc5/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20181205085412-a5c9d58dba9a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190209173611-3b5209105503/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= -golang.org/x/sys v0.0.0-20190222072716-a9d3bda3a223/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190312061237-fead79001313/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20190321052220-f7bb7a8bee54/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190403152447-81d4e9dc473e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -694,44 +690,71 @@ golang.org/x/sys v0.0.0-20190826190057-c7b8b68b1456/go.mod h1:h1NjWce9XRLGQEsW7w golang.org/x/sys v0.0.0-20190904154756-749cb33beabd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191001151750-bb3f8db39f24/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20191022100944-742c48ecaeb7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191120155948-bd437916bb0e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200113162924-86b910548bc1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200212091648-12a6c2dcc1e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200302150141-5c8b2ff67527/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20200519105757-fe76b779f299/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200331124033-c3d80250170d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200501052902-10377860bb8e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200803210538-64077c9b5642/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200831180312-196b9ba8737a/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20200905004654-be1d3432aa8f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/sys v0.0.0-20201112073958-5cba982894dd h1:5CtCZbICpIOFdgO940moixOPjc0178IU44m4EjOO5IY= -golang.org/x/sys v0.0.0-20201112073958-5cba982894dd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= -golang.org/x/text v0.0.0-20160726164857-2910a502d2bf/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= +golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210104204734-6f8348627aad/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210112080510-489259a85091/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210220050731-9a76102bfb43/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210305230114-8fe3ee5dd75b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210315160823-c6e025ad8005/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210320140829-1e4c9ba3b0c4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210403161142-5e06dd20ab57/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210426230700-d19ff857e887/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= +golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c h1:F1jZWGFhYfh0Ci55sIpILtKKK8p3i2/krTr0H1rg74I= +golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= +golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw= +golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= +golang.org/x/term v0.0.0-20210220032956-6a3ed077a48d h1:SZxvLBoTP5yHO3Frd4z4vrF+DBX9vMVanchswa69toE= +golang.org/x/term v0.0.0-20210220032956-6a3ed077a48d/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= -golang.org/x/text v0.3.4 h1:0YWbFKbhXG/wIiuHDSKpS0Iy7FSA+u45VtBMfQcFTTc= golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= +golang.org/x/text v0.3.6 h1:aRYxNxv6iGQlyVaZmk6ZgYEDa+Jg18DxebPSrd6bg1M= +golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= -golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e h1:EHBhcS0mlXEAVwNyO2dLfjToGsyY4j24pTs2ScHnX7s= -golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20210220033141-f8bda1e9f3ba/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= +golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac h1:7zkz7BUtwNFFqcowJ+RIgu2MaV/MapERkDIy+mwPyjs= +golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/tools v0.0.0-20181011042414-1f849cf54d09/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/tools v0.0.0-20181030221726-6c7e314b6563/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/tools v0.0.0-20190125232054-d66bd3c5d5a6/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= -golang.org/x/tools v0.0.0-20190206041539-40960b6deb8e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY= golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= golang.org/x/tools v0.0.0-20190312151545-0bb0c0a6e846/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs= @@ -742,17 +765,13 @@ golang.org/x/tools v0.0.0-20190506145303-2d16b83fe98c/go.mod h1:RgjU9mgBXZiqYHBn golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q= golang.org/x/tools v0.0.0-20190606124116-d0a3d012864b/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= golang.org/x/tools v0.0.0-20190614205625-5aca471b1d59/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= -golang.org/x/tools v0.0.0-20190617190820-da514acc4774/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= golang.org/x/tools v0.0.0-20190621195816-6e04913cbbac/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= golang.org/x/tools v0.0.0-20190624222133-a101b041ded4/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= golang.org/x/tools v0.0.0-20190628153133-6cdbf07be9d0/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc= golang.org/x/tools v0.0.0-20190816200558-6889da9d5479/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20190911174233-4f2ddba30aff/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20190920225731-5eefd052ad72/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191012152004-8de300cfc20a/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191018212557-ed542cd5b28a/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20191029041327-9cc4af7d6b2c/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= -golang.org/x/tools v0.0.0-20191029190741-b9c20aec41a5/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191108193012-7d206e10da11/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191112195655-aa38f8e97acc/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= golang.org/x/tools v0.0.0-20191113191852-77e3bb0ad9e7/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo= @@ -769,22 +788,37 @@ golang.org/x/tools v0.0.0-20200204074204-1cc6d1ef6c74/go.mod h1:TB2adYChydJhpapK golang.org/x/tools v0.0.0-20200207183749-b753a1ba74fa/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200212150539-ea181f53ac56/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200224181240-023911ca70b2/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= +golang.org/x/tools v0.0.0-20200227222343-706bc42d1f0d/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28= golang.org/x/tools v0.0.0-20200304193943-95d2e580d8eb/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= +golang.org/x/tools v0.0.0-20200312045724-11d5b4c81c7d/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw= +golang.org/x/tools v0.0.0-20200331025713-a30bf2db82d4/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8= +golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= golang.org/x/tools v0.0.0-20200505023115-26f46d2f7ef8/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= -golang.org/x/tools v0.0.0-20200616133436-c1934b75d054/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= -golang.org/x/tools v0.0.0-20200616195046-dc31b401abb5/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= -golang.org/x/tools v0.0.0-20200916195026-c9a70fc28ce3 h1:DywqrEscRX7O2phNjkT0L6lhHKGBoMLCNX+XcAe7t6s= -golang.org/x/tools v0.0.0-20200916195026-c9a70fc28ce3/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU= +golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= +golang.org/x/tools v0.0.0-20200729194436-6467de6f59a7/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= +golang.org/x/tools v0.0.0-20200804011535-6c149bb5ef0d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= +golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA= +golang.org/x/tools v0.0.0-20200904185747-39188db58858/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE= +golang.org/x/tools v0.0.0-20201110124207-079ba7bd75cd/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201201161351-ac6f37ff4c2a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201208233053-a543418bbed2/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20201224043029-2b0845dc783e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20210105154028-b0ab187a4818/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= +golang.org/x/tools v0.1.0/go.mod h1:xkSsbof2nBLbhDlRMhhhyNLN/zl3eTqcnHD5viDpcZ0= +golang.org/x/tools v0.1.2/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= +golang.org/x/tools v0.1.5 h1:ouewzE6p+/VEB31YYnTbEJdi8pFqKp4P4n85vwo3DHA= +golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE= golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -gomodules.xyz/jsonpatch/v2 v2.1.0 h1:Phva6wqu+xR//Njw6iorylFFgn/z547tw5Ne3HZPQ+k= -gomodules.xyz/jsonpatch/v2 v2.1.0/go.mod h1:IhYNNY4jnS53ZnfE4PAmpKtDpTCj1JFXc+3mwe7XcUU= -gonum.org/v1/gonum v0.0.0-20190331200053-3d26580ed485/go.mod h1:2ltnJ7xHfj0zHS40VVPYEAAMTa3ZGguvHGBSJeRWqE0= -gonum.org/v1/netlib v0.0.0-20190313105609-8cb42192e0e0/go.mod h1:wa6Ws7BG/ESfp6dHfk7C6KdzKA7wR7u/rKwOGE66zvw= -gonum.org/v1/netlib v0.0.0-20190331212654-76723241ea4e/go.mod h1:kS+toOQn6AQKjmKJ7gzohV1XkqsFehRA2FbsbkopSuQ= +gomodules.xyz/jsonpatch/v2 v2.2.0 h1:4pT439QV83L+G9FkcCriY6EkpcK6r6bK+A5FBUMI7qY= +gomodules.xyz/jsonpatch/v2 v2.2.0/go.mod h1:WXp+iVDkoLQqPudfQ9GBlwB2eZ5DKOnjQZCYdOS8GPY= google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE= google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M= google.golang.org/api v0.8.0/go.mod h1:o4eAsZoiT+ibD93RtjEohWalFOjRDx6CVaqeizhEnKg= @@ -794,14 +828,27 @@ google.golang.org/api v0.14.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsb google.golang.org/api v0.15.0/go.mod h1:iLdEw5Ide6rF15KTC1Kkl0iskquN2gFfn9o9XIsbkAI= google.golang.org/api v0.17.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= google.golang.org/api v0.18.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.19.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= google.golang.org/api v0.20.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.22.0/go.mod h1:BwFmGc8tA3vsd7r/7kR8DY7iEEGSU04BFxCo5jP/sfE= +google.golang.org/api v0.24.0/go.mod h1:lIXQywCXRcnZPGlsd8NbLnOjtAoL6em04bJ9+z0MncE= +google.golang.org/api v0.28.0/go.mod h1:lIXQywCXRcnZPGlsd8NbLnOjtAoL6em04bJ9+z0MncE= +google.golang.org/api v0.29.0/go.mod h1:Lcubydp8VUV7KeIHD9z2Bys/sm/vGKnG1UHuDBSrHWM= +google.golang.org/api v0.30.0/go.mod h1:QGmEvQ87FHZNiUVJkT14jQNYJ4ZJjdRF23ZXz5138Fc= +google.golang.org/api v0.35.0/go.mod h1:/XrVsuzM0rZmrsbjJutiuftIzeuTQcEeaYcSk/mQ1dg= +google.golang.org/api v0.36.0/go.mod h1:+z5ficQTmoYpPn8LCUNVpK5I7hwkpjbcgqA7I34qYtE= +google.golang.org/api v0.40.0/go.mod h1:fYKFpnQN0DsDSKRVRcQSDQNtqWPfM9i+zNPxepjRCQ8= +google.golang.org/api v0.41.0/go.mod h1:RkxM5lITDfTzmyKFPt+wGrCJbVfniCr2ool8kTBzRTU= +google.golang.org/api v0.43.0/go.mod h1:nQsDGjRXMo4lvh5hP0TKqF244gqhGcr/YSIykhUk/94= +google.golang.org/api v0.44.0/go.mod h1:EBOGZqzyhtvMDoxwS97ctnh0zUmYY6CxqXsc1AvkYD8= 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= google.golang.org/appengine v1.6.1/go.mod h1:i06prIuMbXzDqacNJfV5OdTW448YApPu5ww/cMBSeb0= google.golang.org/appengine v1.6.5/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= -google.golang.org/appengine v1.6.6 h1:lMO5rYAqUxkmaj76jAkRUvt5JZgFymx/+Q5Mzfivuhc= google.golang.org/appengine v1.6.6/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= +google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6c= +google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc= google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc= google.golang.org/genproto v0.0.0-20190307195333-5fe7a883aa19/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE= @@ -819,18 +866,52 @@ google.golang.org/genproto v0.0.0-20200122232147-0452cf42e150/go.mod h1:n3cpQtvx google.golang.org/genproto v0.0.0-20200204135345-fa8e72b47b90/go.mod h1:GmwEX6Z4W5gMy59cAlVYjN9JhxgbQH6Gn+gFDQe2lzA= google.golang.org/genproto v0.0.0-20200212174721-66ed5ce911ce/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= google.golang.org/genproto v0.0.0-20200224152610-e50cd9704f63/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200228133532-8c2c7df3a383/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= google.golang.org/genproto v0.0.0-20200305110556-506484158171/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200312145019-da6875a35672/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c= +google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U= google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo= +google.golang.org/genproto v0.0.0-20200618031413-b414f8b61790/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA= +google.golang.org/genproto v0.0.0-20200729003335-053ba62fc06f/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20200804131852-c06518451d9c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20200825200019-8632dd797987/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20200904004341-0bd0a958aa1d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201019141844-1ed22bb0c154/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201109203340-2640f1f9cdfb/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= google.golang.org/genproto v0.0.0-20201110150050-8816d57aaa9a/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201201144952-b05cb90ed32e/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201210142538-e3217bee35cc/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20201214200347-8c77b98c765d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210222152913-aa3ee6e6a81c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210303154014-9728d6b83eeb/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210310155132-4ce2db91004e/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210319143718-93e7006c17a6/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no= +google.golang.org/genproto v0.0.0-20210402141018-6c239bbf2bb1/go.mod h1:9lPAdzaEmUacj36I+k7YKbEc5CXzPIeORRgDAUOu28A= +google.golang.org/genproto v0.0.0-20210602131652-f16073e35f0c/go.mod h1:UODoCrxHCcBojKKwX1terBiRUaqAsFqJiF615XL43r0= google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c= google.golang.org/grpc v1.20.1/go.mod h1:10oTOabMzJvdu6/UiuZezV6QK5dSlG84ov/aaiqXj38= -google.golang.org/grpc v1.21.0/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= google.golang.org/grpc v1.21.1/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ijfRaM= google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= -google.golang.org/grpc v1.23.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg= +google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY= google.golang.org/grpc v1.26.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= google.golang.org/grpc v1.27.1/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk= +google.golang.org/grpc v1.28.0/go.mod h1:rpkK4SK4GF4Ach/+MFLZUBavHOvF2JJB5uozKKal+60= +google.golang.org/grpc v1.29.1/go.mod h1:itym6AZVZYACWQqET3MqgPpjcuV5QH3BxFS3IjizoKk= +google.golang.org/grpc v1.30.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.31.0/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.31.1/go.mod h1:N36X2cJ7JwdamYAgDz+s+rVMFjt3numwzf/HckM8pak= +google.golang.org/grpc v1.33.1/go.mod h1:fr5YgcSWrqhRRxogOsw7RzIpsmvOZ6IcH4kBYTpR3n0= +google.golang.org/grpc v1.33.2/go.mod h1:JMHMWHQWaTccqQQlmk3MJZS+GWXOdAesneDmEnv2fbc= +google.golang.org/grpc v1.34.0/go.mod h1:WotjhfgOW/POjDeRt8vscBtXq+2VjORFy659qA51WJ8= +google.golang.org/grpc v1.35.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= +google.golang.org/grpc v1.36.0/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= +google.golang.org/grpc v1.36.1/go.mod h1:qjiiYl8FncCW8feJPdyg3v6XW24KsRHe+dy9BAGRRjU= +google.golang.org/grpc v1.38.0/go.mod h1:NREThFqKR1f3iQ6oBuvc5LadQuXVGo9rkm5ZGrQdJfM= google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8= google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0= google.golang.org/protobuf v0.0.0-20200228230310-ab0ca4ff8a60/go.mod h1:cfTl7dwQJ+fmap5saPgwCLgHXTUD7jkjRqWcaiX5VyM= @@ -840,8 +921,10 @@ google.golang.org/protobuf v1.22.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2 google.golang.org/protobuf v1.23.0/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= google.golang.org/protobuf v1.23.1-0.20200526195155-81db48ad09cc/go.mod h1:EGpADcykh3NcUnDUJcl1+ZksZNG86OlYog2l/sGQquU= google.golang.org/protobuf v1.24.0/go.mod h1:r/3tXBNzIEhYS9I1OUVjXDlt8tc493IdKGjtUeSXeh4= -google.golang.org/protobuf v1.25.0 h1:Ejskq+SyPohKW+1uil0JJMtmHCgJPJ/qWTxr8qp+R4c= google.golang.org/protobuf v1.25.0/go.mod h1:9JNX74DMeImyA3h4bdi1ymwjUzf21/xIlbajtzgsN7c= +google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= +google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk= +google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= gopkg.in/alecthomas/kingpin.v2 v2.2.6 h1:jMFz6MfLP0/4fUyZle81rXUoxOBFi19VUFKVDOQfozc= gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= @@ -853,10 +936,10 @@ gopkg.in/cheggaaa/pb.v1 v1.0.25/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qS gopkg.in/cheggaaa/pb.v1 v1.0.27/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qStrOgw= gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI= gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys= -gopkg.in/inf.v0 v0.9.0/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc= gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= gopkg.in/ini.v1 v1.51.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= +gopkg.in/ini.v1 v1.62.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k= gopkg.in/resty.v1 v1.12.0/go.mod h1:mDo4pnntr5jdWRML875a/NmxYqAlA73dVijT2AXvQQo= gopkg.in/square/go-jose.v2 v2.2.2/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI= @@ -865,95 +948,60 @@ gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWD gopkg.in/yaml.v2 v2.0.0-20170812160011-eb3733d160e7/go.mod h1:JAlM8MvJe8wmxCU4Bli9HhUf9+ttbYbLASfIpnQbh74= gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.2.3/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.4/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.5/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v2 v2.3.0 h1:clyUAQHOM3G0M3f5vQj7LuJrETvjVot3Z5el9nffUtU= gopkg.in/yaml.v2 v2.3.0/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= -gopkg.in/yaml.v3 v3.0.0-20190905181640-827449938966/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= +gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= -gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776 h1:tQIYjPdBoyREyB9XMu+nnTclpTYkz2zFM+lzLJFO4gQ= gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= -gotest.tools v2.2.0+incompatible/go.mod h1:DsYFclhRJ6vuDpmuTbkuFWG+y2sxOXAzmJt81HFBacw= +gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b h1:h8qDotaEPuJATrMmW04NCwg7v22aHH28wwpauUhK9Oo= +gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gotest.tools/v3 v3.0.2/go.mod h1:3SzNCllyD9/Y+b5r9JIKQ474KzkZyqLqEfYqMsX94Bk= +gotest.tools/v3 v3.0.3/go.mod h1:Z7Lb0S5l+klDB31fvDQX8ss/FlKDxtlFlw3Oa8Ymbl8= honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.0-20190418001031-e561f6794a2a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg= -honnef.co/go/tools v0.0.1-2020.1.3 h1:sXmLre5bzIR6ypkjXCDI3jHPssRhc8KD/Ome589sc3U= honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= -k8s.io/api v0.0.0-20190918155943-95b840bb6a1f/go.mod h1:uWuOHnjmNrtQomJrvEBg0c0HRNyQ+8KTEERVsK0PW48= -k8s.io/api v0.18.2/go.mod h1:SJCWI7OLzhZSvbY7U8zwNl9UA4o1fizoug34OV/2r78= -k8s.io/api v0.20.1 h1:ud1c3W3YNzGd6ABJlbFfKXBKXO+1KdGfcgGGNgFR03E= -k8s.io/api v0.20.1/go.mod h1:KqwcCVogGxQY3nBlRpwt+wpAMF/KjaCc7RpywacvqUo= -k8s.io/apiextensions-apiserver v0.0.0-20190918161926-8f644eb6e783/go.mod h1:xvae1SZB3E17UpV59AWc271W/Ph25N+bjPyR63X6tPY= -k8s.io/apiextensions-apiserver v0.18.2/go.mod h1:q3faSnRGmYimiocj6cHQ1I3WpLqmDgJFlKL37fC4ZvY= -k8s.io/apiextensions-apiserver v0.20.1 h1:ZrXQeslal+6zKM/HjDXLzThlz/vPSxrfK3OqL8txgVQ= -k8s.io/apiextensions-apiserver v0.20.1/go.mod h1:ntnrZV+6a3dB504qwC5PN/Yg9PBiDNt1EVqbW2kORVk= -k8s.io/apimachinery v0.0.0-20190913080033-27d36303b655/go.mod h1:nL6pwRT8NgfF8TT68DBI8uEePRt89cSvoXUVqbkWHq4= -k8s.io/apimachinery v0.18.2/go.mod h1:9SnR/e11v5IbyPCGbvJViimtJ0SwHG4nfZFjU77ftcA= -k8s.io/apimachinery v0.20.1/go.mod h1:WlLqWAHZGg07AeltaI0MV5uk1Omp8xaN0JGLY6gkRpU= -k8s.io/apimachinery v0.20.2 h1:hFx6Sbt1oG0n6DZ+g4bFt5f6BoMkOjKWsQFu077M3Vg= -k8s.io/apimachinery v0.20.2/go.mod h1:WlLqWAHZGg07AeltaI0MV5uk1Omp8xaN0JGLY6gkRpU= -k8s.io/apiserver v0.0.0-20190918160949-bfa5e2e684ad/go.mod h1:XPCXEwhjaFN29a8NldXA901ElnKeKLrLtREO9ZhFyhg= -k8s.io/apiserver v0.18.2/go.mod h1:Xbh066NqrZO8cbsoenCwyDJ1OSi8Ag8I2lezeHxzwzw= -k8s.io/apiserver v0.20.1/go.mod h1:ro5QHeQkgMS7ZGpvf4tSMx6bBOgPfE+f52KwvXfScaU= -k8s.io/client-go v0.0.0-20190918160344-1fbdaa4c8d90/go.mod h1:J69/JveO6XESwVgG53q3Uz5OSfgsv4uxpScmmyYOOlk= -k8s.io/client-go v0.18.2/go.mod h1:Xcm5wVGXX9HAA2JJ2sSBUn3tCJ+4SVlCbl2MNNv+CIU= -k8s.io/client-go v0.20.1 h1:Qquik0xNFbK9aUG92pxHYsyfea5/RPO9o9bSywNor+M= -k8s.io/client-go v0.20.1/go.mod h1:/zcHdt1TeWSd5HoUe6elJmHSQ6uLLgp4bIJHVEuy+/Y= -k8s.io/code-generator v0.0.0-20190912054826-cd179ad6a269/go.mod h1:V5BD6M4CyaN5m+VthcclXWsVcT1Hu+glwa1bi3MIsyE= -k8s.io/code-generator v0.18.2/go.mod h1:+UHX5rSbxmR8kzS+FAv7um6dtYrZokQvjHpDSYRVkTc= -k8s.io/code-generator v0.20.1/go.mod h1:UsqdF+VX4PU2g46NC2JRs4gc+IfrctnwHb76RNbWHJg= -k8s.io/component-base v0.0.0-20190918160511-547f6c5d7090/go.mod h1:933PBGtQFJky3TEwYx4aEPZ4IxqhWh3R6DCmzqIn1hA= -k8s.io/component-base v0.18.2/go.mod h1:kqLlMuhJNHQ9lz8Z7V5bxUUtjFZnrypArGl58gmDfUM= -k8s.io/component-base v0.20.1 h1:6OQaHr205NSl24t5wOF2IhdrlxZTWEZwuGlLvBgaeIg= -k8s.io/component-base v0.20.1/go.mod h1:guxkoJnNoh8LNrbtiQOlyp2Y2XFCZQmrcg2n/DeYNLk= -k8s.io/gengo v0.0.0-20190128074634-0689ccc1d7d6/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= -k8s.io/gengo v0.0.0-20190822140433-26a664648505/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= -k8s.io/gengo v0.0.0-20200114144118-36b2048a9120/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= +honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k= +k8s.io/api v0.21.3 h1:cblWILbLO8ar+Fj6xdDGr603HRsf8Wu9E9rngJeprZQ= +k8s.io/api v0.21.3/go.mod h1:hUgeYHUbBp23Ue4qdX9tR8/ANi/g3ehylAqDn9NWVOg= +k8s.io/apiextensions-apiserver v0.21.3 h1:+B6biyUWpqt41kz5x6peIsljlsuwvNAp/oFax/j2/aY= +k8s.io/apiextensions-apiserver v0.21.3/go.mod h1:kl6dap3Gd45+21Jnh6utCx8Z2xxLm8LGDkprcd+KbsE= +k8s.io/apimachinery v0.21.3 h1:3Ju4nvjCngxxMYby0BimUk+pQHPOQp3eCGChk5kfVII= +k8s.io/apimachinery v0.21.3/go.mod h1:H/IM+5vH9kZRNJ4l3x/fXP/5bOPJaVP/guptnZPeCFI= +k8s.io/apiserver v0.21.3/go.mod h1:eDPWlZG6/cCCMj/JBcEpDoK+I+6i3r9GsChYBHSbAzU= +k8s.io/client-go v0.21.3 h1:J9nxZTOmvkInRDCzcSNQmPJbDYN/PjlxXT9Mos3HcLg= +k8s.io/client-go v0.21.3/go.mod h1:+VPhCgTsaFmGILxR/7E1N0S+ryO010QBeNCv5JwRGYU= +k8s.io/code-generator v0.21.3/go.mod h1:K3y0Bv9Cz2cOW2vXUrNZlFbflhuPvuadW6JdnN6gGKo= +k8s.io/component-base v0.21.3 h1:4WuuXY3Npa+iFfi2aDRiOz+anhNvRfye0859ZgfC5Og= +k8s.io/component-base v0.21.3/go.mod h1:kkuhtfEHeZM6LkX0saqSK8PbdO7A0HigUngmhhrwfGQ= k8s.io/gengo v0.0.0-20200413195148-3a45101e95ac/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0= -k8s.io/gengo v0.0.0-20201113003025-83324d819ded/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E= -k8s.io/klog v0.0.0-20181102134211-b9b56d5dfc92/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= -k8s.io/klog v0.3.0/go.mod h1:Gq+BEi5rUBO/HRz0bTSXDUcqjScdoY3a9IHpCEIOOfk= -k8s.io/klog v0.4.0/go.mod h1:4Bi6QPql/J/LkTDqv7R/cd3hPo4k2DG6Ptcz060Ez5I= -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/gengo v0.0.0-20201214224949-b6c5ce23f027/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E= k8s.io/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE= k8s.io/klog/v2 v2.2.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y= -k8s.io/klog/v2 v2.4.0 h1:7+X0fUguPyrKEC4WjH8iGDg3laWgMo5tMnRTIGTTxGQ= -k8s.io/klog/v2 v2.4.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y= -k8s.io/kube-openapi v0.0.0-20190816220812-743ec37842bf/go.mod h1:1TqjTSzOxsLGIKfj0lK8EeCP7K1iUG65v09OM0/WG5E= -k8s.io/kube-openapi v0.0.0-20200121204235-bf4fb3bd569c/go.mod h1:GRQhZsXIAJ1xR0C9bd8UpWHZ5plfAS9fzPjJuQ6JL3E= -k8s.io/kube-openapi v0.0.0-20201113171705-d219536bb9fd h1:sOHNzJIkytDF6qadMNKhhDRpc6ODik8lVC6nOur7B2c= -k8s.io/kube-openapi v0.0.0-20201113171705-d219536bb9fd/go.mod h1:WOJ3KddDSol4tAGcJo0Tvi+dK12EcqSLqcWsryKMpfM= -k8s.io/utils v0.0.0-20190801114015-581e00157fb1/go.mod h1:sZAwmy6armz5eXlNoLmJcl4F1QuKu7sr+mFQ0byX7Ew= -k8s.io/utils v0.0.0-20200324210504-a9aa75ae1b89/go.mod h1:sZAwmy6armz5eXlNoLmJcl4F1QuKu7sr+mFQ0byX7Ew= -k8s.io/utils v0.0.0-20201110183641-67b214c5f920 h1:CbnUZsM497iRC5QMVkHwyl8s2tB3g7yaSHkYPkpgelw= +k8s.io/klog/v2 v2.8.0 h1:Q3gmuM9hKEjefWFFYF0Mat+YyFJvsUyYuwyNNJ5C9Ts= +k8s.io/klog/v2 v2.8.0/go.mod h1:hy9LJ/NvuK+iVyP4Ehqva4HxZG/oXyIS3n3Jmire4Ec= +k8s.io/kube-openapi v0.0.0-20210305001622-591a79e4bda7 h1:vEx13qjvaZ4yfObSSXW7BrMc/KQBBT/Jyee8XtLf4x0= +k8s.io/kube-openapi v0.0.0-20210305001622-591a79e4bda7/go.mod h1:wXW5VT87nVfh/iLV8FpR2uDvrFyomxbtb1KivDbvPTE= k8s.io/utils v0.0.0-20201110183641-67b214c5f920/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= -modernc.org/cc v1.0.0/go.mod h1:1Sk4//wdnYJiUIxnW8ddKpaOJCF37yAdqYnkxUpaYxw= -modernc.org/golex v1.0.0/go.mod h1:b/QX9oBD/LhixY6NDh+IdGv17hgB+51fET1i2kPSmvk= -modernc.org/mathutil v1.0.0/go.mod h1:wU0vUrJsVWBZ4P6e7xtFJEhFSNsfRLJ8H458uRjg03k= -modernc.org/strutil v1.0.0/go.mod h1:lstksw84oURvj9y3tn8lGvRxyRC1S2+g5uuIzNfIOBs= -modernc.org/xc v1.0.0/go.mod h1:mRNCo0bvLjGhHO9WsyuKVU4q0ceiDDDoEeWDJHrNx8I= +k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471 h1:DnzUXII7sVg1FJ/4JX6YDRJfLNAC7idRatPwe07suiI= +k8s.io/utils v0.0.0-20210722164352-7f3ee0f31471/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA= rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8= rsc.io/quote/v3 v3.1.0/go.mod h1:yEA65RcK8LyAZtP9Kv3t0HmxON59tX3rD+tICJqUlj0= rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA= -sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.7/go.mod h1:PHgbrJT7lCHcxMU+mDHEm+nx46H4zuuHZkDP6icnhu0= -sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.14/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg= -sigs.k8s.io/controller-runtime v0.8.0 h1:s0dYdo7lQgJiAf+alP82PRwbz+oAqL3oSyMQ18XRDOc= -sigs.k8s.io/controller-runtime v0.8.0/go.mod h1:v9Lbj5oX443uR7GXYY46E0EE2o7k2YxQ58GxVNeXSW4= -sigs.k8s.io/controller-tools v0.2.4/go.mod h1:m/ztfQNocGYBgTTCmFdnK94uVvgxeZeE3LtJvd/jIzA= -sigs.k8s.io/controller-tools v0.4.0 h1:9zIdrc6q9RKke8+DnVPVBVZ+cfF9L0TwM01cxNnklYo= -sigs.k8s.io/controller-tools v0.4.0/go.mod h1:G9rHdZMVlBDocIxGkK3jHLWqcTMNvveypYJwrvYKjWU= -sigs.k8s.io/structured-merge-diff v0.0.0-20190525122527-15d366b2352e/go.mod h1:wWxsB5ozmmv/SG7nM11ayaAW51xMvak/t1r0CSlcokI= -sigs.k8s.io/structured-merge-diff v0.0.0-20190817042607-6149e4549fca h1:6dsH6AYQWbyZmtttJNe8Gq1cXOeS1BdV3eW37zHilAQ= -sigs.k8s.io/structured-merge-diff v0.0.0-20190817042607-6149e4549fca/go.mod h1:IIgPezJWb76P0hotTxzDbWsMYB8APh18qZnxkomBpxA= -sigs.k8s.io/structured-merge-diff/v3 v3.0.0-20200116222232-67a7b8c61874/go.mod h1:PlARxl6Hbt/+BC80dRLi1qAmnMqwqDg62YvvVkZjemw= -sigs.k8s.io/structured-merge-diff/v3 v3.0.0/go.mod h1:PlARxl6Hbt/+BC80dRLi1qAmnMqwqDg62YvvVkZjemw= -sigs.k8s.io/structured-merge-diff/v4 v4.0.2 h1:YHQV7Dajm86OuqnIR6zAelnDWBRjo+YhYV9PmGrh1s8= +sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.19/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg= +sigs.k8s.io/controller-runtime v0.9.6 h1:EevVMlgUj4fC1NVM4+DB3iPkWkmGRNarA66neqv9Qew= +sigs.k8s.io/controller-runtime v0.9.6/go.mod h1:q6PpkM5vqQubEKUKOM6qr06oXGzOBcCby1DA9FbyZeA= +sigs.k8s.io/controller-tools v0.6.2 h1:+Y8L0UsAugDipGRw8lrkPoAi6XqlQVZuf1DQHME3PgU= +sigs.k8s.io/controller-tools v0.6.2/go.mod h1:oaeGpjXn6+ZSEIQkUe/+3I40PNiDYp9aeawbt3xTgJ8= sigs.k8s.io/structured-merge-diff/v4 v4.0.2/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw= +sigs.k8s.io/structured-merge-diff/v4 v4.1.2 h1:Hr/htKFmJEbtMgS/UD0N+gtgctAqz81t3nu+sPzynno= +sigs.k8s.io/structured-merge-diff/v4 v4.1.2/go.mod h1:j/nl6xW8vLS49O8YvXW1ocPhZawJtm+Yrr7PPRQ0Vg4= sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o= sigs.k8s.io/yaml v1.2.0 h1:kr/MCeFWJWTwyaHoR9c8EjH9OumOmoF9YGiZd7lFm/Q= sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc= diff --git a/package/crds/azure.crossplane.io_providerconfigs.yaml b/package/crds/azure.crossplane.io_providerconfigs.yaml index 80289bad..b2b1bc77 100644 --- a/package/crds/azure.crossplane.io_providerconfigs.yaml +++ b/package/crds/azure.crossplane.io_providerconfigs.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: providerconfigs.azure.crossplane.io spec: @@ -26,13 +28,18 @@ spec: name: v1beta1 schema: openAPIV3Schema: - description: A ProviderConfig configures an Azure 'provider', i.e. a connection to a particular Azure account using a particular Azure Service Principal. + description: A ProviderConfig configures an Azure 'provider', i.e. a connection + to a particular Azure account using a particular Azure Service Principal. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -43,7 +50,8 @@ spec: description: Credentials required to authenticate to this provider. properties: env: - description: Env is a reference to an environment variable that contains credentials that must be used to connect to the provider. + description: Env is a reference to an environment variable that + contains credentials that must be used to connect to the provider. properties: name: description: Name is the name of an environment variable. @@ -52,7 +60,8 @@ spec: - name type: object fs: - description: Fs is a reference to a filesystem location that contains credentials that must be used to connect to the provider. + description: Fs is a reference to a filesystem location that contains + credentials that must be used to connect to the provider. properties: path: description: Path is a filesystem path. @@ -61,7 +70,8 @@ spec: - path type: object secretRef: - description: A SecretRef is a reference to a secret key that contains the credentials that must be used to connect to the provider. + description: A SecretRef is a reference to a secret key that contains + the credentials that must be used to connect to the provider. properties: key: description: The key to select. @@ -100,20 +110,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/azure.crossplane.io_providerconfigusages.yaml b/package/crds/azure.crossplane.io_providerconfigusages.yaml index 456fbf4f..087c617e 100644 --- a/package/crds/azure.crossplane.io_providerconfigusages.yaml +++ b/package/crds/azure.crossplane.io_providerconfigusages.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: providerconfigusages.azure.crossplane.io spec: @@ -37,10 +39,14 @@ spec: description: A ProviderConfigUsage indicates that a resource is using a ProviderConfig. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -54,7 +60,8 @@ spec: - name type: object resourceRef: - description: ResourceReference to the managed resource using the provider config. + description: ResourceReference to the managed resource using the provider + config. properties: apiVersion: description: APIVersion of the referenced object. diff --git a/package/crds/azure.crossplane.io_providers.yaml b/package/crds/azure.crossplane.io_providers.yaml index e55d0f31..c208477e 100644 --- a/package/crds/azure.crossplane.io_providers.yaml +++ b/package/crds/azure.crossplane.io_providers.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: providers.azure.crossplane.io spec: @@ -26,13 +28,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A Provider configures an Azure 'provider', i.e. a connection to a particular Azure account using a particular Azure Service Principal. + description: A Provider configures an Azure 'provider', i.e. a connection + to a particular Azure account using a particular Azure Service Principal. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -40,7 +47,9 @@ spec: description: A ProviderSpec defines the desired state of a Provider. properties: credentialsSecretRef: - description: CredentialsSecretRef references a specific secret's key that contains the credentials that are used to connect to the Azure API. + description: CredentialsSecretRef references a specific secret's key + that contains the credentials that are used to connect to the Azure + API. properties: key: description: The key to select. diff --git a/package/crds/azure.crossplane.io_resourcegroups.yaml b/package/crds/azure.crossplane.io_resourcegroups.yaml index 805cf5a4..88bb250d 100644 --- a/package/crds/azure.crossplane.io_resourcegroups.yaml +++ b/package/crds/azure.crossplane.io_resourcegroups.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: resourcegroups.azure.crossplane.io spec: @@ -28,13 +30,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A ResourceGroup is a managed resource that represents an Azure Resource Group. + description: A ResourceGroup is a managed resource that represents an Azure + Resource Group. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -43,18 +50,23 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string location: - description: Location of the resource group. See the official list of valid regions - https://azure.microsoft.com/en-us/global-infrastructure/regions/ + description: Location of the resource group. See the official list + of valid regions - https://azure.microsoft.com/en-us/global-infrastructure/regions/ type: string providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -63,7 +75,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -72,7 +86,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -88,7 +106,8 @@ spec: - location type: object status: - description: A ResourceGroupStatus represents the observed status of a ResourceGroup. + description: A ResourceGroupStatus represents the observed status of a + ResourceGroup. properties: conditions: description: Conditions of the resource. @@ -96,20 +115,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -119,7 +143,8 @@ spec: type: object type: array provisioningState: - description: ProvisioningState - The provisioning state of the resource group. + description: ProvisioningState - The provisioning state of the resource + group. type: string type: object required: diff --git a/package/crds/cache.azure.crossplane.io_redis.yaml b/package/crds/cache.azure.crossplane.io_redis.yaml index dc9a5c2f..3a477130 100644 --- a/package/crds/cache.azure.crossplane.io_redis.yaml +++ b/package/crds/cache.azure.crossplane.io_redis.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: redis.cache.azure.crossplane.io spec: @@ -37,13 +39,18 @@ spec: name: v1beta1 schema: openAPIV3Schema: - description: A Redis is a managed resource that represents an Azure Redis cluster. + description: A Redis is a managed resource that represents an Azure Redis + cluster. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -52,27 +59,40 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: RedisParameters define the desired state of an Azure Redis cluster. https://docs.microsoft.com/en-us/rest/api/redis/redis/create#redisresource + description: RedisParameters define the desired state of an Azure + Redis cluster. https://docs.microsoft.com/en-us/rest/api/redis/redis/create#redisresource properties: enableNonSslPort: - description: EnableNonSSLPort specifies whether the non-ssl Redis server port (6379) is enabled. + description: EnableNonSSLPort specifies whether the non-ssl Redis + server port (6379) is enabled. type: boolean location: description: Location in which to create this resource. type: string minimumTlsVersion: - description: 'MinimumTLSVersion - Optional: requires clients to use a specified TLS version (or higher) to connect (e,g, ''1.0'', ''1.1'', ''1.2''). Possible values include: ''OneFullStopZero'', ''OneFullStopOne'', ''OneFullStopTwo''' + description: 'MinimumTLSVersion - Optional: requires clients to + use a specified TLS version (or higher) to connect (e,g, ''1.0'', + ''1.1'', ''1.2''). Possible values include: ''OneFullStopZero'', + ''OneFullStopOne'', ''OneFullStopTwo''' type: string redisConfiguration: additionalProperties: type: string - description: 'RedisConfiguration - All Redis Settings. Few possible keys: rdb-backup-enabled,rdb-storage-connection-string,rdb-backup-frequency maxmemory-delta,maxmemory-policy,notify-keyspace-events,maxmemory-samples, slowlog-log-slower-than,slowlog-max-len,list-max-ziplist-entries, list-max-ziplist-value,hash-max-ziplist-entries,hash-max-ziplist-value, set-max-intset-entries,zset-max-ziplist-entries,zset-max-ziplist-value etc.' + description: 'RedisConfiguration - All Redis Settings. Few possible + keys: rdb-backup-enabled,rdb-storage-connection-string,rdb-backup-frequency + maxmemory-delta,maxmemory-policy,notify-keyspace-events,maxmemory-samples, + slowlog-log-slower-than,slowlog-max-len,list-max-ziplist-entries, + list-max-ziplist-value,hash-max-ziplist-entries,hash-max-ziplist-value, + set-max-intset-entries,zset-max-ziplist-entries,zset-max-ziplist-value + etc.' type: object resourceGroupName: description: ResourceGroupName in which to create this resource. @@ -87,36 +107,45 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector to select a reference to a resource group. + description: ResourceGroupNameSelector to select a reference to + a resource group. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object shardCount: - description: ShardCount specifies the number of shards to be created on a Premium Cluster Cache. + description: ShardCount specifies the number of shards to be created + on a Premium Cluster Cache. type: integer sku: description: Sku - The SKU of the Redis cache to deploy. properties: capacity: - description: 'Capacity specifies the size of Redis cache to deploy. Valid values: for C family (0, 1, 2, 3, 4, 5, 6), for P family (1, 2, 3, 4).' + description: 'Capacity specifies the size of Redis cache to + deploy. Valid values: for C family (0, 1, 2, 3, 4, 5, 6), + for P family (1, 2, 3, 4).' maximum: 6 minimum: 0 type: integer family: - description: 'Family specifies which family to use. Valid values: (C, P). Possible values include: ''C'', ''P''' + description: 'Family specifies which family to use. Valid + values: (C, P). Possible values include: ''C'', ''P''' enum: - C - P type: string name: - description: 'Name specifies what type of Redis cache to deploy. Valid values: (Basic, Standard, Premium). Possible values include: ''Basic'', ''Standard'', ''Premium''' + description: 'Name specifies what type of Redis cache to deploy. + Valid values: (Basic, Standard, Premium). Possible values + include: ''Basic'', ''Standard'', ''Premium''' enum: - Basic - Standard @@ -128,10 +157,13 @@ spec: - name type: object staticIp: - description: StaticIP address. Required when deploying a Redis cache inside an existing Azure Virtual Network. + description: StaticIP address. Required when deploying a Redis + cache inside an existing Azure Virtual Network. type: string subnetId: - description: 'SubnetID specifies the full resource ID of a subnet in a virtual network to deploy the Redis cache in. Example format: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/Microsoft.{Network|ClassicNetwork}/VirtualNetworks/vnet1/subnets/subnet1' + description: 'SubnetID specifies the full resource ID of a subnet + in a virtual network to deploy the Redis cache in. Example format: + /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/Microsoft.{Network|ClassicNetwork}/VirtualNetworks/vnet1/subnets/subnet1' type: string tags: additionalProperties: @@ -144,7 +176,8 @@ spec: description: TenantSettings - A dictionary of tenant settings type: object zones: - description: Zones - A list of availability zones denoting where the resource needs to come from. + description: Zones - A list of availability zones denoting where + the resource needs to come from. items: type: string type: array @@ -155,7 +188,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -164,7 +199,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -173,7 +210,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -192,7 +233,8 @@ spec: description: A RedisStatus represents the observed state of a Redis. properties: atProvider: - description: RedisObservation represents the observed state of the Redis object in Azure. + description: RedisObservation represents the observed state of the + Redis object in Azure. properties: hostName: description: HostName - Redis host name. @@ -201,7 +243,8 @@ spec: description: ID - Resource ID. type: string linkedServers: - description: LinkedServers - List of the linked servers associated with the cache + description: LinkedServers - List of the linked servers associated + with the cache items: type: string type: array @@ -212,7 +255,11 @@ spec: description: Port - Redis non-SSL port. type: integer provisioningState: - description: 'ProvisioningState - Redis instance provisioning status. Possible values include: ''Creating'', ''Deleting'', ''Disabled'', ''Failed'', ''Linking'', ''Provisioning'', ''RecoveringScaleFailure'', ''Scaling'', ''Succeeded'', ''Unlinking'', ''Unprovisioning'', ''Updating''' + description: 'ProvisioningState - Redis instance provisioning + status. Possible values include: ''Creating'', ''Deleting'', + ''Disabled'', ''Failed'', ''Linking'', ''Provisioning'', ''RecoveringScaleFailure'', + ''Scaling'', ''Succeeded'', ''Unlinking'', ''Unprovisioning'', + ''Updating''' type: string redisVersion: description: RedisVersion - Redis version. @@ -227,20 +274,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/compute.azure.crossplane.io_aksclusters.yaml b/package/crds/compute.azure.crossplane.io_aksclusters.yaml index 7bc7c1ca..8b78464d 100644 --- a/package/crds/compute.azure.crossplane.io_aksclusters.yaml +++ b/package/crds/compute.azure.crossplane.io_aksclusters.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: aksclusters.compute.azure.crossplane.io spec: @@ -37,13 +39,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: An AKSCluster is a managed resource that represents an Azure Kubernetes Engine cluster. + description: An AKSCluster is a managed resource that represents an Azure + Kubernetes Engine cluster. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -52,32 +59,44 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string disableRBAC: - description: DisableRBAC determines whether RBAC will be disabled or enabled in the cluster. + description: DisableRBAC determines whether RBAC will be disabled + or enabled in the cluster. type: boolean dnsNamePrefix: - description: DNSNamePrefix is the DNS name prefix to use with the hosted Kubernetes API server FQDN. You will use this to connect to the Kubernetes API when managing containers after creating the cluster. + description: DNSNamePrefix is the DNS name prefix to use with the + hosted Kubernetes API server FQDN. You will use this to connect + to the Kubernetes API when managing containers after creating the + cluster. type: string location: - description: Location is the Azure location that the cluster will be created in + description: Location is the Azure location that the cluster will + be created in type: string nodeCount: - description: NodeCount is the number of nodes that the cluster will initially be created with. This can be scaled over time and defaults to 1. + description: NodeCount is the number of nodes that the cluster will + initially be created with. This can be scaled over time and defaults + to 1. maximum: 100 minimum: 0 type: integer nodeVMSize: - description: NodeVMSize is the name of the worker node VM size, e.g., Standard_B2s, Standard_F2s_v2, etc. + description: NodeVMSize is the name of the worker node VM size, e.g., + Standard_B2s, Standard_F2s_v2, etc. type: string providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -86,7 +105,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -95,10 +116,12 @@ spec: - name type: object resourceGroupName: - description: ResourceGroupName is the name of the resource group that the cluster will be created in + description: ResourceGroupName is the name of the resource group that + the cluster will be created in type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + to retrieve its name properties: name: description: Name of the referenced object. @@ -107,25 +130,31 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Select a reference to a ResourceGroup to retrieve its name + description: ResourceGroupNameSelector - Select a reference to a ResourceGroup + to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object version: - description: Version is the Kubernetes version that will be deployed to the cluster + description: Version is the Kubernetes version that will be deployed + to the cluster type: string vnetSubnetID: - description: VnetSubnetID is the subnet to which the cluster will be deployed. + description: VnetSubnetID is the subnet to which the cluster will + be deployed. type: string vnetSubnetIDRef: - description: ResourceGroupNameRef - A reference to a Subnet to retrieve its ID + description: ResourceGroupNameRef - A reference to a Subnet to retrieve + its ID properties: name: description: Name of the referenced object. @@ -134,19 +163,26 @@ spec: - name type: object vnetSubnetIDSelector: - description: ResourceGroupNameSelector - Select a reference to a Subnet to retrieve its ID + description: ResourceGroupNameSelector - Select a reference to a Subnet + to retrieve its ID properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -171,20 +207,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -197,7 +238,8 @@ spec: description: Endpoint is the endpoint where the cluster can be reached type: string providerID: - description: ProviderID is the external ID to identify this resource in the cloud provider. + description: ProviderID is the external ID to identify this resource + in the cloud provider. type: string state: description: State is the current state of the cluster. diff --git a/package/crds/database.azure.crossplane.io_cosmosdbaccounts.yaml b/package/crds/database.azure.crossplane.io_cosmosdbaccounts.yaml index f4676495..cf1c6385 100644 --- a/package/crds/database.azure.crossplane.io_cosmosdbaccounts.yaml +++ b/package/crds/database.azure.crossplane.io_cosmosdbaccounts.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: cosmosdbaccounts.database.azure.crossplane.io spec: @@ -37,81 +39,124 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A CosmosDBAccount is a managed resource that represents an Azure CosmosDB account with CosmosDB API. + description: A CosmosDBAccount is a managed resource that represents an Azure + CosmosDB account with CosmosDB API. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A CosmosDBAccountSpec defines the desired state of a CosmosDB Account. + description: A CosmosDBAccountSpec defines the desired state of a CosmosDB + Account. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: CosmosDBAccountParameters define the desired state of an Azure CosmosDB account. + description: CosmosDBAccountParameters define the desired state of + an Azure CosmosDB account. properties: kind: description: Kind - Indicates the type of database account. type: string location: - description: Location - The location of the resource. This will be one of the supported and registered Azure Geo Regions (e.g. West US, East US, Southeast Asia, etc.). + description: Location - The location of the resource. This will + be one of the supported and registered Azure Geo Regions (e.g. + West US, East US, Southeast Asia, etc.). type: string properties: - description: Properties - Account properties like databaseAccountOfferType, ipRangeFilters, etc. + description: Properties - Account properties like databaseAccountOfferType, + ipRangeFilters, etc. properties: consistencyPolicy: - description: ConsistencyPolicy - The consistency policy for the Cosmos DB account. + description: ConsistencyPolicy - The consistency policy for + the Cosmos DB account. properties: defaultConsistencyLevel: - description: 'DefaultConsistencyLevel - The default consistency level and configuration settings of the Cosmos DB account. Possible values include: ''Eventual'', ''Session'', ''BoundedStaleness'', ''Strong'', ''ConsistentPrefix''' + description: 'DefaultConsistencyLevel - The default consistency + level and configuration settings of the Cosmos DB account. + Possible values include: ''Eventual'', ''Session'', + ''BoundedStaleness'', ''Strong'', ''ConsistentPrefix''' type: string maxIntervalInSeconds: - description: MaxIntervalInSeconds - When used with the Bounded Staleness consistency level, this value represents the time amount of staleness (in seconds) tolerated. Accepted range for this value is 5 - 86400. Required when defaultConsistencyPolicy is set to 'BoundedStaleness'. + description: MaxIntervalInSeconds - When used with the + Bounded Staleness consistency level, this value represents + the time amount of staleness (in seconds) tolerated. + Accepted range for this value is 5 - 86400. Required + when defaultConsistencyPolicy is set to 'BoundedStaleness'. format: int32 type: integer maxStalenessPrefix: - description: MaxStalenessPrefix - When used with the Bounded Staleness consistency level, this value represents the number of stale requests tolerated. Accepted range for this value is 1 – 2,147,483,647. Required when defaultConsistencyPolicy is set to 'BoundedStaleness'. + description: MaxStalenessPrefix - When used with the Bounded + Staleness consistency level, this value represents the + number of stale requests tolerated. Accepted range for + this value is 1 – 2,147,483,647. Required when defaultConsistencyPolicy + is set to 'BoundedStaleness'. format: int64 type: integer required: - defaultConsistencyLevel type: object databaseAccountOfferType: - description: DatabaseAccountOfferType - The offer type for the database + description: DatabaseAccountOfferType - The offer type for + the database type: string enableAutomaticFailover: - description: EnableAutomaticFailover - Enables automatic failover of the write region in the rare event that the region is unavailable due to an outage. Automatic failover will result in a new write region for the account and is chosen based on the failover priorities configured for the account. + description: EnableAutomaticFailover - Enables automatic failover + of the write region in the rare event that the region is + unavailable due to an outage. Automatic failover will result + in a new write region for the account and is chosen based + on the failover priorities configured for the account. type: boolean enableCassandraConnector: - description: EnableCassandraConnector - Enables the cassandra connector on the Cosmos DB C* account + description: EnableCassandraConnector - Enables the cassandra + connector on the Cosmos DB C* account type: boolean enableMultipleWriteLocations: - description: EnableMultipleWriteLocations - Enables the account to write in multiple locations + description: EnableMultipleWriteLocations - Enables the account + to write in multiple locations type: boolean ipRangeFilter: - description: 'IPRangeFilter - Cosmos DB Firewall Support: This value specifies the set of IP addresses or IP address ranges in CIDR form to be included as the allowed list of client IPs for a given database account. IP addresses/ranges must be comma separated and must not contain any spaces.' + description: 'IPRangeFilter - Cosmos DB Firewall Support: + This value specifies the set of IP addresses or IP address + ranges in CIDR form to be included as the allowed list of + client IPs for a given database account. IP addresses/ranges + must be comma separated and must not contain any spaces.' type: string locations: - description: Locations - An array that contains the georeplication locations enabled for the Cosmos DB account. + description: Locations - An array that contains the georeplication + locations enabled for the Cosmos DB account. items: - description: CosmosDBAccountLocation a region in which the Azure Cosmos DB database account is deployed. + description: CosmosDBAccountLocation a region in which the + Azure Cosmos DB database account is deployed. properties: failoverPriority: - description: FailoverPriority - The failover priority of the region. A failover priority of 0 indicates a write region. The maximum value for a failover priority = (total number of regions - 1). Failover priority values must be unique for each of the regions in which the database account exists. + description: FailoverPriority - The failover priority + of the region. A failover priority of 0 indicates + a write region. The maximum value for a failover priority + = (total number of regions - 1). Failover priority + values must be unique for each of the regions in which + the database account exists. format: int32 type: integer isZoneRedundant: - description: IsZoneRedundant - Flag to indicate whether or not this region is an AvailabilityZone region + description: IsZoneRedundant - Flag to indicate whether + or not this region is an AvailabilityZone region type: boolean locationName: description: LocationName - The name of the region. @@ -127,10 +172,12 @@ spec: - locations type: object resourceGroupName: - description: ResourceGroupName specifies the name of the resource group that should contain this Account. + description: ResourceGroupName specifies the name of the resource + group that should contain this Account. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -139,21 +186,29 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector to select a reference to a resource group. + description: ResourceGroupNameSelector to select a reference to + a resource group. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object tags: additionalProperties: type: string - description: Tags - A list of key value pairs that describe the resource. These tags can be used for viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key with a length no greater than 128 characters and a value with a length no greater than 256 characters. + description: Tags - A list of key value pairs that describe the + resource. These tags can be used for viewing and grouping this + resource (across resource groups). A maximum of 15 tags can + be provided for a resource. Each tag must have a key with a + length no greater than 128 characters and a value with a length + no greater than 256 characters. type: object required: - kind @@ -163,7 +218,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -172,7 +229,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -181,7 +240,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -197,10 +260,12 @@ spec: - forProvider type: object status: - description: An CosmosDBAccountStatus represents the observed state of an Account. + description: An CosmosDBAccountStatus represents the observed state of + an Account. properties: atProvider: - description: CosmosDBAccountObservation shows current state of an Azure CosmosDB account. + description: CosmosDBAccountObservation shows current state of an + Azure CosmosDB account. properties: id: description: Identity - The identity of the resource. @@ -218,20 +283,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_mysqlserverconfigurations.yaml b/package/crds/database.azure.crossplane.io_mysqlserverconfigurations.yaml index 3a9ff9fa..8a21906f 100644 --- a/package/crds/database.azure.crossplane.io_mysqlserverconfigurations.yaml +++ b/package/crds/database.azure.crossplane.io_mysqlserverconfigurations.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: mysqlserverconfigurations.database.azure.crossplane.io spec: @@ -34,37 +36,49 @@ spec: name: v1beta1 schema: openAPIV3Schema: - description: A MySQLServerConfiguration is a managed resource that represents an Azure MySQL Server Configuration. + description: A MySQLServerConfiguration is a managed resource that represents + an Azure MySQL Server Configuration. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A SQLServerConfigurationSpec defines the desired state of a SQLServer Configuration. + description: A SQLServerConfigurationSpec defines the desired state of + a SQLServer Configuration. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: SQLServerConfigurationParameters define the desired state of an Azure SQL Database Server Configuration, either PostgreSQL or MySQL Configuration. + description: SQLServerConfigurationParameters define the desired state + of an Azure SQL Database Server Configuration, either PostgreSQL + or MySQL Configuration. properties: name: description: Name - Configuration name to be applied type: string resourceGroupName: - description: ResourceGroupName specifies the name of the resource group that should contain this SQLServer. + description: ResourceGroupName specifies the name of the resource + group that should contain this SQLServer. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -73,22 +87,27 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - A selector for a ResourceGroup object to retrieve its name + description: ResourceGroupNameSelector - A selector for a ResourceGroup + object to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object serverName: - description: ServerName specifies the name of the server that this configuration applies to. + description: ServerName specifies the name of the server that + this configuration applies to. type: string serverNameRef: - description: ServerNameRef - A reference to a server object to retrieve its name + description: ServerNameRef - A reference to a server object to + retrieve its name properties: name: description: Name of the referenced object. @@ -97,19 +116,23 @@ spec: - name type: object serverNameSelector: - description: ServerNameSelector - A selector for a server object to retrieve its name + description: ServerNameSelector - A selector for a server object + to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object value: - description: Value - Configuration value to be applied Can be left unset to read the current value as a result of late-initialization. + description: Value - Configuration value to be applied Can be + left unset to read the current value as a result of late-initialization. type: string required: - name @@ -117,7 +140,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -126,7 +151,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -135,7 +162,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -151,10 +182,12 @@ spec: - forProvider type: object status: - description: A SQLServerConfigurationStatus represents the observed state of a SQLServerConfiguration. + description: A SQLServerConfigurationStatus represents the observed state + of a SQLServerConfiguration. properties: atProvider: - description: SQLServerConfigurationObservation represents the current state of Azure SQL resource. + description: SQLServerConfigurationObservation represents the current + state of Azure SQL resource. properties: dataType: description: DataType - Data type for the configuration @@ -169,16 +202,20 @@ spec: description: ID - Resource ID type: string lastOperation: - description: LastOperation represents the state of the last operation started by the controller. + description: LastOperation represents the state of the last operation + started by the controller. properties: errorMessage: - description: ErrorMessage represents the error that occurred during the operation. + description: ErrorMessage represents the error that occurred + during the operation. type: string method: - description: Method is HTTP method that the initial request is made with. + description: Method is HTTP method that the initial request + is made with. type: string pollingUrl: - description: PollingURL is used to fetch the status of the given operation. + description: PollingURL is used to fetch the status of the + given operation. type: string status: description: Status represents the status of the operation. @@ -203,20 +240,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_mysqlserverfirewallrules.yaml b/package/crds/database.azure.crossplane.io_mysqlserverfirewallrules.yaml index 8d1977dd..4dce4021 100644 --- a/package/crds/database.azure.crossplane.io_mysqlserverfirewallrules.yaml +++ b/package/crds/database.azure.crossplane.io_mysqlserverfirewallrules.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: mysqlserverfirewallrules.database.azure.crossplane.io spec: @@ -34,47 +36,60 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A MySQLServerFirewallRule is a managed resource that represents an Azure MySQL firewall rule. + description: A MySQLServerFirewallRule is a managed resource that represents + an Azure MySQL firewall rule. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A FirewallRuleSpec defines the desired state of an Azure SQL firewall rule. + description: A FirewallRuleSpec defines the desired state of an Azure + SQL firewall rule. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: FirewallRuleParameters define the desired state of an Azure SQL firewall rule. + description: FirewallRuleParameters define the desired state of an + Azure SQL firewall rule. properties: properties: description: FirewallRuleProperties - Resource properties. properties: endIpAddress: - description: EndIPAddress of the IP range this firewall rule allows. + description: EndIPAddress of the IP range this firewall rule + allows. type: string startIpAddress: - description: StartIPAddress of the IP range this firewall rule allows. + description: StartIPAddress of the IP range this firewall + rule allows. type: string required: - endIpAddress - startIpAddress type: object resourceGroupName: - description: ResourceGroupName - Name of the Firewall Rule's resource group. + description: ResourceGroupName - Name of the Firewall Rule's resource + group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -83,22 +98,26 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Selects a ResourceGroup to reference. + description: ResourceGroupNameSelector - Selects a ResourceGroup + to reference. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object serverName: description: ServerName - Name of the Firewall Rule's server. type: string serverNameRef: - description: ServerNameRef - A reference to the Firewall Rule's MySQLServer. + description: ServerNameRef - A reference to the Firewall Rule's + MySQLServer. properties: name: description: Name of the referenced object. @@ -110,12 +129,14 @@ spec: description: ServerNameSelector - Selects a MySQLServer to reference. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object required: @@ -124,7 +145,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -133,7 +156,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -142,7 +167,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -158,10 +187,12 @@ spec: - forProvider type: object status: - description: A FirewallRuleStatus represents the status of an Azure SQL firewall rule. + description: A FirewallRuleStatus represents the status of an Azure SQL + firewall rule. properties: atProvider: - description: A FirewallRuleObservation represents the observed state of an Azure SQL firewall rule. + description: A FirewallRuleObservation represents the observed state + of an Azure SQL firewall rule. properties: id: description: ID - Resource ID @@ -176,20 +207,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_mysqlservers.yaml b/package/crds/database.azure.crossplane.io_mysqlservers.yaml index 9809a654..a253ac40 100644 --- a/package/crds/database.azure.crossplane.io_mysqlservers.yaml +++ b/package/crds/database.azure.crossplane.io_mysqlservers.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: mysqlservers.database.azure.crossplane.io spec: @@ -34,13 +36,18 @@ spec: name: v1beta1 schema: openAPIV3Schema: - description: A MySQLServer is a managed resource that represents an Azure MySQL Database Server. + description: A MySQLServer is a managed resource that represents an Azure + MySQL Database Server. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -49,19 +56,26 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: SQLServerParameters define the desired state of an Azure SQL Database, either PostgreSQL or MySQL. + description: SQLServerParameters define the desired state of an Azure + SQL Database, either PostgreSQL or MySQL. properties: administratorLogin: - description: AdministratorLogin - The administrator's login name of a server. Can only be specified when the server is being created (and is required for creation). + description: AdministratorLogin - The administrator's login name + of a server. Can only be specified when the server is being + created (and is required for creation). type: string createMode: - description: 'CreateMode - Possible values include: ''CreateModeDefault'', ''CreateModePointInTimeRestore'', ''CreateModeGeoRestore'', ''CreateModeReplica''' + description: 'CreateMode - Possible values include: ''CreateModeDefault'', + ''CreateModePointInTimeRestore'', ''CreateModeGeoRestore'', + ''CreateModeReplica''' enum: - Default - GeoRestore @@ -75,16 +89,20 @@ spec: description: MinimalTLSVersion - control TLS connection policy type: string publicNetworkAccess: - description: PublicNetworkAccess - Whether or not public network access is allowed for this server. Value is optional but if passed in, must be 'Enabled' or 'Disabled'. + description: PublicNetworkAccess - Whether or not public network + access is allowed for this server. Value is optional but if + passed in, must be 'Enabled' or 'Disabled'. enum: - Enabled - Disabled type: string resourceGroupName: - description: ResourceGroupName specifies the name of the resource group that should contain this SQLServer. + description: ResourceGroupName specifies the name of the resource + group that should contain this SQLServer. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -93,35 +111,43 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - A selector for a ResourceGroup object to retrieve its name + description: ResourceGroupNameSelector - A selector for a ResourceGroup + object to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object restorePointInTime: - description: RestorePointInTime - Restore point creation time (RFC3339 format), specifying the time to restore from. + description: RestorePointInTime - Restore point creation time + (RFC3339 format), specifying the time to restore from. format: date-time type: string sku: - description: SKU is the billing information related properties of the server. + description: SKU is the billing information related properties + of the server. properties: capacity: - description: Capacity - The scale up/out capacity, representing server's compute units. + description: Capacity - The scale up/out capacity, representing + server's compute units. type: integer family: description: Family - The family of hardware. type: string size: - description: Size - The size code, to be interpreted by resource as appropriate. + description: Size - The size code, to be interpreted by resource + as appropriate. type: string tier: - description: 'Tier - The tier of the particular SKU. Possible values include: ''Basic'', ''GeneralPurpose'', ''MemoryOptimized''' + description: 'Tier - The tier of the particular SKU. Possible + values include: ''Basic'', ''GeneralPurpose'', ''MemoryOptimized''' enum: - Basic - GeneralPurpose @@ -133,10 +159,12 @@ spec: - tier type: object sourceServerID: - description: SourceServerID - The server to restore from when restoring or creating replicas + description: SourceServerID - The server to restore from when + restoring or creating replicas type: string sslEnforcement: - description: 'SSLEnforcement - Enable ssl enforcement or not when connect to server. Possible values include: ''Enabled'', ''Disabled''' + description: 'SSLEnforcement - Enable ssl enforcement or not when + connect to server. Possible values include: ''Enabled'', ''Disabled''' enum: - Enabled - Disabled @@ -145,16 +173,20 @@ spec: description: StorageProfile - Storage profile of a server. properties: backupRetentionDays: - description: BackupRetentionDays - Backup retention days for the server. + description: BackupRetentionDays - Backup retention days for + the server. type: integer geoRedundantBackup: - description: 'GeoRedundantBackup - Enable Geo-redundant or not for server backup. Possible values include: ''Enabled'', ''Disabled''' + description: 'GeoRedundantBackup - Enable Geo-redundant or + not for server backup. Possible values include: ''Enabled'', + ''Disabled''' enum: - Enabled - Disabled type: string storageAutogrow: - description: 'StorageAutogrow - Enable Storage Auto Grow. Possible values include: ''Enabled'', ''Disabled''' + description: 'StorageAutogrow - Enable Storage Auto Grow. + Possible values include: ''Enabled'', ''Disabled''' enum: - Enabled - Disabled @@ -168,7 +200,8 @@ spec: tags: additionalProperties: type: string - description: Tags - Application-specific metadata in the form of key-value pairs. + description: Tags - Application-specific metadata in the form + of key-value pairs. type: object version: description: Version - Server version. @@ -184,7 +217,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -193,7 +228,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -202,7 +239,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -221,32 +262,39 @@ spec: description: A SQLServerStatus represents the observed state of a SQLServer. properties: atProvider: - description: SQLServerObservation represents the current state of Azure SQL resource. + description: SQLServerObservation represents the current state of + Azure SQL resource. properties: fullyQualifiedDomainName: - description: FullyQualifiedDomainName - The fully qualified domain name of a server. + description: FullyQualifiedDomainName - The fully qualified domain + name of a server. type: string id: description: ID - Resource ID type: string lastOperation: - description: LastOperation represents the state of the last operation started by the controller. + description: LastOperation represents the state of the last operation + started by the controller. properties: errorMessage: - description: ErrorMessage represents the error that occurred during the operation. + description: ErrorMessage represents the error that occurred + during the operation. type: string method: - description: Method is HTTP method that the initial request is made with. + description: Method is HTTP method that the initial request + is made with. type: string pollingUrl: - description: PollingURL is used to fetch the status of the given operation. + description: PollingURL is used to fetch the status of the + given operation. type: string status: description: Status represents the status of the operation. type: string type: object masterServerId: - description: MasterServerID - The master server id of a replica server. + description: MasterServerID - The master server id of a replica + server. type: string name: description: Name - Resource name. @@ -255,7 +303,8 @@ spec: description: Type - Resource type. type: string userVisibleState: - description: UserVisibleState - A state of a server that is visible to user. + description: UserVisibleState - A state of a server that is visible + to user. type: string type: object conditions: @@ -264,20 +313,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_mysqlservervirtualnetworkrules.yaml b/package/crds/database.azure.crossplane.io_mysqlservervirtualnetworkrules.yaml index 769ce2ad..99d8fb18 100644 --- a/package/crds/database.azure.crossplane.io_mysqlservervirtualnetworkrules.yaml +++ b/package/crds/database.azure.crossplane.io_mysqlservervirtualnetworkrules.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: mysqlservervirtualnetworkrules.database.azure.crossplane.io spec: @@ -34,22 +36,30 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A MySQLServerVirtualNetworkRule is a managed resource that represents an Azure MySQL Database virtual network rule. + description: A MySQLServerVirtualNetworkRule is a managed resource that represents + an Azure MySQL Database virtual network rule. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A MySQLVirtualNetworkRuleSpec defines the desired state of a MySQLVirtualNetworkRule. + description: A MySQLVirtualNetworkRuleSpec defines the desired state of + a MySQLVirtualNetworkRule. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -58,13 +68,16 @@ spec: description: VirtualNetworkRuleProperties - Resource properties. properties: ignoreMissingVnetServiceEndpoint: - description: IgnoreMissingVnetServiceEndpoint - Create firewall rule before the virtual network has vnet service endpoint enabled. + description: IgnoreMissingVnetServiceEndpoint - Create firewall + rule before the virtual network has vnet service endpoint enabled. type: boolean virtualNetworkSubnetId: - description: VirtualNetworkSubnetID - The ARM resource id of the virtual network subnet. + description: VirtualNetworkSubnetID - The ARM resource id of the + virtual network subnet. type: string virtualNetworkSubnetIdRef: - description: VirtualNetworkSubnetIDRef - A reference to a Subnet to retrieve its ID + description: VirtualNetworkSubnetIDRef - A reference to a Subnet + to retrieve its ID properties: name: description: Name of the referenced object. @@ -73,22 +86,27 @@ spec: - name type: object virtualNetworkSubnetIdSelector: - description: VirtualNetworkSubnetIDRef - A selector for a Subnet to retrieve its ID + description: VirtualNetworkSubnetIDRef - A selector for a Subnet + to retrieve its ID properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object type: object providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -97,7 +115,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -106,10 +126,12 @@ spec: - name type: object resourceGroupName: - description: ResourceGroupName - Name of the Virtual Network Rule's resource group. + description: ResourceGroupName - Name of the Virtual Network Rule's + resource group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -118,22 +140,26 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Selects a ResourceGroup to reference. + description: ResourceGroupNameSelector - Selects a ResourceGroup to + reference. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object serverName: description: ServerName - Name of the Virtual Network Rule's server. type: string serverNameRef: - description: ServerNameRef - A reference to the Virtual Network Rule's MySQLServer. + description: ServerNameRef - A reference to the Virtual Network Rule's + MySQLServer. properties: name: description: Name of the referenced object. @@ -145,16 +171,22 @@ spec: description: ServerNameSelector - Selects a MySQLServer to reference. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -170,7 +202,8 @@ spec: - properties type: object status: - description: A VirtualNetworkRuleStatus represents the observed state of a VirtualNetworkRule. + description: A VirtualNetworkRuleStatus represents the observed state + of a VirtualNetworkRule. properties: conditions: description: Conditions of the resource. @@ -178,20 +211,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -204,7 +242,8 @@ spec: description: ID - Resource ID type: string message: - description: A Message containing details about the state of this virtual network rule, if any. + description: A Message containing details about the state of this + virtual network rule, if any. type: string state: description: State of this virtual network rule. diff --git a/package/crds/database.azure.crossplane.io_postgresqlserverconfigurations.yaml b/package/crds/database.azure.crossplane.io_postgresqlserverconfigurations.yaml index 8ed6b3c7..cca15728 100644 --- a/package/crds/database.azure.crossplane.io_postgresqlserverconfigurations.yaml +++ b/package/crds/database.azure.crossplane.io_postgresqlserverconfigurations.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: postgresqlserverconfigurations.database.azure.crossplane.io spec: @@ -34,37 +36,49 @@ spec: name: v1beta1 schema: openAPIV3Schema: - description: A PostgreSQLServerConfiguration is a managed resource that represents an Azure PostgreSQL Server Configuration. + description: A PostgreSQLServerConfiguration is a managed resource that represents + an Azure PostgreSQL Server Configuration. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A SQLServerConfigurationSpec defines the desired state of a SQLServer Configuration. + description: A SQLServerConfigurationSpec defines the desired state of + a SQLServer Configuration. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: SQLServerConfigurationParameters define the desired state of an Azure SQL Database Server Configuration, either PostgreSQL or MySQL Configuration. + description: SQLServerConfigurationParameters define the desired state + of an Azure SQL Database Server Configuration, either PostgreSQL + or MySQL Configuration. properties: name: description: Name - Configuration name to be applied type: string resourceGroupName: - description: ResourceGroupName specifies the name of the resource group that should contain this SQLServer. + description: ResourceGroupName specifies the name of the resource + group that should contain this SQLServer. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -73,22 +87,27 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - A selector for a ResourceGroup object to retrieve its name + description: ResourceGroupNameSelector - A selector for a ResourceGroup + object to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object serverName: - description: ServerName specifies the name of the server that this configuration applies to. + description: ServerName specifies the name of the server that + this configuration applies to. type: string serverNameRef: - description: ServerNameRef - A reference to a server object to retrieve its name + description: ServerNameRef - A reference to a server object to + retrieve its name properties: name: description: Name of the referenced object. @@ -97,19 +116,23 @@ spec: - name type: object serverNameSelector: - description: ServerNameSelector - A selector for a server object to retrieve its name + description: ServerNameSelector - A selector for a server object + to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object value: - description: Value - Configuration value to be applied Can be left unset to read the current value as a result of late-initialization. + description: Value - Configuration value to be applied Can be + left unset to read the current value as a result of late-initialization. type: string required: - name @@ -117,7 +140,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -126,7 +151,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -135,7 +162,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -151,10 +182,12 @@ spec: - forProvider type: object status: - description: A SQLServerConfigurationStatus represents the observed state of a SQLServerConfiguration. + description: A SQLServerConfigurationStatus represents the observed state + of a SQLServerConfiguration. properties: atProvider: - description: SQLServerConfigurationObservation represents the current state of Azure SQL resource. + description: SQLServerConfigurationObservation represents the current + state of Azure SQL resource. properties: dataType: description: DataType - Data type for the configuration @@ -169,16 +202,20 @@ spec: description: ID - Resource ID type: string lastOperation: - description: LastOperation represents the state of the last operation started by the controller. + description: LastOperation represents the state of the last operation + started by the controller. properties: errorMessage: - description: ErrorMessage represents the error that occurred during the operation. + description: ErrorMessage represents the error that occurred + during the operation. type: string method: - description: Method is HTTP method that the initial request is made with. + description: Method is HTTP method that the initial request + is made with. type: string pollingUrl: - description: PollingURL is used to fetch the status of the given operation. + description: PollingURL is used to fetch the status of the + given operation. type: string status: description: Status represents the status of the operation. @@ -203,20 +240,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_postgresqlserverfirewallrules.yaml b/package/crds/database.azure.crossplane.io_postgresqlserverfirewallrules.yaml index 6ee002b1..bc987518 100644 --- a/package/crds/database.azure.crossplane.io_postgresqlserverfirewallrules.yaml +++ b/package/crds/database.azure.crossplane.io_postgresqlserverfirewallrules.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: postgresqlserverfirewallrules.database.azure.crossplane.io spec: @@ -34,47 +36,60 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A PostgreSQLServerFirewallRule is a managed resource that represents an Azure PostgreSQL firewall rule. + description: A PostgreSQLServerFirewallRule is a managed resource that represents + an Azure PostgreSQL firewall rule. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A FirewallRuleSpec defines the desired state of an Azure SQL firewall rule. + description: A FirewallRuleSpec defines the desired state of an Azure + SQL firewall rule. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: FirewallRuleParameters define the desired state of an Azure SQL firewall rule. + description: FirewallRuleParameters define the desired state of an + Azure SQL firewall rule. properties: properties: description: FirewallRuleProperties - Resource properties. properties: endIpAddress: - description: EndIPAddress of the IP range this firewall rule allows. + description: EndIPAddress of the IP range this firewall rule + allows. type: string startIpAddress: - description: StartIPAddress of the IP range this firewall rule allows. + description: StartIPAddress of the IP range this firewall + rule allows. type: string required: - endIpAddress - startIpAddress type: object resourceGroupName: - description: ResourceGroupName - Name of the Firewall Rule's resource group. + description: ResourceGroupName - Name of the Firewall Rule's resource + group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -83,22 +98,26 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Selects a ResourceGroup to reference. + description: ResourceGroupNameSelector - Selects a ResourceGroup + to reference. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object serverName: description: ServerName - Name of the Firewall Rule's server. type: string serverNameRef: - description: ServerNameRef - A reference to the Firewall Rule's MySQLServer. + description: ServerNameRef - A reference to the Firewall Rule's + MySQLServer. properties: name: description: Name of the referenced object. @@ -110,12 +129,14 @@ spec: description: ServerNameSelector - Selects a MySQLServer to reference. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object required: @@ -124,7 +145,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -133,7 +156,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -142,7 +167,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -158,10 +187,12 @@ spec: - forProvider type: object status: - description: A FirewallRuleStatus represents the status of an Azure SQL firewall rule. + description: A FirewallRuleStatus represents the status of an Azure SQL + firewall rule. properties: atProvider: - description: A FirewallRuleObservation represents the observed state of an Azure SQL firewall rule. + description: A FirewallRuleObservation represents the observed state + of an Azure SQL firewall rule. properties: id: description: ID - Resource ID @@ -176,20 +207,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_postgresqlservers.yaml b/package/crds/database.azure.crossplane.io_postgresqlservers.yaml index dae19e73..eb286463 100644 --- a/package/crds/database.azure.crossplane.io_postgresqlservers.yaml +++ b/package/crds/database.azure.crossplane.io_postgresqlservers.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: postgresqlservers.database.azure.crossplane.io spec: @@ -34,13 +36,18 @@ spec: name: v1beta1 schema: openAPIV3Schema: - description: A PostgreSQLServer is a managed resource that represents an Azure PostgreSQL Database Server. + description: A PostgreSQLServer is a managed resource that represents an Azure + PostgreSQL Database Server. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -49,19 +56,26 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: SQLServerParameters define the desired state of an Azure SQL Database, either PostgreSQL or MySQL. + description: SQLServerParameters define the desired state of an Azure + SQL Database, either PostgreSQL or MySQL. properties: administratorLogin: - description: AdministratorLogin - The administrator's login name of a server. Can only be specified when the server is being created (and is required for creation). + description: AdministratorLogin - The administrator's login name + of a server. Can only be specified when the server is being + created (and is required for creation). type: string createMode: - description: 'CreateMode - Possible values include: ''CreateModeDefault'', ''CreateModePointInTimeRestore'', ''CreateModeGeoRestore'', ''CreateModeReplica''' + description: 'CreateMode - Possible values include: ''CreateModeDefault'', + ''CreateModePointInTimeRestore'', ''CreateModeGeoRestore'', + ''CreateModeReplica''' enum: - Default - GeoRestore @@ -75,16 +89,20 @@ spec: description: MinimalTLSVersion - control TLS connection policy type: string publicNetworkAccess: - description: PublicNetworkAccess - Whether or not public network access is allowed for this server. Value is optional but if passed in, must be 'Enabled' or 'Disabled'. + description: PublicNetworkAccess - Whether or not public network + access is allowed for this server. Value is optional but if + passed in, must be 'Enabled' or 'Disabled'. enum: - Enabled - Disabled type: string resourceGroupName: - description: ResourceGroupName specifies the name of the resource group that should contain this SQLServer. + description: ResourceGroupName specifies the name of the resource + group that should contain this SQLServer. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -93,35 +111,43 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - A selector for a ResourceGroup object to retrieve its name + description: ResourceGroupNameSelector - A selector for a ResourceGroup + object to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object restorePointInTime: - description: RestorePointInTime - Restore point creation time (RFC3339 format), specifying the time to restore from. + description: RestorePointInTime - Restore point creation time + (RFC3339 format), specifying the time to restore from. format: date-time type: string sku: - description: SKU is the billing information related properties of the server. + description: SKU is the billing information related properties + of the server. properties: capacity: - description: Capacity - The scale up/out capacity, representing server's compute units. + description: Capacity - The scale up/out capacity, representing + server's compute units. type: integer family: description: Family - The family of hardware. type: string size: - description: Size - The size code, to be interpreted by resource as appropriate. + description: Size - The size code, to be interpreted by resource + as appropriate. type: string tier: - description: 'Tier - The tier of the particular SKU. Possible values include: ''Basic'', ''GeneralPurpose'', ''MemoryOptimized''' + description: 'Tier - The tier of the particular SKU. Possible + values include: ''Basic'', ''GeneralPurpose'', ''MemoryOptimized''' enum: - Basic - GeneralPurpose @@ -133,10 +159,12 @@ spec: - tier type: object sourceServerID: - description: SourceServerID - The server to restore from when restoring or creating replicas + description: SourceServerID - The server to restore from when + restoring or creating replicas type: string sslEnforcement: - description: 'SSLEnforcement - Enable ssl enforcement or not when connect to server. Possible values include: ''Enabled'', ''Disabled''' + description: 'SSLEnforcement - Enable ssl enforcement or not when + connect to server. Possible values include: ''Enabled'', ''Disabled''' enum: - Enabled - Disabled @@ -145,16 +173,20 @@ spec: description: StorageProfile - Storage profile of a server. properties: backupRetentionDays: - description: BackupRetentionDays - Backup retention days for the server. + description: BackupRetentionDays - Backup retention days for + the server. type: integer geoRedundantBackup: - description: 'GeoRedundantBackup - Enable Geo-redundant or not for server backup. Possible values include: ''Enabled'', ''Disabled''' + description: 'GeoRedundantBackup - Enable Geo-redundant or + not for server backup. Possible values include: ''Enabled'', + ''Disabled''' enum: - Enabled - Disabled type: string storageAutogrow: - description: 'StorageAutogrow - Enable Storage Auto Grow. Possible values include: ''Enabled'', ''Disabled''' + description: 'StorageAutogrow - Enable Storage Auto Grow. + Possible values include: ''Enabled'', ''Disabled''' enum: - Enabled - Disabled @@ -168,7 +200,8 @@ spec: tags: additionalProperties: type: string - description: Tags - Application-specific metadata in the form of key-value pairs. + description: Tags - Application-specific metadata in the form + of key-value pairs. type: object version: description: Version - Server version. @@ -184,7 +217,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -193,7 +228,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -202,7 +239,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -221,32 +262,39 @@ spec: description: A SQLServerStatus represents the observed state of a SQLServer. properties: atProvider: - description: SQLServerObservation represents the current state of Azure SQL resource. + description: SQLServerObservation represents the current state of + Azure SQL resource. properties: fullyQualifiedDomainName: - description: FullyQualifiedDomainName - The fully qualified domain name of a server. + description: FullyQualifiedDomainName - The fully qualified domain + name of a server. type: string id: description: ID - Resource ID type: string lastOperation: - description: LastOperation represents the state of the last operation started by the controller. + description: LastOperation represents the state of the last operation + started by the controller. properties: errorMessage: - description: ErrorMessage represents the error that occurred during the operation. + description: ErrorMessage represents the error that occurred + during the operation. type: string method: - description: Method is HTTP method that the initial request is made with. + description: Method is HTTP method that the initial request + is made with. type: string pollingUrl: - description: PollingURL is used to fetch the status of the given operation. + description: PollingURL is used to fetch the status of the + given operation. type: string status: description: Status represents the status of the operation. type: string type: object masterServerId: - description: MasterServerID - The master server id of a replica server. + description: MasterServerID - The master server id of a replica + server. type: string name: description: Name - Resource name. @@ -255,7 +303,8 @@ spec: description: Type - Resource type. type: string userVisibleState: - description: UserVisibleState - A state of a server that is visible to user. + description: UserVisibleState - A state of a server that is visible + to user. type: string type: object conditions: @@ -264,20 +313,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/database.azure.crossplane.io_postgresqlservervirtualnetworkrules.yaml b/package/crds/database.azure.crossplane.io_postgresqlservervirtualnetworkrules.yaml index ff9537f7..12f030b1 100644 --- a/package/crds/database.azure.crossplane.io_postgresqlservervirtualnetworkrules.yaml +++ b/package/crds/database.azure.crossplane.io_postgresqlservervirtualnetworkrules.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: postgresqlservervirtualnetworkrules.database.azure.crossplane.io spec: @@ -34,22 +36,30 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A PostgreSQLServerVirtualNetworkRule is a managed resource that represents an Azure PostgreSQL Database virtual network rule. + description: A PostgreSQLServerVirtualNetworkRule is a managed resource that + represents an Azure PostgreSQL Database virtual network rule. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object spec: - description: A PostgreSQLVirtualNetworkRuleSpec defines the desired state of a PostgreSQLVirtualNetworkRule. + description: A PostgreSQLVirtualNetworkRuleSpec defines the desired state + of a PostgreSQLVirtualNetworkRule. properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -58,13 +68,16 @@ spec: description: VirtualNetworkRuleProperties - Resource properties. properties: ignoreMissingVnetServiceEndpoint: - description: IgnoreMissingVnetServiceEndpoint - Create firewall rule before the virtual network has vnet service endpoint enabled. + description: IgnoreMissingVnetServiceEndpoint - Create firewall + rule before the virtual network has vnet service endpoint enabled. type: boolean virtualNetworkSubnetId: - description: VirtualNetworkSubnetID - The ARM resource id of the virtual network subnet. + description: VirtualNetworkSubnetID - The ARM resource id of the + virtual network subnet. type: string virtualNetworkSubnetIdRef: - description: VirtualNetworkSubnetIDRef - A reference to a Subnet to retrieve its ID + description: VirtualNetworkSubnetIDRef - A reference to a Subnet + to retrieve its ID properties: name: description: Name of the referenced object. @@ -73,22 +86,27 @@ spec: - name type: object virtualNetworkSubnetIdSelector: - description: VirtualNetworkSubnetIDRef - A selector for a Subnet to retrieve its ID + description: VirtualNetworkSubnetIDRef - A selector for a Subnet + to retrieve its ID properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object type: object providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -97,7 +115,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -106,10 +126,12 @@ spec: - name type: object resourceGroupName: - description: ResourceGroupName - Name of the Virtual Network Rule's resource group. + description: ResourceGroupName - Name of the Virtual Network Rule's + resource group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to a ResourceGroup object to retrieve its name + description: ResourceGroupNameRef - A reference to a ResourceGroup + object to retrieve its name properties: name: description: Name of the referenced object. @@ -118,22 +140,26 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - A selector for a ResourceGroup object to retrieve its name + description: ResourceGroupNameSelector - A selector for a ResourceGroup + object to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object serverName: description: ServerName - Name of the Virtual Network Rule's PostgreSQLServer. type: string serverNameRef: - description: ServerNameRef - A reference to the Virtual Network Rule's PostgreSQLServer. + description: ServerNameRef - A reference to the Virtual Network Rule's + PostgreSQLServer. properties: name: description: Name of the referenced object. @@ -142,19 +168,26 @@ spec: - name type: object serverNameSelector: - description: ServerNameSelector - A selector of the Virtual Network Rule's PostgreSQLServer. + description: ServerNameSelector - A selector of the Virtual Network + Rule's PostgreSQLServer. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -170,7 +203,8 @@ spec: - properties type: object status: - description: A VirtualNetworkRuleStatus represents the observed state of a VirtualNetworkRule. + description: A VirtualNetworkRuleStatus represents the observed state + of a VirtualNetworkRule. properties: conditions: description: Conditions of the resource. @@ -178,20 +212,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -204,7 +243,8 @@ spec: description: ID - Resource ID type: string message: - description: A Message containing details about the state of this virtual network rule, if any. + description: A Message containing details about the state of this + virtual network rule, if any. type: string state: description: State of this virtual network rule. diff --git a/package/crds/keyvault.azure.crossplane.io_keyvaultsecrets.yaml b/package/crds/keyvault.azure.crossplane.io_keyvaultsecrets.yaml index 0a257d73..b021473e 100644 --- a/package/crds/keyvault.azure.crossplane.io_keyvaultsecrets.yaml +++ b/package/crds/keyvault.azure.crossplane.io_keyvaultsecrets.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: keyvaultsecrets.keyvault.azure.crossplane.io spec: @@ -33,13 +35,18 @@ spec: name: v1alpha1 schema: openAPIV3Schema: - description: A KeyVaultSecret is a managed resource that represents an Azure KeyVaultSecret cluster. + description: A KeyVaultSecret is a managed resource that represents an Azure + KeyVaultSecret cluster. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -48,13 +55,16 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete type: string forProvider: - description: KeyVaultSecretParameters defines the desired state of an Azure Key Vault Secret. https://docs.microsoft.com/en-us/rest/api/keyvault/#secret-operations + description: KeyVaultSecretParameters defines the desired state of + an Azure Key Vault Secret. https://docs.microsoft.com/en-us/rest/api/keyvault/#secret-operations properties: attributes: description: SecretAttributes - The secret management attributes @@ -67,12 +77,14 @@ spec: format: date-time type: string notBeforeDate: - description: NotBeforeDate - Not before date in UTC (RFC3339 format). + description: NotBeforeDate - Not before date in UTC (RFC3339 + format). format: date-time type: string type: object contentType: - description: ContentType - Type of the secret value such as a password + description: ContentType - Type of the secret value such as a + password type: string name: description: Name - The name of the secret @@ -80,7 +92,8 @@ spec: tags: additionalProperties: type: string - description: Tags - Application-specific metadata in the form of key-value pairs + description: Tags - Application-specific metadata in the form + of key-value pairs type: object value: description: Value - The value of the secret @@ -110,7 +123,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -119,7 +134,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -128,7 +145,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -144,10 +165,12 @@ spec: - forProvider type: object status: - description: A KeyVaultSecretStatus represents the observed state of a Secret. + description: A KeyVaultSecretStatus represents the observed state of a + Secret. properties: atProvider: - description: KeyVaultSecretObservation represents the observed state of the Secret object in Azure. + description: KeyVaultSecretObservation represents the observed state + of the Secret object in Azure. properties: attributes: description: Attributes - The secret management attributes. @@ -157,7 +180,14 @@ spec: format: date-time type: string recoveryLevel: - description: 'RecoveryLevel - READ-ONLY; Reflects the deletion recovery level currently in effect for secrets in the current vault. If it contains ''Purgeable'', the secret can be permanently deleted by a privileged user; otherwise, only the system can purge the secret, at the end of the retention interval. Possible values include: ''Purgeable'', ''RecoverablePurgeable'', ''Recoverable'', ''RecoverableProtectedSubscription'', ''CustomizedRecoverablePurgeable'', ''CustomizedRecoverable'', ''CustomizedRecoverableProtectedSubscription''' + description: 'RecoveryLevel - READ-ONLY; Reflects the deletion + recovery level currently in effect for secrets in the current + vault. If it contains ''Purgeable'', the secret can be permanently + deleted by a privileged user; otherwise, only the system + can purge the secret, at the end of the retention interval. + Possible values include: ''Purgeable'', ''RecoverablePurgeable'', + ''Recoverable'', ''RecoverableProtectedSubscription'', ''CustomizedRecoverablePurgeable'', + ''CustomizedRecoverable'', ''CustomizedRecoverableProtectedSubscription''' type: string updated: description: Updated - READ-ONLY; Last updated time in UTC. @@ -168,10 +198,14 @@ spec: description: ID - The secret id. type: string kid: - description: Kid - READ-ONLY; If this is a secret backing a KV certificate, then this field specifies the corresponding key backing the KV certificate. + description: Kid - READ-ONLY; If this is a secret backing a KV + certificate, then this field specifies the corresponding key + backing the KV certificate. type: string managed: - description: Managed - READ-ONLY; True if the secret's lifetime is managed by key vault. If this is a secret backing a certificate, then managed will be true. + description: Managed - READ-ONLY; True if the secret's lifetime + is managed by key vault. If this is a secret backing a certificate, + then managed will be true. type: boolean type: object conditions: @@ -180,20 +214,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/network.azure.crossplane.io_publicipaddresses.yaml b/package/crds/network.azure.crossplane.io_publicipaddresses.yaml index 5536b025..aebe9b60 100644 --- a/package/crds/network.azure.crossplane.io_publicipaddresses.yaml +++ b/package/crds/network.azure.crossplane.io_publicipaddresses.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: publicipaddresses.network.azure.crossplane.io spec: @@ -37,13 +39,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A PublicIPAddress is a managed resource that represents an Azure PublicIPAddress. + description: A PublicIPAddress is a managed resource that represents an Azure + PublicIPAddress. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -52,7 +59,9 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -61,34 +70,48 @@ spec: description: PublicIPAddressProperties defines properties of the PublicIPAddress. properties: allocationMethod: - description: 'PublicIPAllocationMethod - The public IP address allocation method. Possible values include: ''Static'', ''Dynamic''' + description: 'PublicIPAllocationMethod - The public IP address + allocation method. Possible values include: ''Static'', ''Dynamic''' enum: - Static - Dynamic type: string dnsSettings: - description: PublicIPAddressDNSSettings - The FQDN of the DNS record associated with the public IP address. + description: PublicIPAddressDNSSettings - The FQDN of the DNS + record associated with the public IP address. properties: domainNameLabel: - description: DomainNameLabel -the Domain name label. The concatenation of the domain name label and the regionalized DNS zone make up the fully qualified domain name associated with the public IP address. If a domain name label is specified, an A DNS record is created for the public IP in the Microsoft Azure DNS system. + description: DomainNameLabel -the Domain name label. The concatenation + of the domain name label and the regionalized DNS zone make + up the fully qualified domain name associated with the public + IP address. If a domain name label is specified, an A DNS + record is created for the public IP in the Microsoft Azure + DNS system. minLength: 1 type: string reverseFqdn: - description: ReverseFQDN - Gets or Sets the Reverse FQDN. A user-visible, fully qualified domain name that resolves to this public IP address. If the reverseFqdn is specified, then a PTR DNS record is created pointing from the IP address in the in-addr.arpa domain to the reverse FQDN. + description: ReverseFQDN - Gets or Sets the Reverse FQDN. + A user-visible, fully qualified domain name that resolves + to this public IP address. If the reverseFqdn is specified, + then a PTR DNS record is created pointing from the IP address + in the in-addr.arpa domain to the reverse FQDN. type: string required: - domainNameLabel type: object ipTags: - description: IPTags - IP tags to be assigned to this public IP address + description: IPTags - IP tags to be assigned to this public IP + address items: - description: IPTag list of tags to be assigned to this public IP + description: IPTag list of tags to be assigned to this public + IP properties: ipTagType: description: 'IPTagType - Type of the IP tag. Example: FirstPartyUsage.' type: string tag: - description: Tag - Value of the IpTag associated with the public IP. Example SQL, Storage etc. + description: Tag - Value of the IpTag associated with the + public IP. Example SQL, Storage etc. type: string required: - ipTagType @@ -100,13 +123,16 @@ spec: minLength: 1 type: string publicIPPrefixID: - description: PublicIPPrefixID - The Public IP Prefix this Public IP Address should be allocated from. + description: PublicIPPrefixID - The Public IP Prefix this Public + IP Address should be allocated from. type: string resourceGroupName: - description: ResourceGroupName - Name of the Public IP address's resource group. + description: ResourceGroupName - Name of the Public IP address's + resource group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to the the Public IP address's resource group. + description: ResourceGroupNameRef - A reference to the the Public + IP address's resource group. properties: name: description: Name of the referenced object. @@ -115,22 +141,26 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Select a reference to the Public IP address's resource group. + description: ResourceGroupNameSelector - Select a reference to + the Public IP address's resource group. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the + same controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object sku: description: SKU of PublicIPAddress properties: name: - description: 'Name - Name of sku. Possible values include: [''Standard'', ''Basic'']' + description: 'Name - Name of sku. Possible values include: + [''Standard'', ''Basic'']' enum: - Standard - Basic @@ -144,12 +174,14 @@ spec: description: Tags - Resource tags. type: object tcpIdleTimeoutInMinutes: - description: TCPIdleTimeoutInMinutes - Timeout in minutes for idle TCP connections + description: TCPIdleTimeoutInMinutes - Timeout in minutes for + idle TCP connections format: int32 minimum: 0 type: integer version: - description: 'PublicIPAllocationMethod - The public IP address version. Possible values include: ''IPv4'', ''IPv6''' + description: 'PublicIPAllocationMethod - The public IP address + version. Possible values include: ''IPv4'', ''IPv6''' enum: - IPv4 - IPv6 @@ -162,7 +194,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -171,7 +205,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -180,7 +216,11 @@ spec: - name type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -196,51 +236,74 @@ spec: - forProvider type: object status: - description: A PublicIPAddressStatus represents the observed state of a SQLServer. + description: A PublicIPAddressStatus represents the observed state of + a SQLServer. properties: atProvider: - description: A PublicIPAddressObservation represents the observed state of a PublicIPAddress. + description: A PublicIPAddressObservation represents the observed + state of a PublicIPAddress. properties: address: - description: Address - A string identifying address of PublicIPAddress resource + description: Address - A string identifying address of PublicIPAddress + resource type: string dnsSettings: description: DNSSettings observed DNS settings of the IP address properties: domainNameLabel: - description: DomainNameLabel -the Domain name label. The concatenation of the domain name label and the regionalized DNS zone make up the fully qualified domain name associated with the public IP address. If a domain name label is specified, an A DNS record is created for the public IP in the Microsoft Azure DNS system. + description: DomainNameLabel -the Domain name label. The concatenation + of the domain name label and the regionalized DNS zone make + up the fully qualified domain name associated with the public + IP address. If a domain name label is specified, an A DNS + record is created for the public IP in the Microsoft Azure + DNS system. type: string fqdn: - description: FQDN - Gets the FQDN, Fully qualified domain name of the A DNS record associated with the public IP. This is the concatenation of the domainNameLabel and the regionalized DNS zone. + description: FQDN - Gets the FQDN, Fully qualified domain + name of the A DNS record associated with the public IP. + This is the concatenation of the domainNameLabel and the + regionalized DNS zone. type: string reverseFqdn: - description: ReverseFQDN - Gets or Sets the Reverse FQDN. A user-visible, fully qualified domain name that resolves to this public IP address. If the reverseFqdn is specified, then a PTR DNS record is created pointing from the IP address in the in-addr.arpa domain to the reverse FQDN. + description: ReverseFQDN - Gets or Sets the Reverse FQDN. + A user-visible, fully qualified domain name that resolves + to this public IP address. If the reverseFqdn is specified, + then a PTR DNS record is created pointing from the IP address + in the in-addr.arpa domain to the reverse FQDN. type: string type: object etag: - description: Etag - A unique string that changes whenever the resource is updated. + description: Etag - A unique string that changes whenever the + resource is updated. type: string id: description: ID of this PublicIPAddress. type: string ipConfiguration: - description: IPConfiguration - The IP configuration associated with the public IP address + description: IPConfiguration - The IP configuration associated + with the public IP address properties: privateIPAddress: - description: PrivateIPAddress - The private IP address of the IP configuration. + description: PrivateIPAddress - The private IP address of + the IP configuration. type: string privateIPAllocationMethod: - description: 'PrivateIPAllocationMethod - The private IP address allocation method. Possible values include: ''Static'', ''Dynamic''' + description: 'PrivateIPAllocationMethod - The private IP address + allocation method. Possible values include: ''Static'', + ''Dynamic''' type: string provisioningState: - description: 'ProvisioningState - Gets the provisioning state of the public IP resource. Possible values are: ''Updating'', ''Deleting'', and ''Failed''.' + description: 'ProvisioningState - Gets the provisioning state + of the public IP resource. Possible values are: ''Updating'', + ''Deleting'', and ''Failed''.' type: string required: - privateIPAllocationMethod - provisioningState type: object message: - description: A Message providing detail about the state of this PublicIPAddress, if any. + description: A Message providing detail about the state of this + PublicIPAddress, if any. type: string state: description: State of this PublicIPAddress. @@ -258,20 +321,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/package/crds/network.azure.crossplane.io_subnets.yaml b/package/crds/network.azure.crossplane.io_subnets.yaml index a408c90c..42864b8a 100644 --- a/package/crds/network.azure.crossplane.io_subnets.yaml +++ b/package/crds/network.azure.crossplane.io_subnets.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: subnets.network.azure.crossplane.io spec: @@ -37,10 +39,14 @@ spec: description: A Subnet is a managed resource that represents an Azure Subnet. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -49,7 +55,9 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -63,7 +71,8 @@ spec: serviceEndpoints: description: ServiceEndpoints - An array of service endpoints. items: - description: ServiceEndpointPropertiesFormat defines properties of a service endpoint. + description: ServiceEndpointPropertiesFormat defines properties + of a service endpoint. properties: locations: description: Locations - A list of locations. @@ -71,7 +80,8 @@ spec: type: string type: array provisioningState: - description: ProvisioningState - The provisioning state of the resource. + description: ProvisioningState - The provisioning state + of the resource. type: string service: description: Service - The type of the endpoint service. @@ -84,7 +94,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -93,7 +105,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -105,7 +119,8 @@ spec: description: ResourceGroupName - Name of the Subnet's resource group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to the the Subnets's resource group. + description: ResourceGroupNameRef - A reference to the the Subnets's + resource group. properties: name: description: Name of the referenced object. @@ -114,22 +129,26 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Selects a reference to the the Subnets's resource group. + description: ResourceGroupNameSelector - Selects a reference to the + the Subnets's resource group. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object virtualNetworkName: description: VirtualNetworkName - Name of the Subnet's virtual network. type: string virtualNetworkNameRef: - description: VirtualNetworkNameRef references to a VirtualNetwork to retrieve its name + description: VirtualNetworkNameRef references to a VirtualNetwork + to retrieve its name properties: name: description: Name of the referenced object. @@ -138,19 +157,26 @@ spec: - name type: object virtualNetworkNameSelector: - description: VirtualNetworkNameSelector selects a reference to a VirtualNetwork to retrieve its name + description: VirtualNetworkNameSelector selects a reference to a VirtualNetwork + to retrieve its name properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -174,20 +200,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -197,16 +228,19 @@ spec: type: object type: array etag: - description: Etag - A unique string that changes whenever the resource is updated. + description: Etag - A unique string that changes whenever the resource + is updated. type: string id: description: ID of this Subnet. type: string message: - description: A Message providing detail about the state of this Subnet, if any. + description: A Message providing detail about the state of this Subnet, + if any. type: string purpose: - description: Purpose - A string identifying the intention of use for this subnet based on delegations and other user-defined properties. + description: Purpose - A string identifying the intention of use for + this subnet based on delegations and other user-defined properties. type: string state: description: State of this Subnet. diff --git a/package/crds/network.azure.crossplane.io_virtualnetworks.yaml b/package/crds/network.azure.crossplane.io_virtualnetworks.yaml index ef3dfb15..21bf1b78 100644 --- a/package/crds/network.azure.crossplane.io_virtualnetworks.yaml +++ b/package/crds/network.azure.crossplane.io_virtualnetworks.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: virtualnetworks.network.azure.crossplane.io spec: @@ -37,13 +39,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A VirtualNetwork is a managed resource that represents an Azure Virtual Network. + description: A VirtualNetwork is a managed resource that represents an Azure + Virtual Network. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -52,7 +59,9 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -61,13 +70,16 @@ spec: description: Location - Resource location. type: string properties: - description: VirtualNetworkPropertiesFormat - Properties of the virtual network. + description: VirtualNetworkPropertiesFormat - Properties of the virtual + network. properties: addressSpace: - description: AddressSpace - The AddressSpace that contains an array of IP address ranges that can be used by subnets. + description: AddressSpace - The AddressSpace that contains an + array of IP address ranges that can be used by subnets. properties: addressPrefixes: - description: AddressPrefixes - A list of address blocks reserved for this virtual network in CIDR notation. + description: AddressPrefixes - A list of address blocks reserved + for this virtual network in CIDR notation. items: type: string type: array @@ -75,16 +87,21 @@ spec: - addressPrefixes type: object enableDdosProtection: - description: EnableDDOSProtection - Indicates if DDoS protection is enabled for all the protected resources in the virtual network. It requires a DDoS protection plan associated with the resource. + description: EnableDDOSProtection - Indicates if DDoS protection + is enabled for all the protected resources in the virtual network. + It requires a DDoS protection plan associated with the resource. type: boolean enableVmProtection: - description: EnableVMProtection - Indicates if VM protection is enabled for all the subnets in the virtual network. + description: EnableVMProtection - Indicates if VM protection is + enabled for all the subnets in the virtual network. type: boolean type: object providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -93,7 +110,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -102,10 +121,12 @@ spec: - name type: object resourceGroupName: - description: ResourceGroupName - Name of the Virtual Network's resource group. + description: ResourceGroupName - Name of the Virtual Network's resource + group. type: string resourceGroupNameRef: - description: ResourceGroupNameRef - A reference to the the Virtual Network's resource group. + description: ResourceGroupNameRef - A reference to the the Virtual + Network's resource group. properties: name: description: Name of the referenced object. @@ -114,15 +135,18 @@ spec: - name type: object resourceGroupNameSelector: - description: ResourceGroupNameSelector - Select a reference to the the Virtual Network's resource group. + description: ResourceGroupNameSelector - Select a reference to the + the Virtual Network's resource group. properties: matchControllerRef: - description: MatchControllerRef ensures an object with the same controller reference as the selecting object is selected. + description: MatchControllerRef ensures an object with the same + controller reference as the selecting object is selected. type: boolean matchLabels: additionalProperties: type: string - description: MatchLabels ensures an object with matching labels is selected. + description: MatchLabels ensures an object with matching labels + is selected. type: object type: object tags: @@ -131,7 +155,11 @@ spec: description: Tags - Resource tags. type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -148,7 +176,8 @@ spec: - properties type: object status: - description: A VirtualNetworkStatus represents the observed state of a VirtualNetwork. + description: A VirtualNetworkStatus represents the observed state of a + VirtualNetwork. properties: conditions: description: Conditions of the resource. @@ -156,20 +185,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -179,13 +213,15 @@ spec: type: object type: array etag: - description: Etag - A unique read-only string that changes whenever the resource is updated. + description: Etag - A unique read-only string that changes whenever + the resource is updated. type: string id: description: ID of this VirtualNetwork. type: string message: - description: A Message providing detail about the state of this VirtualNetwork, if any. + description: A Message providing detail about the state of this VirtualNetwork, + if any. type: string resourceGuid: description: ResourceGUID - The GUID of this VirtualNetwork. diff --git a/package/crds/storage.azure.crossplane.io_accounts.yaml b/package/crds/storage.azure.crossplane.io_accounts.yaml index c56bb1e1..09580474 100644 --- a/package/crds/storage.azure.crossplane.io_accounts.yaml +++ b/package/crds/storage.azure.crossplane.io_accounts.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: accounts.storage.azure.crossplane.io spec: @@ -31,13 +33,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: An Account is a managed resource that represents an Azure Blob Service Account. + description: An Account is a managed resource that represents an Azure Blob + Service Account. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -46,7 +53,9 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -54,7 +63,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -63,7 +74,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -72,10 +85,12 @@ spec: - name type: object resourceGroupName: - description: ResourceGroupName specifies the resource group for this Account. + description: ResourceGroupName specifies the resource group for this + Account. type: string storageAccountSpec: - description: StorageAccountSpec specifies the desired state of this Account. + description: StorageAccountSpec specifies the desired state of this + Account. properties: identity: description: Identity - The identity of the resource. @@ -91,44 +106,61 @@ spec: type: string type: object kind: - description: 'Kind - Indicates the type of storage account. Possible values include: ''Storage'', ''BlobStorage''' + description: 'Kind - Indicates the type of storage account. Possible + values include: ''Storage'', ''BlobStorage''' enum: - Storage - BlobStorage type: string location: - description: Location - The location of the resource. This will be one of the supported and registered Azure Geo Regions (e.g. West US, East US, Southeast Asia, etc.). + description: Location - The location of the resource. This will + be one of the supported and registered Azure Geo Regions (e.g. + West US, East US, Southeast Asia, etc.). type: string properties: - description: StorageAccountSpecProperties - The parameters used to create the storage account. + description: StorageAccountSpecProperties - The parameters used + to create the storage account. properties: accessTier: - description: 'AccessTier - Required for storage accounts where kind = BlobStorage. The access tier used for billing. Possible values include: ''Hot'', ''Cool''' + description: 'AccessTier - Required for storage accounts where + kind = BlobStorage. The access tier used for billing. Possible + values include: ''Hot'', ''Cool''' enum: - Hot - Cool type: string customDomain: - description: CustomDomain - User domain assigned to the storage account. Name is the CNAME source. Only one custom domain is supported per storage account at this time. to clear the existing custom domain, use an empty string for the custom domain name property. + description: CustomDomain - User domain assigned to the storage + account. Name is the CNAME source. Only one custom domain + is supported per storage account at this time. to clear + the existing custom domain, use an empty string for the + custom domain name property. properties: name: - description: Name - custom domain name assigned to the storage account. Name is the CNAME source. + description: Name - custom domain name assigned to the + storage account. Name is the CNAME source. type: string useSubDomainName: - description: UseSubDomainName - Indicates whether indirect CNAME validation is enabled. + description: UseSubDomainName - Indicates whether indirect + CNAME validation is enabled. type: boolean type: object encryption: - description: Encryption - Provides the encryption settings on the account. If left unspecified the account encryption settings will remain the same. The default setting is unencrypted. + description: Encryption - Provides the encryption settings + on the account. If left unspecified the account encryption + settings will remain the same. The default setting is unencrypted. properties: keySource: - description: "KeySource - The encryption keySource (provider). \n Possible values (case-insensitive): Microsoft.Storage, Microsoft.Keyvault" + description: "KeySource - The encryption keySource (provider). + \n Possible values (case-insensitive): Microsoft.Storage, + Microsoft.Keyvault" enum: - Microsoft.Storage - Microsoft.Keyvault type: string keyvaultproperties: - description: KeyVaultProperties - Properties provided by key vault. + description: KeyVaultProperties - Properties provided + by key vault. properties: keyname: description: KeyName - The name of KeyVault key. @@ -137,17 +169,21 @@ spec: description: KeyVaultURI - The Uri of KeyVault. type: string keyversion: - description: KeyVersion - The version of KeyVault key. + description: KeyVersion - The version of KeyVault + key. type: string type: object services: - description: Services - List of services which support encryption. + description: Services - List of services which support + encryption. properties: blob: - description: Blob - The encryption function of the blob storage service. + description: Blob - The encryption function of the + blob storage service. type: boolean file: - description: File - The encryption function of the file storage service. + description: File - The encryption function of the + file storage service. type: boolean type: object type: object @@ -155,10 +191,17 @@ spec: description: NetworkRuleSet - Network rule set properties: bypass: - description: 'Bypass - Specifies whether traffic is bypassed for Logging/Metrics/AzureServices. Possible values are any combination of Logging|Metrics|AzureServices (For example, "Logging, Metrics"), or None to bypass none of those traffics. Possible values include: ''None'', ''Logging'', ''Metrics'', ''AzureServices''' + description: 'Bypass - Specifies whether traffic is bypassed + for Logging/Metrics/AzureServices. Possible values are + any combination of Logging|Metrics|AzureServices (For + example, "Logging, Metrics"), or None to bypass none + of those traffics. Possible values include: ''None'', + ''Logging'', ''Metrics'', ''AzureServices''' type: string defaultAction: - description: "DefaultAction - Specifies the default action of allow or deny when no other rules match. \n Possible values include: 'Allow', 'Deny'" + description: "DefaultAction - Specifies the default action + of allow or deny when no other rules match. \n Possible + values include: 'Allow', 'Deny'" enum: - Allow - Deny @@ -166,51 +209,66 @@ spec: ipRules: description: IPRules - Sets the IP ACL rules items: - description: IPRule IP rule with specific IP or IP range in CIDR format. + description: IPRule IP rule with specific IP or IP range + in CIDR format. properties: action: - description: 'Action - The action of IP ACL rule. Possible values include: ''Allow''' + description: 'Action - The action of IP ACL rule. + Possible values include: ''Allow''' enum: - Allow type: string value: - description: IPAddressOrRange - Specifies the IP or IP range in CIDR format. Only IPV4 address is allowed. + description: IPAddressOrRange - Specifies the IP + or IP range in CIDR format. Only IPV4 address + is allowed. type: string type: object type: array virtualNetworkRules: - description: VirtualNetworkRules - Sets the virtual network rules + description: VirtualNetworkRules - Sets the virtual network + rules items: description: VirtualNetworkRule virtual Network rule. properties: action: - description: 'Action - The action of virtual network rule. Possible values include: ''Allow''' + description: 'Action - The action of virtual network + rule. Possible values include: ''Allow''' enum: - Allow type: string id: - description: 'VirtualNetworkResourceID - Resource ID of a subnet, for example: /subscriptions/{subscriptionId}/resourceGroups/{groupName}/providers/Microsoft.Network/virtualNetworks/{vnetName}/subnets/{subnetName}.' + description: 'VirtualNetworkResourceID - Resource + ID of a subnet, for example: /subscriptions/{subscriptionId}/resourceGroups/{groupName}/providers/Microsoft.Network/virtualNetworks/{vnetName}/subnets/{subnetName}.' type: string type: object type: array type: object supportsHttpsTrafficOnly: - description: EnableHTTPSTrafficOnly - Allows https traffic only to storage service if sets to true. + description: EnableHTTPSTrafficOnly - Allows https traffic + only to storage service if sets to true. type: boolean type: object sku: description: Sku of the storage account. properties: capabilities: - description: Capabilities - The capability information in the specified sku, including file encryption, network acls, change notification, etc. + description: Capabilities - The capability information in + the specified sku, including file encryption, network acls, + change notification, etc. items: - description: skuCapability the capability information in the specified sku, including file encryption, network acls, change notification, etc. + description: skuCapability the capability information in + the specified sku, including file encryption, network + acls, change notification, etc. properties: name: - description: Name - The name of capability, The capability information in the specified sku, including file encryption, network acls, change notification, etc. + description: Name - The name of capability, The capability + information in the specified sku, including file encryption, + network acls, change notification, etc. type: string value: - description: Value - A string value to indicate states of given capability. Possibly 'true' or 'false'. + description: Value - A string value to indicate states + of given capability. Possibly 'true' or 'false'. enum: - true - false @@ -218,18 +276,25 @@ spec: type: object type: array kind: - description: "Kind - Indicates the type of storage account. \n Possible values include: 'Storage', 'BlobStorage'" + description: "Kind - Indicates the type of storage account. + \n Possible values include: 'Storage', 'BlobStorage'" enum: - Storage - BlobStorage type: string locations: - description: Locations - The set of locations that the Sku is available. This will be supported and registered Azure Geo Regions (e.g. West US, East US, Southeast Asia, etc.). + description: Locations - The set of locations that the Sku + is available. This will be supported and registered Azure + Geo Regions (e.g. West US, East US, Southeast Asia, etc.). items: type: string type: array name: - description: "Name - Gets or sets the sku name. Required for account creation; optional for update. Note that in older versions, sku name was called accountType. \n Possible values include: 'Standard_LRS', 'Standard_GRS', 'Standard_RAGRS', 'Standard_ZRS', 'Premium_LRS'" + description: "Name - Gets or sets the sku name. Required for + account creation; optional for update. Note that in older + versions, sku name was called accountType. \n Possible values + include: 'Standard_LRS', 'Standard_GRS', 'Standard_RAGRS', + 'Standard_ZRS', 'Premium_LRS'" enum: - Standard_LRS - Standard_GRS @@ -238,10 +303,12 @@ spec: - Premium_LRS type: string resourceType: - description: ResourceType - The type of the resource, usually it is 'storageAccounts'. + description: ResourceType - The type of the resource, usually + it is 'storageAccounts'. type: string tier: - description: "Tier - Gets the sku tier. This is based on the Sku name. \n Possible values include: 'Standard', 'Premium'" + description: "Tier - Gets the sku tier. This is based on the + Sku name. \n Possible values include: 'Standard', 'Premium'" enum: - Standard - Premium @@ -252,7 +319,12 @@ spec: tags: additionalProperties: type: string - description: Tags - A list of key value pairs that describe the resource. These tags can be used for viewing and grouping this resource (across resource groups). A maximum of 15 tags can be provided for a resource. Each tag must have a key with a length no greater than 128 characters and a value with a length no greater than 256 characters. + description: Tags - A list of key value pairs that describe the + resource. These tags can be used for viewing and grouping this + resource (across resource groups). A maximum of 15 tags can + be provided for a resource. Each tag must have a key with a + length no greater than 128 characters and a value with a length + no greater than 256 characters. type: object required: - kind @@ -260,7 +332,11 @@ spec: - sku type: object writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -285,20 +361,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime @@ -317,15 +398,22 @@ spec: description: Properties of this Account. properties: creationTime: - description: CreationTime - the creation date and time of the storage account in UTC. + description: CreationTime - the creation date and time of the + storage account in UTC. format: date-time type: string lastGeoFailoverTime: - description: LastGeoFailoverTime - the timestamp of the most recent instance of a failover to the secondary location. Only the most recent timestamp is retained. This element is not returned if there has never been a failover instance. Only available if the accountType is Standard_GRS or Standard_RAGRS. + description: LastGeoFailoverTime - the timestamp of the most recent + instance of a failover to the secondary location. Only the most + recent timestamp is retained. This element is not returned if + there has never been a failover instance. Only available if + the accountType is Standard_GRS or Standard_RAGRS. format: date-time type: string primaryEndpoints: - description: PrimaryEndpoints - the URLs that are used to perform a retrieval of a public blob, queue, or table object. Note that Standard_ZRS and Premium_LRS accounts only return the blob endpoint. + description: PrimaryEndpoints - the URLs that are used to perform + a retrieval of a public blob, queue, or table object. Note that + Standard_ZRS and Premium_LRS accounts only return the blob endpoint. properties: blob: description: Blob - the blob endpoint. @@ -341,17 +429,23 @@ spec: type: string type: object primaryLocation: - description: PrimaryLocation - the location of the primary data center for the storage account. + description: PrimaryLocation - the location of the primary data + center for the storage account. type: string provisioningState: - description: 'ProvisioningState - the status of the storage account at the time the operation was called. Possible values include: ''Creating'', ''ResolvingDNS'', ''Succeeded''' + description: 'ProvisioningState - the status of the storage account + at the time the operation was called. Possible values include: + ''Creating'', ''ResolvingDNS'', ''Succeeded''' enum: - Creating - ResolvingDNS - Succeeded type: string secondaryEndpoints: - description: SecondaryEndpoints - the URLs that are used to perform a retrieval of a public blob, queue, or table object from the secondary location of the storage account. Only available if the Sku name is Standard_RAGRS. + description: SecondaryEndpoints - the URLs that are used to perform + a retrieval of a public blob, queue, or table object from the + secondary location of the storage account. Only available if + the Sku name is Standard_RAGRS. properties: blob: description: Blob - the blob endpoint. @@ -367,13 +461,20 @@ spec: type: string type: object secondaryLocation: - description: SecondaryLocation - the location of the geo-replicated secondary for the storage account. Only available if the accountType is Standard_GRS or Standard_RAGRS. + description: SecondaryLocation - the location of the geo-replicated + secondary for the storage account. Only available if the accountType + is Standard_GRS or Standard_RAGRS. type: string statusOfPrimary: - description: 'StatusOfPrimary - the status indicating whether the primary location of the storage account is available or unavailable. Possible values include: ''Available'', ''Unavailable''' + description: 'StatusOfPrimary - the status indicating whether + the primary location of the storage account is available or + unavailable. Possible values include: ''Available'', ''Unavailable''' type: string statusOfSecondary: - description: 'StatusOfSecondary - the status indicating whether the secondary location of the storage account is available or unavailable. Only available if the Sku name is Standard_GRS or Standard_RAGRS. Possible values include: ''Available'', ''Unavailable''' + description: 'StatusOfSecondary - the status indicating whether + the secondary location of the storage account is available or + unavailable. Only available if the Sku name is Standard_GRS + or Standard_RAGRS. Possible values include: ''Available'', ''Unavailable''' enum: - Available - Unavailable diff --git a/package/crds/storage.azure.crossplane.io_containers.yaml b/package/crds/storage.azure.crossplane.io_containers.yaml index a6fefeeb..3e72b702 100644 --- a/package/crds/storage.azure.crossplane.io_containers.yaml +++ b/package/crds/storage.azure.crossplane.io_containers.yaml @@ -1,8 +1,10 @@ + +--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.4.0 + controller-gen.kubebuilder.io/version: v0.6.2 creationTimestamp: null name: containers.storage.azure.crossplane.io spec: @@ -37,13 +39,18 @@ spec: name: v1alpha3 schema: openAPIV3Schema: - description: A Container is a managed resource that represents an Azure Blob Storage Container. + description: A Container is a managed resource that represents an Azure Blob + Storage Container. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: 'APIVersion defines the versioned schema of this representation + of an object. Servers should convert recognized schemas to the latest + internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' type: string kind: - description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: 'Kind is a string value representing the REST resource this + object represents. Servers may infer this from the endpoint the client + submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' type: string metadata: type: object @@ -52,7 +59,9 @@ spec: properties: deletionPolicy: default: Delete - description: DeletionPolicy specifies what will happen to the underlying external when this managed resource is deleted - either "Delete" or "Orphan" the external resource. + description: DeletionPolicy specifies what will happen to the underlying + external when this managed resource is deleted - either "Delete" + or "Orphan" the external resource. enum: - Orphan - Delete @@ -65,7 +74,9 @@ spec: providerConfigRef: default: name: default - description: ProviderConfigReference specifies how the provider that will be used to create, observe, update, and delete this managed resource should be configured. + description: ProviderConfigReference specifies how the provider that + will be used to create, observe, update, and delete this managed + resource should be configured. properties: name: description: Name of the referenced object. @@ -74,7 +85,9 @@ spec: - name type: object providerRef: - description: 'ProviderReference specifies the provider that will be used to create, observe, update, and delete this managed resource. Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' + description: 'ProviderReference specifies the provider that will be + used to create, observe, update, and delete this managed resource. + Deprecated: Please use ProviderConfigReference, i.e. `providerConfigRef`' properties: name: description: Name of the referenced object. @@ -83,10 +96,15 @@ spec: - name type: object publicAccessType: - description: PublicAccessType for this container; either "blob" or "container". + description: PublicAccessType for this container; either "blob" or + "container". type: string writeConnectionSecretToRef: - description: WriteConnectionSecretToReference specifies the namespace and name of a Secret to which any connection details for this managed resource should be written. Connection details frequently include the endpoint, username, and password required to connect to the managed resource. + description: WriteConnectionSecretToReference specifies the namespace + and name of a Secret to which any connection details for this managed + resource should be written. Connection details frequently include + the endpoint, username, and password required to connect to the + managed resource. properties: name: description: Name of the secret. @@ -108,20 +126,25 @@ spec: description: A Condition that may apply to a resource. properties: lastTransitionTime: - description: LastTransitionTime is the last time this condition transitioned from one status to another. + description: LastTransitionTime is the last time this condition + transitioned from one status to another. format: date-time type: string message: - description: A Message containing details about this condition's last transition from one status to another, if any. + description: A Message containing details about this condition's + last transition from one status to another, if any. type: string reason: - description: A Reason for this condition's last transition from one status to another. + description: A Reason for this condition's last transition from + one status to another. type: string status: - description: Status of this condition; is it currently True, False, or Unknown? + description: Status of this condition; is it currently True, + False, or Unknown? type: string type: - description: Type of this condition. At most one of each condition type may apply to a resource at any point in time. + description: Type of this condition. At most one of each condition + type may apply to a resource at any point in time. type: string required: - lastTransitionTime diff --git a/pkg/clients/azure.go b/pkg/clients/azure.go index 10f66d56..e9df69fd 100644 --- a/pkg/clients/azure.go +++ b/pkg/clients/azure.go @@ -26,11 +26,11 @@ import ( "github.com/Azure/go-autorest/autorest/azure" "github.com/Azure/go-autorest/autorest/azure/auth" "github.com/Azure/go-autorest/autorest/to" - "github.com/pkg/errors" corev1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/types" "sigs.k8s.io/controller-runtime/pkg/client" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/provider-azure/apis/v1alpha3" diff --git a/pkg/clients/compute/aks.go b/pkg/clients/compute/aks.go index 4971fbaa..09214256 100644 --- a/pkg/clients/compute/aks.go +++ b/pkg/clients/compute/aks.go @@ -30,8 +30,8 @@ import ( "github.com/Azure/go-autorest/autorest/date" "github.com/Azure/go-autorest/autorest/to" "github.com/google/uuid" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/clients/database/cosmosdb/account.go b/pkg/clients/database/cosmosdb/account.go index 1b4b638e..1e1a37aa 100644 --- a/pkg/clients/database/cosmosdb/account.go +++ b/pkg/clients/database/cosmosdb/account.go @@ -25,7 +25,8 @@ import ( "github.com/Azure/azure-sdk-for-go/services/cosmos-db/mgmt/2015-04-08/documentdb" "github.com/Azure/azure-sdk-for-go/services/cosmos-db/mgmt/2015-04-08/documentdb/documentdbapi" "github.com/Azure/go-autorest/autorest/azure/auth" - "github.com/pkg/errors" + + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/provider-azure/apis/database/v1alpha3" azure "github.com/crossplane/provider-azure/pkg/clients" diff --git a/pkg/clients/database/cosmosdb/account_test.go b/pkg/clients/database/cosmosdb/account_test.go index 9820d83f..669a27c0 100644 --- a/pkg/clients/database/cosmosdb/account_test.go +++ b/pkg/clients/database/cosmosdb/account_test.go @@ -20,8 +20,8 @@ import ( "testing" "github.com/Azure/azure-sdk-for-go/services/cosmos-db/mgmt/2015-04-08/documentdb" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/test" @@ -40,7 +40,7 @@ func TestNewCosmosDBAccountClient(t *testing.T) { name: "EmptyData", args: []byte{}, wantRes: nil, - wantErr: errors.WithStack(errors.New("cannot unmarshal Azure client secret data: unexpected end of JSON input")), + wantErr: errors.Wrap(errors.New("unexpected end of JSON input"), "cannot unmarshal Azure client secret data"), }, { name: "Success", diff --git a/pkg/clients/database/mysql.go b/pkg/clients/database/mysql.go index 5a4fd899..a0fd8d0d 100644 --- a/pkg/clients/database/mysql.go +++ b/pkg/clients/database/mysql.go @@ -309,8 +309,11 @@ func UpdateMySQLObservation(o *azuredbv1beta1.SQLServerObservation, in mysql.Ser } // LateInitializeMySQL fills the empty values of SQLServerParameters with the -// ones that are retrieved from the Azure API. -func LateInitializeMySQL(p *azuredbv1beta1.SQLServerParameters, in mysql.Server) { +// ones that are retrieved from the Azure API. Returns true if the params were +// late initialized. +func LateInitializeMySQL(p *azuredbv1beta1.SQLServerParameters, in mysql.Server) bool { + before := p.DeepCopy() + if in.Sku != nil { p.SKU.Size = azure.LateInitializeStringPtrFromPtr(p.SKU.Size, in.Sku.Size) } @@ -329,6 +332,8 @@ func LateInitializeMySQL(p *azuredbv1beta1.SQLServerParameters, in mysql.Server) if p.PublicNetworkAccess == nil { p.PublicNetworkAccess = azure.ToStringPtr(string(in.PublicNetworkAccess)) } + + return !cmp.Equal(before, p) } // IsMySQLUpToDate is used to report whether given mysql.Server is in diff --git a/pkg/clients/database/postgresql.go b/pkg/clients/database/postgresql.go index 53642e99..ffc3c293 100644 --- a/pkg/clients/database/postgresql.go +++ b/pkg/clients/database/postgresql.go @@ -300,9 +300,11 @@ func UpdatePostgreSQLObservation(o *azuredbv1beta1.SQLServerObservation, in post o.MasterServerID = azure.ToString(in.MasterServerID) } -// LateInitializePostgreSQL fills the empty values of SQLServerParameters with the -// ones that are retrieved from the Azure API. -func LateInitializePostgreSQL(p *azuredbv1beta1.SQLServerParameters, in postgresql.Server) { +// LateInitializePostgreSQL fills the empty values of SQLServerParameters with +// the ones that are retrieved from the Azure API. Returns true if the params +// were late initialized. +func LateInitializePostgreSQL(p *azuredbv1beta1.SQLServerParameters, in postgresql.Server) bool { + before := p.DeepCopy() if in.Sku != nil { p.SKU.Size = azure.LateInitializeStringPtrFromPtr(p.SKU.Size, in.Sku.Size) } @@ -322,6 +324,8 @@ func LateInitializePostgreSQL(p *azuredbv1beta1.SQLServerParameters, in postgres if p.PublicNetworkAccess == nil { p.PublicNetworkAccess = azure.ToStringPtr(string(in.PublicNetworkAccess)) } + + return !cmp.Equal(before, p) } // IsPostgreSQLUpToDate is used to report whether given postgresql.Server is in diff --git a/pkg/clients/keyvault/secret/keyvault_secret.go b/pkg/clients/keyvault/secret/keyvault_secret.go index c57f1e49..902c504e 100644 --- a/pkg/clients/keyvault/secret/keyvault_secret.go +++ b/pkg/clients/keyvault/secret/keyvault_secret.go @@ -24,11 +24,11 @@ import ( "github.com/Azure/azure-sdk-for-go/services/keyvault/v7.0/keyvault" "github.com/Azure/go-autorest/autorest/date" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp/cmpopts" "github.com/mitchellh/copystructure" - "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "sigs.k8s.io/controller-runtime/pkg/client" diff --git a/pkg/clients/keyvault/secret/keyvault_secret_test.go b/pkg/clients/keyvault/secret/keyvault_secret_test.go index c49278c0..e37b648a 100644 --- a/pkg/clients/keyvault/secret/keyvault_secret_test.go +++ b/pkg/clients/keyvault/secret/keyvault_secret_test.go @@ -23,14 +23,15 @@ import ( "github.com/Azure/azure-sdk-for-go/services/keyvault/v7.0/keyvault" "github.com/Azure/go-autorest/autorest/date" - xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" - "github.com/crossplane/crossplane-runtime/pkg/test" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "sigs.k8s.io/controller-runtime/pkg/client" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/test" + "github.com/crossplane/provider-azure/apis/keyvault/v1alpha1" azure "github.com/crossplane/provider-azure/pkg/clients" ) diff --git a/pkg/clients/resourcegroup/resourcegroup.go b/pkg/clients/resourcegroup/resourcegroup.go index 70519e2f..36e70a78 100644 --- a/pkg/clients/resourcegroup/resourcegroup.go +++ b/pkg/clients/resourcegroup/resourcegroup.go @@ -22,8 +22,8 @@ import ( "github.com/Azure/azure-sdk-for-go/services/resources/mgmt/2018-05-01/resources" "github.com/Azure/azure-sdk-for-go/services/resources/mgmt/2018-05-01/resources/resourcesapi" "github.com/Azure/go-autorest/autorest/azure/auth" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/provider-azure/apis/v1alpha3" diff --git a/pkg/clients/storage/account.go b/pkg/clients/storage/account.go index 1898e837..c7433b82 100644 --- a/pkg/clients/storage/account.go +++ b/pkg/clients/storage/account.go @@ -24,7 +24,7 @@ import ( "github.com/Azure/azure-sdk-for-go/services/storage/mgmt/2017-06-01/storage" "github.com/Azure/go-autorest/autorest/azure/auth" "github.com/Azure/go-autorest/autorest/to" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" azure "github.com/crossplane/provider-azure/pkg/clients" ) diff --git a/pkg/clients/storage/account_test.go b/pkg/clients/storage/account_test.go index b127a1a4..80a3a627 100644 --- a/pkg/clients/storage/account_test.go +++ b/pkg/clients/storage/account_test.go @@ -21,8 +21,8 @@ import ( "github.com/Azure/azure-sdk-for-go/services/storage/mgmt/2017-06-01/storage" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/test" ) @@ -37,7 +37,7 @@ func TestNewStorageAccountClient(t *testing.T) { name: "EmptyData", args: []byte{}, wantRes: nil, - wantErr: errors.WithStack(errors.New("cannot unmarshal Azure client secret data: unexpected end of JSON input")), + wantErr: errors.Wrap(errors.New("unexpected end of JSON input"), "cannot unmarshal Azure client secret data"), }, { name: "Success", diff --git a/pkg/controller/azure.go b/pkg/controller/azure.go index 4f01ba0b..d23dc415 100644 --- a/pkg/controller/azure.go +++ b/pkg/controller/azure.go @@ -17,12 +17,9 @@ limitations under the License. package controller import ( - "time" - - "k8s.io/client-go/util/workqueue" ctrl "sigs.k8s.io/controller-runtime" - "github.com/crossplane/crossplane-runtime/pkg/logging" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/provider-azure/pkg/controller/cache" "github.com/crossplane/provider-azure/pkg/controller/compute" @@ -46,8 +43,8 @@ import ( ) // Setup Azure controllers. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { - for _, setup := range []func(ctrl.Manager, logging.Logger, workqueue.RateLimiter, time.Duration) error{ +func Setup(mgr ctrl.Manager, o controller.Options) error { + for _, setup := range []func(ctrl.Manager, controller.Options) error{ cache.SetupRedis, compute.SetupAKSCluster, mysqlserver.Setup, @@ -67,9 +64,9 @@ func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll ti container.Setup, secret.SetupSecret, } { - if err := setup(mgr, l, rl, poll); err != nil { + if err := setup(mgr, o); err != nil { return err } } - return config.Setup(mgr, l, rl) + return config.Setup(mgr, o) } diff --git a/pkg/controller/cache/redis.go b/pkg/controller/cache/redis.go index c4158a18..b042dd05 100644 --- a/pkg/controller/cache/redis.go +++ b/pkg/controller/cache/redis.go @@ -19,19 +19,16 @@ package cache import ( "context" "strconv" - "time" "github.com/Azure/azure-sdk-for-go/profiles/latest/redis/mgmt/redis" "github.com/Azure/azure-sdk-for-go/profiles/latest/redis/mgmt/redis/redisapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -55,22 +52,22 @@ const ( ) // SetupRedis adds a controller that reconciles Redis resources. -func SetupRedis(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func SetupRedis(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1beta1.RedisGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1beta1.RedisGroupVersionKind), + managed.WithExternalConnecter(&connector{kube: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1beta1.Redis{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1beta1.RedisGroupVersionKind), - managed.WithExternalConnecter(&connector{kube: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connector struct { diff --git a/pkg/controller/cache/redis_test.go b/pkg/controller/cache/redis_test.go index 675deb32..7ab164b6 100644 --- a/pkg/controller/cache/redis_test.go +++ b/pkg/controller/cache/redis_test.go @@ -26,10 +26,10 @@ import ( "github.com/Azure/azure-sdk-for-go/services/redis/mgmt/2018-03-01/redis" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" "sigs.k8s.io/controller-runtime/pkg/client" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/test" diff --git a/pkg/controller/compute/managed.go b/pkg/controller/compute/managed.go index 94b1146a..d8e7e5c2 100644 --- a/pkg/controller/compute/managed.go +++ b/pkg/controller/compute/managed.go @@ -18,19 +18,16 @@ package compute import ( "context" - "time" "github.com/Azure/go-autorest/autorest/to" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" "k8s.io/client-go/tools/clientcmd" - "k8s.io/client-go/util/workqueue" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/password" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" @@ -53,22 +50,22 @@ const ( ) // SetupAKSCluster adds a controller that reconciles AKSClusters. -func SetupAKSCluster(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func SetupAKSCluster(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.AKSClusterGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.AKSClusterGroupVersionKind), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.AKSCluster{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.AKSClusterGroupVersionKind), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/compute/managed_test.go b/pkg/controller/compute/managed_test.go index 16e884c0..9458ea58 100644 --- a/pkg/controller/compute/managed_test.go +++ b/pkg/controller/compute/managed_test.go @@ -25,8 +25,8 @@ import ( "github.com/Azure/go-autorest/autorest" "github.com/Azure/go-autorest/autorest/to" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/crossplane-runtime/pkg/test" diff --git a/pkg/controller/config/config.go b/pkg/controller/config/config.go index 16437649..5d44dbd8 100644 --- a/pkg/controller/config/config.go +++ b/pkg/controller/config/config.go @@ -17,13 +17,11 @@ limitations under the License. package config import ( - "k8s.io/client-go/util/workqueue" ctrl "sigs.k8s.io/controller-runtime" - "sigs.k8s.io/controller-runtime/pkg/controller" "sigs.k8s.io/controller-runtime/pkg/source" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/providerconfig" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -33,7 +31,7 @@ import ( // Setup adds a controller that reconciles ProviderConfigs by accounting for // their current usage. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := providerconfig.ControllerName(v1beta1.ProviderConfigGroupKind) of := resource.ProviderConfigKinds{ @@ -41,14 +39,14 @@ func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter) error { UsageList: v1beta1.ProviderConfigUsageListGroupVersionKind, } + r := providerconfig.NewReconciler(mgr, of, + providerconfig.WithLogger(o.Logger.WithValues("controller", name)), + providerconfig.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1beta1.ProviderConfig{}). Watches(&source.Kind{Type: &v1beta1.ProviderConfigUsage{}}, &resource.EnqueueRequestForProviderConfig{}). - Complete(providerconfig.NewReconciler(mgr, of, - providerconfig.WithLogger(l.WithValues("controller", name)), - providerconfig.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } diff --git a/pkg/controller/database/cosmosdb/managed.go b/pkg/controller/database/cosmosdb/managed.go index e9b91aa8..773a231b 100644 --- a/pkg/controller/database/cosmosdb/managed.go +++ b/pkg/controller/database/cosmosdb/managed.go @@ -19,18 +19,15 @@ package cosmosdb import ( "context" "net/http" - "time" "github.com/Azure/azure-sdk-for-go/services/cosmos-db/mgmt/2015-04-08/documentdb" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -50,23 +47,23 @@ const ( ) // Setup adds a controller that reconciles NoSQLAccount. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.CosmosDBAccountGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.CosmosDBAccountGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{kube: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.CosmosDBAccount{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.CosmosDBAccountGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{kube: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/cosmosdb/managed_test.go b/pkg/controller/database/cosmosdb/managed_test.go index 026f611b..fcc25353 100644 --- a/pkg/controller/database/cosmosdb/managed_test.go +++ b/pkg/controller/database/cosmosdb/managed_test.go @@ -24,12 +24,12 @@ import ( "github.com/Azure/azure-sdk-for-go/services/cosmos-db/mgmt/2015-04-08/documentdb" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" "sigs.k8s.io/controller-runtime/pkg/client" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/controller/database/mysqlserver/managed.go b/pkg/controller/database/mysqlserver/managed.go index a778c3ee..90a8a29e 100644 --- a/pkg/controller/database/mysqlserver/managed.go +++ b/pkg/controller/database/mysqlserver/managed.go @@ -22,16 +22,14 @@ import ( "time" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" - "k8s.io/client-go/util/workqueue" - "sigs.k8s.io/controller-runtime/pkg/controller" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/password" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" @@ -45,33 +43,32 @@ import ( // Error strings. const ( - errUpdateCR = "cannot update MySQLServer custom resource" - errGenPassword = "cannot generate admin password" - errNotMySQLServer = "managed resource is not a MySQLServer" - errCreateMySQLServer = "cannot create MySQLServer" - errUpdateMySQLServer = "cannot update MySQLServer" - errGetMySQLServer = "cannot get MySQLServer" - errDeleteMySQLServer = "cannot delete MySQLServer" - errFetchLastOperation = "cannot fetch last operation" + errGenPassword = "cannot generate admin password" + errNotMySQLServer = "managed resource is not a MySQLServer" + errCreateMySQLServer = "cannot create MySQLServer" + errUpdateMySQLServer = "cannot update MySQLServer" + errGetMySQLServer = "cannot get MySQLServer" + errDeleteMySQLServer = "cannot delete MySQLServer" ) // Setup adds a controller that reconciles MySQLServers. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1beta1.MySQLServerGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1beta1.MySQLServerGroupVersionKind), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithCreationGracePeriod(5*time.Minute), // TODO(negz): Tune me. + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1beta1.MySQLServer{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1beta1.MySQLServerGroupVersionKind), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { @@ -102,32 +99,20 @@ func (e *external) Observe(ctx context.Context, mg resource.Managed) (managed.Ex server, err := e.client.GetServer(ctx, cr) if azure.IsNotFound(err) { - if err := azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation); err != nil { - return managed.ExternalObservation{}, errors.Wrap(err, errFetchLastOperation) - } - // Azure returns NotFound for GET calls until creation is completed - // successfully and we cannot return `ResourceExists: false` during creation - // since this will cause `Create` to be called again and it's not idempotent. - // So, we check whether a creation operation in fact is in motion. - creating := cr.Status.AtProvider.LastOperation.Method == "PUT" && - cr.Status.AtProvider.LastOperation.Status == azure.AsyncOperationStatusInProgress - return managed.ExternalObservation{ResourceExists: creating}, nil + return managed.ExternalObservation{ResourceExists: false}, nil } if err != nil { return managed.ExternalObservation{}, errors.Wrap(err, errGetMySQLServer) } - database.LateInitializeMySQL(&cr.Spec.ForProvider, server) - if err := e.kube.Update(ctx, cr); err != nil { - return managed.ExternalObservation{}, errors.Wrap(err, errUpdateCR) - } + + // NOTE(negz): We make a best effort attempt to fetch the async op for + // backward compatibility. We used to use this operation to determine + // whether we had requested the database be created and whether the + // creation was successful. Now we instead use a creation grace period. + _ = azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation) + database.UpdateMySQLObservation(&cr.Status.AtProvider, server) - // We make this call after kube.Update since it doesn't update the - // status subresource but fetches the the whole object after it's done. So, - // changes to status has to be done after kube.Update in order not to get them - // lost. - if err := azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation); err != nil { - return managed.ExternalObservation{}, errors.Wrap(err, errFetchLastOperation) - } + switch cr.Status.AtProvider.UserVisibleState { case v1beta1.StateReady: cr.SetConditions(xpv1.Available()) @@ -136,8 +121,9 @@ func (e *external) Observe(ctx context.Context, mg resource.Managed) (managed.Ex } return managed.ExternalObservation{ - ResourceExists: true, - ResourceUpToDate: database.IsMySQLUpToDate(cr.Spec.ForProvider, server), + ResourceExists: true, + ResourceLateInitialized: database.LateInitializeMySQL(&cr.Spec.ForProvider, server), + ResourceUpToDate: database.IsMySQLUpToDate(cr.Spec.ForProvider, server), ConnectionDetails: managed.ConnectionDetails{ xpv1.ResourceCredentialsSecretEndpointKey: []byte(cr.Status.AtProvider.FullyQualifiedDomainName), xpv1.ResourceCredentialsSecretUserKey: []byte(fmt.Sprintf("%s@%s", cr.Spec.ForProvider.AdministratorLogin, meta.GetExternalName(cr))), @@ -160,13 +146,7 @@ func (e *external) Create(ctx context.Context, mg resource.Managed) (managed.Ext return managed.ExternalCreation{}, errors.Wrap(err, errCreateMySQLServer) } - return managed.ExternalCreation{ - ConnectionDetails: managed.ConnectionDetails{ - xpv1.ResourceCredentialsSecretPasswordKey: []byte(pw), - }, - }, errors.Wrap( - azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation), - errFetchLastOperation) + return managed.ExternalCreation{ConnectionDetails: managed.ConnectionDetails{xpv1.ResourceCredentialsSecretPasswordKey: []byte(pw)}}, nil } func (e *external) Update(ctx context.Context, mg resource.Managed) (managed.ExternalUpdate, error) { @@ -181,9 +161,7 @@ func (e *external) Update(ctx context.Context, mg resource.Managed) (managed.Ext return managed.ExternalUpdate{}, errors.Wrap(err, errUpdateMySQLServer) } - return managed.ExternalUpdate{}, errors.Wrap( - azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation), - errFetchLastOperation) + return managed.ExternalUpdate{}, nil } func (e *external) Delete(ctx context.Context, mg resource.Managed) error { @@ -199,7 +177,5 @@ func (e *external) Delete(ctx context.Context, mg resource.Managed) error { return errors.Wrap(err, errDeleteMySQLServer) } - return errors.Wrap( - azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation), - errFetchLastOperation) + return nil } diff --git a/pkg/controller/database/mysqlserver/managed_test.go b/pkg/controller/database/mysqlserver/managed_test.go index 0541b21a..ef389fdb 100644 --- a/pkg/controller/database/mysqlserver/managed_test.go +++ b/pkg/controller/database/mysqlserver/managed_test.go @@ -19,17 +19,15 @@ package mysqlserver import ( "context" "fmt" - "io/ioutil" "net/http" - "strings" "testing" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -152,34 +150,6 @@ func TestObserve(t *testing.T) { err: errors.Wrap(errBoom, errGetMySQLServer), }, }, - "ServerCreating": { - e: &external{ - client: &MockMySQLServerAPI{ - MockGetServer: func(_ context.Context, _ *v1beta1.MySQLServer) (mysql.Server, error) { - return mysql.Server{}, autorest.DetailedError{StatusCode: http.StatusNotFound} - }, - MockGetRESTClient: func() autorest.Sender { - return autorest.SenderFunc(func(req *http.Request) (*http.Response, error) { - return &http.Response{ - Request: req, - StatusCode: http.StatusAccepted, - Body: ioutil.NopCloser(strings.NewReader(inProgressResponse)), - ContentLength: int64(len([]byte(inProgressResponse))), - }, nil - }) - }, - }, - }, - args: args{ - ctx: context.Background(), - mg: mysqlserver(withLastOperation(azurev1alpha3.AsyncOperation{Method: http.MethodPut, PollingURL: "crossplane.io"})), - }, - want: want{ - eo: managed.ExternalObservation{ - ResourceExists: true, - }, - }, - }, "ServerNotFound": { e: &external{ client: &MockMySQLServerAPI{ @@ -232,8 +202,9 @@ func TestObserve(t *testing.T) { }, want: want{ eo: managed.ExternalObservation{ - ResourceExists: true, - ResourceUpToDate: true, + ResourceExists: true, + ResourceUpToDate: true, + ResourceLateInitialized: true, ConnectionDetails: managed.ConnectionDetails{ xpv1.ResourceCredentialsSecretEndpointKey: []byte(endpoint), xpv1.ResourceCredentialsSecretUserKey: []byte(fmt.Sprintf("%s@%s", admin, name)), diff --git a/pkg/controller/database/mysqlserverconfiguration/managed.go b/pkg/controller/database/mysqlserverconfiguration/managed.go index e89cc0e0..e23f4792 100644 --- a/pkg/controller/database/mysqlserverconfiguration/managed.go +++ b/pkg/controller/database/mysqlserverconfiguration/managed.go @@ -19,18 +19,15 @@ package mysqlserverconfiguration import ( "context" "fmt" - "time" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -55,23 +52,23 @@ const ( ) // Setup adds a controller that reconciles MySQLInstances. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1beta1.MySQLServerConfigurationGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1beta1.MySQLServerConfigurationGroupVersionKind), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithInitializers(managed.NewDefaultProviderConfig(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1beta1.MySQLServerConfiguration{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1beta1.MySQLServerConfigurationGroupVersionKind), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithInitializers(managed.NewDefaultProviderConfig(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/mysqlserverconfiguration/managed_test.go b/pkg/controller/database/mysqlserverconfiguration/managed_test.go index 3916c126..130d03b0 100644 --- a/pkg/controller/database/mysqlserverconfiguration/managed_test.go +++ b/pkg/controller/database/mysqlserverconfiguration/managed_test.go @@ -24,8 +24,8 @@ import ( "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/controller/database/mysqlserverfirewallrule/managed.go b/pkg/controller/database/mysqlserverfirewallrule/managed.go index b9849c6d..67147d38 100644 --- a/pkg/controller/database/mysqlserverfirewallrule/managed.go +++ b/pkg/controller/database/mysqlserverfirewallrule/managed.go @@ -18,19 +18,16 @@ package mysqlserverfirewallrule import ( "context" - "time" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql/mysqlapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -51,23 +48,23 @@ const ( ) // Setup adds a controller that reconciles MySQLServerFirewallRules. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.MySQLServerFirewallRuleGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.MySQLServerFirewallRuleGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.MySQLServerFirewallRule{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.MySQLServerFirewallRuleGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/mysqlserverfirewallrule/managed_test.go b/pkg/controller/database/mysqlserverfirewallrule/managed_test.go index 493568ef..6b76a5af 100644 --- a/pkg/controller/database/mysqlserverfirewallrule/managed_test.go +++ b/pkg/controller/database/mysqlserverfirewallrule/managed_test.go @@ -23,15 +23,16 @@ import ( "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" "github.com/Azure/go-autorest/autorest" + "github.com/google/go-cmp/cmp" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/types" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/crossplane-runtime/pkg/test" - "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/types" "github.com/crossplane/provider-azure/apis/database/v1alpha3" azure "github.com/crossplane/provider-azure/pkg/clients" diff --git a/pkg/controller/database/mysqlservervirtualnetworkrule/managed.go b/pkg/controller/database/mysqlservervirtualnetworkrule/managed.go index 969e34b9..96185da1 100644 --- a/pkg/controller/database/mysqlservervirtualnetworkrule/managed.go +++ b/pkg/controller/database/mysqlservervirtualnetworkrule/managed.go @@ -18,19 +18,16 @@ package mysqlservervirtualnetworkrule import ( "context" - "time" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql/mysqlapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -51,23 +48,23 @@ const ( ) // Setup adds a controller that reconciles MySQLServerVirtualNetworkRules. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.MySQLServerVirtualNetworkRuleGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.MySQLServerVirtualNetworkRuleGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.MySQLServerVirtualNetworkRule{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.MySQLServerVirtualNetworkRuleGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/mysqlservervirtualnetworkrule/managed_test.go b/pkg/controller/database/mysqlservervirtualnetworkrule/managed_test.go index dcdb2df9..3fd5947d 100644 --- a/pkg/controller/database/mysqlservervirtualnetworkrule/managed_test.go +++ b/pkg/controller/database/mysqlservervirtualnetworkrule/managed_test.go @@ -23,15 +23,16 @@ import ( "github.com/Azure/azure-sdk-for-go/services/mysql/mgmt/2017-12-01/mysql" "github.com/Azure/go-autorest/autorest" + "github.com/google/go-cmp/cmp" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/types" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/crossplane-runtime/pkg/test" - "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/types" "github.com/crossplane/provider-azure/apis/database/v1alpha3" azure "github.com/crossplane/provider-azure/pkg/clients" diff --git a/pkg/controller/database/postgresqlserver/managed.go b/pkg/controller/database/postgresqlserver/managed.go index 37ff3232..7eb45c97 100644 --- a/pkg/controller/database/postgresqlserver/managed.go +++ b/pkg/controller/database/postgresqlserver/managed.go @@ -24,16 +24,14 @@ import ( "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" v1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/types" - "k8s.io/client-go/util/workqueue" - "sigs.k8s.io/controller-runtime/pkg/controller" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/password" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" @@ -47,34 +45,33 @@ import ( // Error strings. const ( - errUpdateCR = "cannot update PostgreSQL custom resource" errGenPassword = "cannot generate admin password" errNotPostgreSQLServer = "managed resource is not a PostgreSQLServer" errCreatePostgreSQLServer = "cannot create PostgreSQLServer" errUpdatePostgreSQLServer = "cannot update PostgreSQLServer" errGetPostgreSQLServer = "cannot get PostgreSQLServer" errDeletePostgreSQLServer = "cannot delete PostgreSQLServer" - errFetchLastOperation = "cannot fetch last operation" errGetConnSecret = "cannot get connection secret" ) // Setup adds a controller that reconciles PostgreSQLInstances. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1beta1.PostgreSQLServerGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1beta1.PostgreSQLServerGroupVersionKind), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithCreationGracePeriod(5*time.Minute), // TODO(negz): Tune me. + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1beta1.PostgreSQLServer{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1beta1.PostgreSQLServerGroupVersionKind), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { @@ -104,32 +101,20 @@ func (e *external) Observe(ctx context.Context, mg resource.Managed) (managed.Ex } server, err := e.client.GetServer(ctx, cr) if azure.IsNotFound(err) { - if err := azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation); err != nil { - return managed.ExternalObservation{}, errors.Wrap(err, errFetchLastOperation) - } - // Azure returns NotFound for GET calls until creation is completed - // successfully and we cannot return `ResourceExists: false` during creation - // since this will cause `Create` to be called again and it's not idempotent. - // So, we check whether a creation operation in fact is in motion. - creating := cr.Status.AtProvider.LastOperation.Method == "PUT" && - cr.Status.AtProvider.LastOperation.Status == azure.AsyncOperationStatusInProgress - return managed.ExternalObservation{ResourceExists: creating}, nil + return managed.ExternalObservation{ResourceExists: false}, nil } if err != nil { return managed.ExternalObservation{}, errors.Wrap(err, errGetPostgreSQLServer) } - database.LateInitializePostgreSQL(&cr.Spec.ForProvider, server) - if err := e.kube.Update(ctx, cr); err != nil { - return managed.ExternalObservation{}, errors.Wrap(err, errUpdateCR) - } + + // NOTE(negz): We make a best effort attempt to fetch the async op for + // backward compatibility. We used to use this operation to determine + // whether we had requested the database be created and whether the + // creation was successful. Now we instead use a creation grace period. + _ = azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation) + database.UpdatePostgreSQLObservation(&cr.Status.AtProvider, server) - // We make this call after kube.Update since it doesn't update the - // status subresource but fetches the the whole object after it's done. So, - // changes to status has to be done after kube.Update in order not to get them - // lost. - if err := azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation); err != nil { - return managed.ExternalObservation{}, errors.Wrap(err, errFetchLastOperation) - } + // Any state beside 'ready' is considered unavailable. switch server.UserVisibleState { //nolint:exhaustive case v1beta1.StateReady: @@ -139,8 +124,9 @@ func (e *external) Observe(ctx context.Context, mg resource.Managed) (managed.Ex } o := managed.ExternalObservation{ - ResourceExists: true, - ResourceUpToDate: database.IsPostgreSQLUpToDate(cr.Spec.ForProvider, server), // NOTE(negz): We don't yet support updating Azure SQL servers. + ResourceExists: true, + ResourceLateInitialized: database.LateInitializePostgreSQL(&cr.Spec.ForProvider, server), + ResourceUpToDate: database.IsPostgreSQLUpToDate(cr.Spec.ForProvider, server), ConnectionDetails: managed.ConnectionDetails{ xpv1.ResourceCredentialsSecretEndpointKey: []byte(cr.Status.AtProvider.FullyQualifiedDomainName), xpv1.ResourceCredentialsSecretUserKey: []byte(fmt.Sprintf("%s@%s", cr.Spec.ForProvider.AdministratorLogin, meta.GetExternalName(cr))), @@ -190,13 +176,7 @@ func (e *external) Create(ctx context.Context, mg resource.Managed) (managed.Ext return managed.ExternalCreation{}, errors.Wrap(err, errCreatePostgreSQLServer) } - return managed.ExternalCreation{ - ConnectionDetails: managed.ConnectionDetails{ - xpv1.ResourceCredentialsSecretPasswordKey: []byte(pw), - }, - }, errors.Wrap( - azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation), - errFetchLastOperation) + return managed.ExternalCreation{ConnectionDetails: managed.ConnectionDetails{xpv1.ResourceCredentialsSecretPasswordKey: []byte(pw)}}, nil } func (e *external) Update(ctx context.Context, mg resource.Managed) (managed.ExternalUpdate, error) { @@ -211,9 +191,7 @@ func (e *external) Update(ctx context.Context, mg resource.Managed) (managed.Ext return managed.ExternalUpdate{}, errors.Wrap(err, errUpdatePostgreSQLServer) } - return managed.ExternalUpdate{}, errors.Wrap( - azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation), - errFetchLastOperation) + return managed.ExternalUpdate{}, nil } func (e *external) Delete(ctx context.Context, mg resource.Managed) error { @@ -228,7 +206,5 @@ func (e *external) Delete(ctx context.Context, mg resource.Managed) error { if err := e.client.DeleteServer(ctx, cr); resource.Ignore(azure.IsNotFound, err) != nil { return errors.Wrap(err, errDeletePostgreSQLServer) } - return errors.Wrap( - azure.FetchAsyncOperation(ctx, e.client.GetRESTClient(), &cr.Status.AtProvider.LastOperation), - errFetchLastOperation) + return nil } diff --git a/pkg/controller/database/postgresqlserver/managed_test.go b/pkg/controller/database/postgresqlserver/managed_test.go index a7288cf0..ad17fd6f 100644 --- a/pkg/controller/database/postgresqlserver/managed_test.go +++ b/pkg/controller/database/postgresqlserver/managed_test.go @@ -19,17 +19,15 @@ package postgresqlserver import ( "context" "fmt" - "io/ioutil" "net/http" - "strings" "testing" "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -152,34 +150,6 @@ func TestObserve(t *testing.T) { err: errors.Wrap(errBoom, errGetPostgreSQLServer), }, }, - "ServerCreating": { - e: &external{ - client: &MockPostgreSQLServerAPI{ - MockGetServer: func(_ context.Context, _ *v1beta1.PostgreSQLServer) (postgresql.Server, error) { - return postgresql.Server{}, autorest.DetailedError{StatusCode: http.StatusNotFound} - }, - MockGetRESTClient: func() autorest.Sender { - return autorest.SenderFunc(func(req *http.Request) (*http.Response, error) { - return &http.Response{ - Request: req, - StatusCode: http.StatusAccepted, - Body: ioutil.NopCloser(strings.NewReader(inProgressResponse)), - ContentLength: int64(len([]byte(inProgressResponse))), - }, nil - }) - }, - }, - }, - args: args{ - ctx: context.Background(), - mg: postgresqlserver(withLastOperation(azurev1alpha3.AsyncOperation{Method: http.MethodPut, PollingURL: "crossplane.io"})), - }, - want: want{ - eo: managed.ExternalObservation{ - ResourceExists: true, - }, - }, - }, "ServerNotFound": { e: &external{ client: &MockPostgreSQLServerAPI{ @@ -232,8 +202,9 @@ func TestObserve(t *testing.T) { }, want: want{ eo: managed.ExternalObservation{ - ResourceExists: true, - ResourceUpToDate: true, + ResourceExists: true, + ResourceUpToDate: true, + ResourceLateInitialized: true, ConnectionDetails: managed.ConnectionDetails{ xpv1.ResourceCredentialsSecretEndpointKey: []byte(endpoint), xpv1.ResourceCredentialsSecretUserKey: []byte(fmt.Sprintf("%s@%s", admin, name)), diff --git a/pkg/controller/database/postgresqlserverconfiguration/managed.go b/pkg/controller/database/postgresqlserverconfiguration/managed.go index a5ec2aa6..21502e72 100644 --- a/pkg/controller/database/postgresqlserverconfiguration/managed.go +++ b/pkg/controller/database/postgresqlserverconfiguration/managed.go @@ -19,19 +19,16 @@ package postgresqlserverconfiguration import ( "context" "fmt" - "time" "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" - xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" - "github.com/crossplane/crossplane-runtime/pkg/meta" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" + "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -54,23 +51,23 @@ const ( ) // Setup adds a controller that reconciles PostgreSQLInstances. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1beta1.PostgreSQLServerConfigurationGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1beta1.PostgreSQLServerConfigurationGroupVersionKind), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithInitializers(managed.NewDefaultProviderConfig(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1beta1.PostgreSQLServerConfiguration{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1beta1.PostgreSQLServerConfigurationGroupVersionKind), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithInitializers(managed.NewDefaultProviderConfig(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/postgresqlserverconfiguration/managed_test.go b/pkg/controller/database/postgresqlserverconfiguration/managed_test.go index fc1a19cb..4f123e98 100644 --- a/pkg/controller/database/postgresqlserverconfiguration/managed_test.go +++ b/pkg/controller/database/postgresqlserverconfiguration/managed_test.go @@ -25,12 +25,13 @@ import ( "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" "github.com/Azure/go-autorest/autorest" + "github.com/google/go-cmp/cmp" + + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/crossplane-runtime/pkg/test" - "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" "github.com/crossplane/provider-azure/apis/database/v1beta1" azurev1alpha3 "github.com/crossplane/provider-azure/apis/v1alpha3" diff --git a/pkg/controller/database/postgresqlserverfirewallrule/managed.go b/pkg/controller/database/postgresqlserverfirewallrule/managed.go index 38d732b6..fab20888 100644 --- a/pkg/controller/database/postgresqlserverfirewallrule/managed.go +++ b/pkg/controller/database/postgresqlserverfirewallrule/managed.go @@ -18,19 +18,16 @@ package postgresqlserverfirewallrule import ( "context" - "time" "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql/postgresqlapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -51,23 +48,23 @@ const ( ) // Setup adds a controller that reconciles PostgreSQLServerFirewallRules. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.PostgreSQLServerFirewallRuleGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.PostgreSQLServerFirewallRuleGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.PostgreSQLServerFirewallRule{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.PostgreSQLServerFirewallRuleGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/postgresqlserverfirewallrule/managed_test.go b/pkg/controller/database/postgresqlserverfirewallrule/managed_test.go index 3af42596..5c6401fd 100644 --- a/pkg/controller/database/postgresqlserverfirewallrule/managed_test.go +++ b/pkg/controller/database/postgresqlserverfirewallrule/managed_test.go @@ -23,15 +23,16 @@ import ( "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" "github.com/Azure/go-autorest/autorest" + "github.com/google/go-cmp/cmp" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/types" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/crossplane-runtime/pkg/test" - "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/types" "github.com/crossplane/provider-azure/apis/database/v1alpha3" azure "github.com/crossplane/provider-azure/pkg/clients" diff --git a/pkg/controller/database/postgresqlservervirtualnetworkrule/managed.go b/pkg/controller/database/postgresqlservervirtualnetworkrule/managed.go index e7e13b76..1bd8dc3c 100644 --- a/pkg/controller/database/postgresqlservervirtualnetworkrule/managed.go +++ b/pkg/controller/database/postgresqlservervirtualnetworkrule/managed.go @@ -18,23 +18,18 @@ package postgresqlservervirtualnetworkrule import ( "context" - "time" - - "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql/postgresqlapi" - "k8s.io/client-go/util/workqueue" - "sigs.k8s.io/controller-runtime/pkg/controller" "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" - - "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" - "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" - "github.com/pkg/errors" + "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql/postgresqlapi" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/event" "github.com/crossplane/crossplane-runtime/pkg/meta" + "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -53,23 +48,23 @@ const ( ) // Setup adds a controller that reconciles PostgreSQLServerVirtualNetworkRules. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.PostgreSQLServerVirtualNetworkRuleGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.PostgreSQLServerVirtualNetworkRuleGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.PostgreSQLServerVirtualNetworkRule{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.PostgreSQLServerVirtualNetworkRuleGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/database/postgresqlservervirtualnetworkrule/managed_test.go b/pkg/controller/database/postgresqlservervirtualnetworkrule/managed_test.go index 3c383621..174b03a1 100644 --- a/pkg/controller/database/postgresqlservervirtualnetworkrule/managed_test.go +++ b/pkg/controller/database/postgresqlservervirtualnetworkrule/managed_test.go @@ -23,15 +23,16 @@ import ( "github.com/Azure/azure-sdk-for-go/services/postgresql/mgmt/2017-12-01/postgresql" "github.com/Azure/go-autorest/autorest" + "github.com/google/go-cmp/cmp" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/types" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" "github.com/crossplane/crossplane-runtime/pkg/test" - "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" - metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" - "k8s.io/apimachinery/pkg/types" "github.com/crossplane/provider-azure/apis/database/v1alpha3" azure "github.com/crossplane/provider-azure/pkg/clients" diff --git a/pkg/controller/doc.go b/pkg/controller/doc.go deleted file mode 100644 index 65178afe..00000000 --- a/pkg/controller/doc.go +++ /dev/null @@ -1,17 +0,0 @@ -/* -Copyright 2019 The Crossplane Authors. - -Licensed under the Apache License, Version 2.0 (the "License"); -you may not use this file except in compliance with the License. -You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - -Unless required by applicable law or agreed to in writing, software -distributed under the License is distributed on an "AS IS" BASIS, -WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -See the License for the specific language governing permissions and -limitations under the License. -*/ - -package controller diff --git a/pkg/controller/keyvault/secret/keyvault_secret.go b/pkg/controller/keyvault/secret/keyvault_secret.go index 741f6e27..fd5c8ebb 100644 --- a/pkg/controller/keyvault/secret/keyvault_secret.go +++ b/pkg/controller/keyvault/secret/keyvault_secret.go @@ -18,20 +18,17 @@ package secret import ( "context" - "time" "github.com/Azure/azure-sdk-for-go/services/keyvault/v7.0/keyvault" "github.com/Azure/azure-sdk-for-go/services/keyvault/v7.0/keyvault/keyvaultapi" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -53,21 +50,21 @@ const ( ) // SetupSecret adds a controller that reconciles KeyVaultSecret resources. -func SetupSecret(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func SetupSecret(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha1.KeyVaultSecretGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha1.KeyVaultSecretGroupVersionKind), + managed.WithExternalConnecter(&connector{kube: mgr.GetClient()}), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha1.KeyVaultSecret{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha1.KeyVaultSecretGroupVersionKind), - managed.WithExternalConnecter(&connector{kube: mgr.GetClient()}), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connector struct { diff --git a/pkg/controller/keyvault/secret/keyvault_secret_test.go b/pkg/controller/keyvault/secret/keyvault_secret_test.go index 64e9e0d3..eb8f4971 100644 --- a/pkg/controller/keyvault/secret/keyvault_secret_test.go +++ b/pkg/controller/keyvault/secret/keyvault_secret_test.go @@ -23,16 +23,17 @@ import ( "github.com/Azure/azure-sdk-for-go/services/keyvault/v7.0/keyvault" "github.com/Azure/azure-sdk-for-go/services/keyvault/v7.0/keyvault/keyvaultapi" - xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" - "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" - "github.com/crossplane/crossplane-runtime/pkg/resource" - "github.com/crossplane/crossplane-runtime/pkg/test" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" corev1 "k8s.io/api/core/v1" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "sigs.k8s.io/controller-runtime/pkg/client" + xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" + "github.com/crossplane/crossplane-runtime/pkg/resource" + "github.com/crossplane/crossplane-runtime/pkg/test" + "github.com/crossplane/provider-azure/apis/keyvault/v1alpha1" azure "github.com/crossplane/provider-azure/pkg/clients" "github.com/crossplane/provider-azure/pkg/clients/keyvault/secret/fake" diff --git a/pkg/controller/network/publicipaddress/managed.go b/pkg/controller/network/publicipaddress/managed.go index e8e6bde4..eac51df8 100644 --- a/pkg/controller/network/publicipaddress/managed.go +++ b/pkg/controller/network/publicipaddress/managed.go @@ -18,19 +18,16 @@ package publicipaddress import ( "context" - "time" azurenetwork "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network" "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network/networkapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/controller" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" @@ -52,23 +49,23 @@ const ( ) // Setup adds a controller that reconciles Public Ip Address. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.PublicIPAddressGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.PublicIPAddressGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.PublicIPAddress{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.PublicIPAddressGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/network/publicipaddress/managed_test.go b/pkg/controller/network/publicipaddress/managed_test.go index 57926389..9cfa59b1 100644 --- a/pkg/controller/network/publicipaddress/managed_test.go +++ b/pkg/controller/network/publicipaddress/managed_test.go @@ -8,11 +8,11 @@ import ( "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/controller/network/subnet/managed.go b/pkg/controller/network/subnet/managed.go index a7b4f209..4c0ba298 100644 --- a/pkg/controller/network/subnet/managed.go +++ b/pkg/controller/network/subnet/managed.go @@ -18,21 +18,18 @@ package subnet import ( "context" - "time" azurenetwork "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network" "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network/networkapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" - "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -51,23 +48,23 @@ const ( ) // Setup adds a controller that reconciles Subnets. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.SubnetGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.SubnetGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.Subnet{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.SubnetGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/network/subnet/managed_test.go b/pkg/controller/network/subnet/managed_test.go index 39dd68c5..9ab46b86 100644 --- a/pkg/controller/network/subnet/managed_test.go +++ b/pkg/controller/network/subnet/managed_test.go @@ -24,11 +24,11 @@ import ( "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/controller/network/virtualnetwork/managed.go b/pkg/controller/network/virtualnetwork/managed.go index 12c4b87d..ac81ff06 100644 --- a/pkg/controller/network/virtualnetwork/managed.go +++ b/pkg/controller/network/virtualnetwork/managed.go @@ -18,21 +18,18 @@ package virtualnetwork import ( "context" - "time" azurenetwork "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network" "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network/networkapi" - "github.com/pkg/errors" - "k8s.io/client-go/util/workqueue" + "github.com/crossplane/crossplane-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" - "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -51,23 +48,23 @@ const ( ) // Setup adds a controller that reconciles VirtualNetworks. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.VirtualNetworkGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.VirtualNetworkGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), + managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.VirtualNetwork{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.VirtualNetworkGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{client: mgr.GetClient()}), - managed.WithReferenceResolver(managed.NewAPISimpleReferenceResolver(mgr.GetClient())), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/network/virtualnetwork/managed_test.go b/pkg/controller/network/virtualnetwork/managed_test.go index 323d436a..6e72a7df 100644 --- a/pkg/controller/network/virtualnetwork/managed_test.go +++ b/pkg/controller/network/virtualnetwork/managed_test.go @@ -24,11 +24,11 @@ import ( "github.com/Azure/azure-sdk-for-go/services/network/mgmt/2019-06-01/network" "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/controller/resourcegroup/resourcegroup.go b/pkg/controller/resourcegroup/resourcegroup.go index 28283bc5..bac67d5e 100644 --- a/pkg/controller/resourcegroup/resourcegroup.go +++ b/pkg/controller/resourcegroup/resourcegroup.go @@ -19,24 +19,21 @@ package resourcegroup import ( "context" "net/http" - "time" "github.com/Azure/azure-sdk-for-go/services/resources/mgmt/2018-05-01/resources" - "k8s.io/client-go/util/workqueue" - "sigs.k8s.io/controller-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" azure "github.com/crossplane/provider-azure/pkg/clients" "github.com/Azure/go-autorest/autorest/to" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/errors" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" "github.com/crossplane/crossplane-runtime/pkg/event" - "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" - "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -54,22 +51,22 @@ const ( ) // Setup adds a controller that reconciles ResourceGroups. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.ResourceGroupGroupKind) + r := managed.NewReconciler(mgr, + resource.ManagedKind(v1alpha3.ResourceGroupGroupVersionKind), + managed.WithConnectionPublishers(), + managed.WithExternalConnecter(&connecter{kube: mgr.GetClient()}), + managed.WithPollInterval(o.PollInterval), + managed.WithLogger(o.Logger.WithValues("controller", name)), + managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name)))) + return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.ResourceGroup{}). - Complete(managed.NewReconciler(mgr, - resource.ManagedKind(v1alpha3.ResourceGroupGroupVersionKind), - managed.WithConnectionPublishers(), - managed.WithExternalConnecter(&connecter{kube: mgr.GetClient()}), - managed.WithPollInterval(poll), - managed.WithLogger(l.WithValues("controller", name)), - managed.WithRecorder(event.NewAPIRecorder(mgr.GetEventRecorderFor(name))))) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } type connecter struct { diff --git a/pkg/controller/resourcegroup/resourcegroup_test.go b/pkg/controller/resourcegroup/resourcegroup_test.go index 1bf2b8e8..4bb06478 100644 --- a/pkg/controller/resourcegroup/resourcegroup_test.go +++ b/pkg/controller/resourcegroup/resourcegroup_test.go @@ -25,11 +25,11 @@ import ( "github.com/Azure/go-autorest/autorest" "github.com/Azure/go-autorest/autorest/to" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/types" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/meta" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" diff --git a/pkg/controller/storage/account/account.go b/pkg/controller/storage/account/account.go index e30d9941..5dca15e3 100644 --- a/pkg/controller/storage/account/account.go +++ b/pkg/controller/storage/account/account.go @@ -23,20 +23,19 @@ import ( "github.com/Azure/azure-sdk-for-go/services/storage/mgmt/2017-06-01/storage" "github.com/Azure/go-autorest/autorest/to" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" corev1 "k8s.io/api/core/v1" kerrors "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/types" - "k8s.io/client-go/util/workqueue" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" "sigs.k8s.io/controller-runtime/pkg/reconcile" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" - "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -71,25 +70,23 @@ type Reconciler struct { } // Setup adds a controller that reconciles Accounts. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.AccountGroupKind) r := &Reconciler{ Client: mgr.GetClient(), syncdeleterMaker: &accountSyncdeleterMaker{mgr.GetClient()}, Initializer: managed.NewNameAsExternalName(mgr.GetClient()), - poll: poll, - log: l.WithValues("controller", name), + poll: o.PollInterval, + log: o.Logger.WithValues("controller", name), } return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.Account{}). Owns(&corev1.Secret{}). - Complete(r) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } // Reconcile reads that state of the cluster for a Provider acct and makes changes based on the state read diff --git a/pkg/controller/storage/account/account_test.go b/pkg/controller/storage/account/account_test.go index e98c0d10..9e55d4a3 100644 --- a/pkg/controller/storage/account/account_test.go +++ b/pkg/controller/storage/account/account_test.go @@ -28,7 +28,6 @@ import ( "github.com/Azure/go-autorest/autorest" "github.com/Azure/go-autorest/autorest/to" "github.com/google/go-cmp/cmp" - "github.com/pkg/errors" kerrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" "k8s.io/apimachinery/pkg/runtime/schema" @@ -39,6 +38,7 @@ import ( "sigs.k8s.io/controller-runtime/pkg/reconcile" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/test" diff --git a/pkg/controller/storage/container/container.go b/pkg/controller/storage/container/container.go index 65d0ddb5..7652e9cc 100644 --- a/pkg/controller/storage/container/container.go +++ b/pkg/controller/storage/container/container.go @@ -23,20 +23,19 @@ import ( "github.com/Azure/azure-storage-blob-go/azblob" "github.com/Azure/go-autorest/autorest/to" - "github.com/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/controller" + "github.com/crossplane/crossplane-runtime/pkg/errors" + "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" corev1 "k8s.io/api/core/v1" kerrors "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/types" - "k8s.io/client-go/util/workqueue" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" - "sigs.k8s.io/controller-runtime/pkg/controller" "sigs.k8s.io/controller-runtime/pkg/reconcile" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/meta" - "github.com/crossplane/crossplane-runtime/pkg/ratelimiter" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/resource" @@ -75,24 +74,22 @@ type Reconciler struct { } // Setup adds a controller that reconciles Containers. -func Setup(mgr ctrl.Manager, l logging.Logger, rl workqueue.RateLimiter, poll time.Duration) error { +func Setup(mgr ctrl.Manager, o controller.Options) error { name := managed.ControllerName(v1alpha3.ContainerGroupKind) r := &Reconciler{ Client: mgr.GetClient(), syncdeleterMaker: &containerSyncdeleterMaker{mgr.GetClient()}, Initializer: managed.NewNameAsExternalName(mgr.GetClient()), - poll: poll, - log: l.WithValues("controller", name), + poll: o.PollInterval, + log: o.Logger.WithValues("controller", name), } return ctrl.NewControllerManagedBy(mgr). Named(name). - WithOptions(controller.Options{ - RateLimiter: ratelimiter.NewDefaultManagedRateLimiter(rl), - }). + WithOptions(o.ForControllerRuntime()). For(&v1alpha3.Container{}). - Complete(r) + Complete(ratelimiter.NewReconciler(name, r, o.GlobalRateLimiter)) } // Reconcile reads that state of the cluster for a Provider acct and makes changes based on the state read diff --git a/pkg/controller/storage/container/container_test.go b/pkg/controller/storage/container/container_test.go index 2d8a18d9..c404ac85 100644 --- a/pkg/controller/storage/container/container_test.go +++ b/pkg/controller/storage/container/container_test.go @@ -29,7 +29,6 @@ import ( "github.com/Azure/go-autorest/autorest" "github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp/cmpopts" - "github.com/pkg/errors" v1 "k8s.io/api/core/v1" kerrors "k8s.io/apimachinery/pkg/api/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" @@ -41,6 +40,7 @@ import ( "sigs.k8s.io/controller-runtime/pkg/reconcile" xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1" + "github.com/crossplane/crossplane-runtime/pkg/errors" "github.com/crossplane/crossplane-runtime/pkg/logging" "github.com/crossplane/crossplane-runtime/pkg/reconciler/managed" "github.com/crossplane/crossplane-runtime/pkg/test"